Rating: 5.0
## Walkthrough
This challenge gives us a set of credentials and two links. Since we're told the credentials are for git, lets open that page and login using them.
### Logging In
Heading to `git.challenge.nahamcon.com:MY_PORT_HERE` gives me this page:
data:image/s3,"s3://crabby-images/d66ba/d66bac88ab26128dabedc11f338c41d2fb7db808" alt="image"
After using the given credentials, we're asked to authorize an app, clicking authorize lets us proceed.
data:image/s3,"s3://crabby-images/fa884/fa884170d59c9982d94fc206f56cc26eead747c3" alt="image"
After doing that we're sent to a second login page. We can enter anything here:
data:image/s3,"s3://crabby-images/b467e/b467e3a86c0bc74c593590efa28b54e8adc018fc" alt="image"
That redirects us to `drone.challenge.nahamcon.com`. Lets head back to `git.challenge.nahamcon.com` and sign in to view the git repos.
### Fatal Flaw
We see there's a git repo at `http://git.challenge.nahamcon.com:30417/JustHacking/poisoned` additionally, based on this commit we can see how the CI/CD pipeline works and it's fatal flaw.
data:image/s3,"s3://crabby-images/70778/70778f52f8aa7bf62213c49ca32248045b8a562c" alt="image"
Heading back to drone, we can see the flag is being echo'd here but due to drones security settings it isn't be displayed.
data:image/s3,"s3://crabby-images/aa62a/aa62ac0e7814f87a2c26501033dfe07e468733f9" alt="image"
Before we make any changes lets make an ngrok tunnel using the command `ngrok 80 http` and save the url for later.
data:image/s3,"s3://crabby-images/d0783/d07834e7f8e19d240027bb42fba981de5e831ec0" alt="image"
### Forking Repo
Lets fork this repo and make some changes to get the flag.
data:image/s3,"s3://crabby-images/1dc60/1dc60b20a23b82ae6e2b18aee57a6d86fdc29f2d" alt="image"
*New commit in our forked repo*
All that's left is to make a pull request and see if it sends the flag over. Lets go ahead and do that.
data:image/s3,"s3://crabby-images/6c82b/6c82b87191000fced5217b4baadd5d95c97f9ad1" alt="image"
data:image/s3,"s3://crabby-images/0f1e6/0f1e60c64f801ad390d1ba74e3d373d42e9218c2" alt="image"
*Drone executing our .drone.yml*
### Flag
data:image/s3,"s3://crabby-images/2cfdb/2cfdb0845c517b19330372e19bce49ae2878af87" alt="image"
Success! It worked! The critical flaw in this app was allowing the CI/CD pipeline access to a secret environmental variable!