Tags: web
Rating:
# Arclbroth Writeup
**Team: M4j4nDyn4sty**
data:image/s3,"s3://crabby-images/c8cab/c8cabcdee36f1041dabc5615b55737501ebc896d" alt="Challenge Screenshot"
## Overview
Arclbroth is a web-game-based challenge where your objective is to brew a flag using "arcs" as your currency. Regular users start with just 10 arcs which is too few to meet the 50-arc threshold required to brew the flag while the admin account is automatically granted 100 arcs. Normally, the username "admin" is reserved and protected against duplicate registrations. However, by exploiting a null byte injection vulnerability during registration, I managed to bypass this restriction and register as the admin then voila I got the flag :)
## Vulnerability
**Null Byte Injection in Registration:** By injecting a null byte into the username, I was able to bypass the duplicate check.
## Exploitation
1. **Intercepting the Registration Request:**
I used Burp Suite to intercept the registration request. I attempted to register with the following credentials:
- **Username:** `admin\u0000hax`
- **Password:** `password`
I noticed that the website automatically added an extra escape character, changing the username to `admin\\u0000hax`
data:image/s3,"s3://crabby-images/cb43c/cb43c8ad7ba2583e9b6ebfad2d650f5ba18e3a6a" alt="Intercepting the Registration Request Screenshot"
2. **Correcting the Payload:**
Before forwarding the request, I edited the payload back to:
```json
{"username": "admin\u0000hax", "password": "password"}
```
data:image/s3,"s3://crabby-images/8349a/8349afe13b52e68c9513d005d38cfd13e4b4b7cf" alt="Correcting the Payload Screenshot"
3. **Logging in as Admin:**
After registering with the credentials above, the server processed the username as admin (since SQLite stops at the null byte), then I was logged in as admin and granted 100 arcs.
data:image/s3,"s3://crabby-images/8f38d/8f38d25630c694a23bccf4a2c592505121e01e2b" alt="Logging in as Admin Screenshot"
4. **Brewing the flag:**
Finally, I clicked the "brew" button. With 100 arcs available, the system deducted 50 arcs and returned the flag in the response:
`lactf{bulri3v3_it_0r_n0t_s3cur3_sqlit3_w4s_n0t_s3cur3}`
data:image/s3,"s3://crabby-images/7399e/7399e82f110c6f37597dc0f91d6ad0a150444fb5" alt="Brewing the Flag Screenshot"
Sincerely yours (Aura 10000+),
**Ahmed Al-Naamani (C00k1eSn4tch3r)**