Rating: 4.5
# Brokerboard
data:image/s3,"s3://crabby-images/fbf58/fbf58d5c0894bbef18a58f922769df63c7f1b63d" alt=""
The important part of the brief is the mentioning of the ```https://localhost/key``` endpoint. This is where the flag will most likely be returned from.
The challenge provided a web interface that fetches links.
data:image/s3,"s3://crabby-images/0dcf3/0dcf30a4fbbdd88d8d425e79fd9fc0afac3156d7" alt=""
As you can see from the image the url ```http://www.google.com``` has been parsed successfully. However, any attempts with localhost as the main host causes this error to be returned:
```
Ruh roh, we don't allow you to fetch internal URLs!
```
The second most important part of the brief is the hint towards the use of ```parse_url``` in the system. This will be our vulnerable entry point.
The bug used was data:image/s3,"s3://crabby-images/22d14/22d14eccba989f9bb0e81b666791491aa6150170" alt="#73192" of the PHP bug page. This states that the host in incorrectly parsed when the use of ```#``` after the port number of the original domain.
The payload used is below:
```
http://example.com:80#@localhost/key
```
NOTE: even though the website states that ```?``` and ```//``` can work in place of the ```#```. These were unable to work in this context.
By placing the playload into the link fetcher it circumvents the initial check for ```localhost``` while ```parse_url``` takes ```localhost/key``` as the main url.
The flag is provided like so:
data:image/s3,"s3://crabby-images/0ff22/0ff2227522ef4f30bce3c570568c772e63c4cbb7" alt=""
```
FLAG: flag{y0u_cANn0t_TRU5t_php}
```
++