Disclaimer
This blog post is a part of NSA Codebreaker 2024 writeup.
The challenge content is a PURELY FICTIONAL SCENARIO created by the NSA for EDUCATIONAL PURPOSES only. The mention and use of any actual products, tools, and techniques are similarly contrived for the sake of the challenge alone, and do not represent the intent of any company, product owner, or standards body.
Any similarities to real persons, entities, or events is coincidental.
Synopsis
Having contacted the NSA liaison at the FBI, you learn that a facility at this address is already on a FBI watchlist for suspected criminal activity.
With this tip, the FBI acquires a warrant and raids the location.
Inside they find the empty boxes of programmable OTP tokens, but the location appears to be abandoned. We’re concerned about what this APT is up to! These hardware tokens are used to secure networks used by Defense Industrial Base companies that produce critical military hardware.
The FBI sends the NSA a cache of other equipment found at the site. It is quickly assigned to an NSA forensics team. Your friend Barry enrolled in the Intrusion Analyst Skill Development Program and is touring with that team, so you message him to get the scoop. Barry tells you that a bunch of hard drives came back with the equipment, but most appear to be securely wiped. He managed to find a drive containing what might be some backups that they forgot to destroy, though he doesn’t immediately recognize the data. Eager to help, you ask him to send you a zip containing a copy of the supposed backup files so that you can take a look at it.
If we could recover files from the drives, it might tell us what the APT is up to. Provide a list of unique SHA256 hashes of all files you were able to find from the backups. Example (2 unique hashes):
471dce655395b5b971650ca2d9494a37468b1d4cb7b3569c200073d3b384c5a4
0122c70e2f7e9cbfca3b5a02682c96edb123a2c2ba780a385b54d0440f27a1f6
Downloads
disk backups (archive.tar.bz2)
Prompt
Provide your list of SHA256 hashes
Solution
Upon checking, it looks like we are given ZFS Snapshots, and it looks like we need to restore the images chronologically to get the unique files.
data:image/s3,"s3://crabby-images/d7fe5/d7fe514b750c7ff40e0593dd3d808998be31e1bf" alt=""
We then transferred to ubuntu which does natively supports zfs
.
We first create the disk, then create the pool, then create the dataset.
data:image/s3,"s3://crabby-images/8e9b8/8e9b80b02afc179aaebc3a6682bd7729cc0a4b9c" alt=""
We then import the starting backup.
data:image/s3,"s3://crabby-images/e4067/e40670a521facce183e56cf807c89847db0b0313" alt=""
We then create a folder which we will put the files for every backup.
data:image/s3,"s3://crabby-images/efd0e/efd0ee4066085117818be775d01e62699d7016f0" alt=""
data:image/s3,"s3://crabby-images/19fca/19fca206cbaa4b24188985b2f5c4cd1cd18a1759" alt=""
Copy the current contents of the pool on the created folder.
data:image/s3,"s3://crabby-images/7916a/7916a1b1de2e098fd6f0020517b4188691258c4d" alt=""
Just repeat the process: import a backup, make a folder where contents will be copied, then copy the content, and then repeat.
I know, this is a tedious process because the backups are not labeled in order (or maybe I missed a clue on it). Also this can be automated, but I chose the hard way.
data:image/s3,"s3://crabby-images/3255d/3255d0bb7855a3684677dca4a0a62dd0c8a8158c" alt=""
…
After importing all and extracting each backup content, we can now proceed to next step.
data:image/s3,"s3://crabby-images/115bd/115bd56861d11b91b0a70d31d3272fe02b6552eb" alt=""
We then recursively get sha256 from the files.
data:image/s3,"s3://crabby-images/7d229/7d229fa3475f60afed0c858ce752d790f4a86fa6" alt=""
Then pipe them to sort
and uniq
.
data:image/s3,"s3://crabby-images/dabfa/dabfa9502bc9af9520d54947ca22050d1d9e8b08" alt=""
Submitted these and viola! Task 2 is done!