With a long weekend ahead, I decided to gather a few friends and formed a team to participate in the DEFCON 29 RTV CTF. We came in with one goal in mind, to have fun. What I've covered in this 2-part post are only challenges that I attempted.
These are the challenges recorded in this part 1 of 2 post:
- Ancient Crypto Corner - The name's Caesar
- Cracking - Easy Crack 1 to 5
- Network Forensics - Protected OSPF
- FLAGUSB - Look at what Wireshark can do!
Challenge Start
The event challenge was released at 10AM (UTC) and these were the challenges.
data:image/s3,"s3://crabby-images/6a531/6a5318931c63251f4517d2e602043de318f11705" alt=""
More challenges were added along the way, and my friends and I went ahead to do what was available. Because all we wanted to do was have fun, so we just did what we found interesting.
The name's Caesar (Caesar Cipher)
I first started with the Caesar Cipher
(I like a salad before my entrée) challenge named The name's Caesar
, under the Ancient Crypto Corner
category.
data:image/s3,"s3://crabby-images/480e7/480e71ae1b83b5f0b81110b60dbbbecb13cc6be6" alt=""
data:image/s3,"s3://crabby-images/5281f/5281f1c5bb7a93da74aa144745f4e2d0eb022cd5" alt=""
Caesar Cipher
is a form of shift cipher
where a key would be pre-determined between senders/receivers so that either would know what each letter in the coded message actually represents. Read more here.
I used a public decoder and got the flag caesar_cipher_shift_of_three
. The +3
indicated the key shift was at 3
.
data:image/s3,"s3://crabby-images/69fd7/69fd78366a93ce29a28e0701964b846fcf96affc" alt=""
Easy Crack 1-5 (Hash cracking)
The next challenge I picked were challenges easy crack 1 to 5
.
data:image/s3,"s3://crabby-images/07cf7/07cf7cbf3b4ea943647409fde0f15bd675460fcb" alt=""
Easy Crack 1 and 5
were MD5 hashes which could was easily cracked when I looked up crackstation
.
data:image/s3,"s3://crabby-images/cbc4d/cbc4df5022fdeb903becaefe366e139e44f9a451" alt=""
data:image/s3,"s3://crabby-images/53f1c/53f1cf8ed92c65db01e23683b61fc0b409536e85" alt=""
Easy Crack 2,3 and 4
were luckily also found in wordlist after identifying the right type of hash.
I used hashcat
to identify the hash by recognising the pattern against hashcat example hashes
.
hashcat --example-hashes | grep "\$6\$*" -B 4
data:image/s3,"s3://crabby-images/d216f/d216f08853782f92ef6509eaf3308f29680498c8" alt=""
Knowing the mode to select, I ran hashcat
on the hashes (I saved all the hashes in a file called easycracks
) against rockyou.txt
to crack the hashes.
hashcat -m 1800 -a 0 easycracks /usr/share/wordlists/rockyou.txt
and after approximately 40-45 minutes, the hashes were cracked.
Christopher:$6$33VlMNJ9o4Xyi343$.1edgNlimWliqoXi2ETLEM4qQk7U.sYo2gCeqs9HlZMlvJGnibSP.BCw4cdpGUqE41Bxjp.fWI2iDKClGBxoR1 (2316AY)
Sean:$6$MPCZQ37FAGshRIep$W1lDSSonF8P080J/VmsS2QVsbkCGPVxcjomFiGTHsWrgS8wBOBWgYonUciXbpY/LmIxnKNX/j4lsuRFegZhFE0 (moe512)
Jessica:$6$qUX8cPJFtK0MIJqG$pFW1bnU4qaS8O9lv1gfsG3/CCa7F2SS12m5ivkrGVO7/Sqtd2/c.RR52d5WQ2461ZbTnOMh7zzGJoXZRO5/rP/ (shikari90)
For these challenges, the cracked hashes were the flag.
Cracking OSPF passphrase (Protected OSPF)
The next one was in the network forensics
category named Protected OSPF
.
data:image/s3,"s3://crabby-images/965cd/965cdf5df2210a48bf1981171331f11447b78380" alt=""
The file for this challenge was a .pcap
file, which contained a MD5 sum of the passphrase
used to secure the OSPF
routing protocol.
data:image/s3,"s3://crabby-images/3d48e/3d48e13f6b8db0630829577d0faa6429419344b6" alt=""
During this CTF, I learnt that ettercap is able to extract certain network protocol (e.g. OSPF, RIPv2) password hashes and convert the format for JohnTheRipper (JtR)
.
ettercap -Tqr ospf.pcap
T: Text-only
q: quiet
r: read file
data:image/s3,"s3://crabby-images/aeb77/aeb778ee67f439085b8f50cf8d9ba0c144209dd8" alt=""
With the extracted hashes, I ran JtR
with the hashes against rockyou.txt
and cracked the hash.
data:image/s3,"s3://crabby-images/6637a/6637a3e144632887ba929011c6254e439bbe1d10" alt=""
Recovering USB Raw Data from packet capture (.pcap) file.
The task was to extract raw USB data
from wireshark.
data:image/s3,"s3://crabby-images/9757f/9757f63c6899749783c3edd4a67863be372ac0dd" alt=""
The downloaded file was a .pcap
file that captured usb transfer data. What I was interested in were packets that contained data.
(usb.data_flag == "present (0)")
Also, the Info
field indicating USB_INTERRUPT in
intrigued me as it was likely a keystroke
or some form of I/O
.
data:image/s3,"s3://crabby-images/5ec1a/5ec1a1a8241c0c49e46b871fe0157c4e25828613" alt=""
I enabled the Leftover Capture Data
field as a column, because the value contains the raw USB data
. However, I had to find a way to extract the values efficiently. And I found that tshark
could do this.
tshark -r file.pcap -T fields -e usb.capdata
data:image/s3,"s3://crabby-images/ab843/ab8434382bb6183cae277152b8881f4edf042b6f" alt=""
I looked up online and came across a similar scenario where the individual was trying to extract raw USB data
.
Also it confirmed my suspicions that the USB_INTERRUPT in
was indeed for keystrokes
.
I successfully extracted the message using the script in the blogpost (credits to the author), which converts the Usage IDs
into ASCII keystrokes
.
data:image/s3,"s3://crabby-images/5b326/5b326acb4895bea7aae6fd50be6d586191120a4b" alt=""
data:image/s3,"s3://crabby-images/761a5/761a51aa40510efbe30cd686ecfe2e08fe03604a" alt=""