TUCTF 2017 | Web Challenges
by Keramas
Challenge:High Source
Category:
Web
data:image/s3,"s3://crabby-images/c04d4/c04d482344f99d950b8a2addd2bfa60cca0758b1" alt=""
Accessing the web page and immediately looking at the source we get trolled. Nothing here... But what about in the login.js source?
data:image/s3,"s3://crabby-images/4a26a/4a26af8453d1a7c21af5cb4264770bccf1a1050a" alt=""
Oh hey, a password! Using this to login we then get our flag!
data:image/s3,"s3://crabby-images/95c9f/95c9f9f3a00a7b180fc288a6641919423952945a" alt=""
data:image/s3,"s3://crabby-images/770bc/770bcaf8ced3727a9f1e6c3b99ec802842bbbdb1" alt=""
Challenge:
Cookie Duty
Category:
Web
data:image/s3,"s3://crabby-images/4d3d5/4d3d5449c127b30d1216edddcc637c420e505a56" alt=""
data:image/s3,"s3://crabby-images/6f5ef/6f5ef22d4f91b7988fc42c3fb8c28497fd919aa6" alt=""
The first page we land on gives a good hint as to what this will entail with cookies... We aren't admin, but can we become an admin by modifying the cookie? "not_admin" is set to a 1 flag, so if we modify this to a 0 we should be able to become admin.
data:image/s3,"s3://crabby-images/474d9/474d939fb6237767b753ce28ccbb38b3486265ff" alt=""
Changing the cookie and making a GET request with Burp Suite, we trick it to thinking we are admin and get our flag!
data:image/s3,"s3://crabby-images/fbcd8/fbcd8aed35d86b1fa54d98f87b320f03cad3d048" alt=""
Challenge:
Git Gud
Category:
Web
data:image/s3,"s3://crabby-images/6fa43/6fa436a0e53368ba7172dcebc6a6e0152681b746" alt=""
Based on the challenge description we know that the site is using Version Control Systems and the title also gives it away that we are looking for something git-related. After researching some stuff about this, it's possible to access a directory at /.git which gives all of the history info, objects, what have you.
data:image/s3,"s3://crabby-images/d9f48/d9f480f1e43e40d125846ab400d036d17655e5fa" alt=""
To make this a bit easier, I just downloaded everything and used comannd line to traverse through the directories. In the master file you can see an update entry for adding a flag, and using the data on the left we can cat the info until we are able to see the past entry and get our flag!
data:image/s3,"s3://crabby-images/fbb18/fbb18d3103ac1b532bf341804796594ae87bf5b1" alt=""
data:image/s3,"s3://crabby-images/8fcc9/8fcc9401b9a59c6fbc3f7fac6048501ef4f181f1" alt=""
Challenge:
Cookie Harrelson
Category:
Web
data:image/s3,"s3://crabby-images/7f3b6/7f3b699d3145a8539408cc27e74fda5bd78dad87" alt=""
More cookies! Inspecting the response/request headers upon loading, we can see that there is a cookie being passed.
data:image/s3,"s3://crabby-images/1377d/1377d93551f64521d983a1533946b24dfbfdbdb1" alt=""
This coded in base64, and decoding it we get:
cat index.txt
Neat... so what if we just encode something like 'cat flag.txt' in base64 and swap it in? Well, this is what I did, but it wasn't as easy as that. Unfortunately when subbing in something different, the cookie gets modified and it becomes something like this:
cat index.txt #(new command here)
So we are getting filtered and need to bypass it somehow! After a lot of experimentation/trial and error, the trick here is to get a carriage return. Using Burp to decode the original cookie, modify it, and then re-encode it, we get our new cookie.
data:image/s3,"s3://crabby-images/41125/41125c5c8c67e844a9be7403cd3c3e88272399dc" alt=""
Now we can put this in the repeater and make our GET request, which gives us the flag!
data:image/s3,"s3://crabby-images/06723/067237bd546da56bf6a1d1f578885703b098dc93" alt=""
Challenge:
iFrame and Shame
Category:
Web
data:image/s3,"s3://crabby-images/507b3/507b3255ccb3b30c7df1ebbcbbb71052eaed5684" alt=""
This challenge took a bit of trial and error to solve. I started by checking for input validation in the search box by adding an " and that seemed to break the format a bit, which kind of tipped me off there may be a possibility for code injection.
After trying different things for a while, the following command worked as a test:
"; echo $(ls) #
data:image/s3,"s3://crabby-images/ddaa7/ddaa795684044a2f739685291913c1ef2e88e6cc" alt=""
Based on this, we just change our command to give us our flag:
"; echo $(cat flag) #
data:image/s3,"s3://crabby-images/e7512/e7512d34d59676fd70a8d70da80f0273e4ea14bb" alt=""
tags: CTF challenge