The weather is terrible and I have nothing planned, you know what that means…..CTF weekend!! Reviewed ctftime and seen a CTF I would be interested in called CODEGATE. CODEGATE has organized international hacking competitions since 2008 so this has to be good. Lets jump right in.
Pre CTF
Before any CTF I do the following:
- Ensure VPN is working properly
- Update CTF Template
- Clone CTF Template for CODEGATE (Trash the VM after each CTF)
- Start OBS Studio (Allows for moving quickly through the CTF, so I can do the write up later)
Registering
data:image/s3,"s3://crabby-images/60224/6022417cab3bc136eaca377d901dede173b7fad8" alt=""
data:image/s3,"s3://crabby-images/1af06/1af069ffb590350d21decbc4cf3c096ea5a9fdb6" alt=""
Check_Check(1pt):
After registering, I look for the “Are you competent?” challenge that typically reveals the format of the flags moving forward.
This challenge for CODEGATE was called check_check.
data:image/s3,"s3://crabby-images/787ba/787ba97741372c78b3e069f01c3973b53ddf5772" alt=""
The checkcheck.jpg is a QR code.
data:image/s3,"s3://crabby-images/8fc37/8fc37f29d5a1734115ae1aa4e99ed929743b7e95" alt=""
I done a quick google for an open source project that reads QR codes. I found and installed zbar-tools and downloaded the .jpg. Now lets try this new tool with zbarimg “checkcheck.jpg.png”
root@kali:# sudo apt-get install zbar-tools
root@kali:~/Downloads# ls
checkcheck.jpg.png
root@kali:~/Downloads# zbarimg "checkcheck.jpg.png"
QR-Code:CODEGATE2020{Q_R_C_O_D_E}
scanned 1 barcode symbols from 1 images in 0.03 seconds
data:image/s3,"s3://crabby-images/66e3a/66e3ac2072647ec111a9da451f805a94863c4fc6" alt=""
Nice! This is a reason I love CTFs. They force me to reach out for new tools I never knew existed.
data:image/s3,"s3://crabby-images/a3957/a3957a6f04e7132344108f7b3e3d095bfdc808b3" alt=""
data:image/s3,"s3://crabby-images/439c5/439c5ae8786af17d9169712ebfaa669c1d23612d" alt=""
Alright we have 1 point. Off to a good start.
LOL(27pt):
The LOL challenge provided a link to download a file. Downloaded file.
data:image/s3,"s3://crabby-images/076f5/076f53bc577c14e2be92920107cbf9a7e828edd1" alt=""
Almost every new file for me goes through Ghidra first (during a CTF). Pull up Ghidra and extract the filesystem.
data:image/s3,"s3://crabby-images/86c1a/86c1acb36a971c140d031ea1334cd4a330fa4550" alt=""
Ahh, here we see a gif. This should be interesting.
data:image/s3,"s3://crabby-images/8990a/8990a0b1336bb1540cf5a4233649055009c5e3d4" alt=""
Import Legend.gif into the project to be analyzed by Ghidra. I will be using x86 64bit gcc language.
data:image/s3,"s3://crabby-images/d49f6/d49f6b256275cdb443870bfbc65ec894189fee11" alt=""
data:image/s3,"s3://crabby-images/76f87/76f87320eb91c0d5a8f201041f878f65a7d8723a" alt=""
Once the file was imported, Ghidra asks if I wanted to analyze the file. Yes…..yes I do. This was the result!
data:image/s3,"s3://crabby-images/dbfda/dbfda3a5ddd4f6425438d83c6b60892c12613764" alt=""
After scrolling through seven or so League of Legends champions, I found the flag. CODEGATE2020{J!n*_L00s3_C@^^0^} 27pts.
ENIGMA (49pts)
Enigma started with another file to download. Downloaded file and loaded into Ghidra as file system.
data:image/s3,"s3://crabby-images/6d1a9/6d1a96fb371bbbf94757aaa9f1e86ba1fe3b5cf8" alt=""
Lets export the file and take a look at what we have.
data:image/s3,"s3://crabby-images/392bb/392bb5d63f5cf9ed7402f2d3e82f79e84b40a99b" alt=""
Viewing the file shows a simple substitution key.
data:image/s3,"s3://crabby-images/bdca4/bdca4c87f0687b19b93abb7238d560899044dfea" alt=""
After replacing the values after “flag is :” we got the following flag.
CODEGATE2020{HACKERS ARE NOT BORN ONLY IT IS MADE}
Summary
Overall, ended up with 77pts and had a great time. Until next time, Stay safe in the Trenches of IT!