Previous Level Guide: Bandit Level 11 → 12
Access
SSH: ssh bandit12@bandit.labs.overthewire.org -p 2220
Password: o1UyFHBN4wagVCBrKOXR6UlMl43zu0hT
Info
Description: The password for the next level is stored in the file data.txt, which is a hexdump of a file that has been repeatedly compressed. For this level it may be useful to create a directory under /tmp in which you can work. Use mkdir with a hard to guess directory name. Or better, use the command “mktemp -d”. Then copy the datafile using cp, and rename it using mv (read the manpages!) Commands: grep, sort, uniq, strings, base64, tr, tar, gzip, bzip2, xxd Sources: Hex dump on Wikipedia.
Theory
To get the password, the instructions say that it's inside a file that is a hexdump of a file that has been compressed a bunch of times, which I guess in different compression formats, like gzip, bzip2, and tar because of the commands given to us in the instructions, and to check with which command to decompress, instead of guessing, maybe the file command could help, which like I've explained before, it estimates the type of a file from going through its contents. So I don't have that much to say here in the theory because it will depend between a couple of commands if it's compressed like this or like that, so most I can do is come up with the template commands for this. For gzip and bzip2, it's easy, you just put it's name and the -d option to decompress the file that you specify after it. Then the tar is a little harder as instead of the -d option it's the -xf, where f is just to specify the file after it and the x is to extract the original files. Finally, xxd is a command that allows you to turn a file into its hexdump form, it's like where it shows all the binary characters as readable and in hexadecimal values in the same lines, recommend reading the Wikipedia page if you don't understand what's going on, and so we use the -r option to reverse the hexdump conversion, and get the compressed archive to start the level. So here are all the commands we might need:
xxd -r original.hex reversed.bin gzip -d original.bin bzip2 -d original.bin tar -xf original.bin
Solution
So now let's enter the level and see what happens:
~$ ls data.txt
As the level suggests, we'll just create a new temporary directory to do these file shenanigans, then copy that data file:
~$ mktemp -d /tmp/tmp.OPSGMOddmc ~$ cd /tmp/tmp.OPSGMOddmc /tmp/tmp.OPSGMOddmc$ cp ~/data.txt /tmp/tmp.OPSGMOddmc$ cat data.txt 00000000: 1f8b 0808 dfcd eb66 0203 6461 7461 322e .......f..data2. 00000010: 6269 6e00 013e 02c1 fd42 5a68 3931 4159 bin..>...BZh91AY 00000020: 2653 59ca 83b2 c100 0017 7fff dff3 f4a7 &SY............. ...
If we go into this file we can see that it is indeed a hexdump, so we just need to reverse it and put it somewhere else:
/tmp/tmp.OPSGMOddmc$ xxd -r data.txt comdata /tmp/tmp.OPSGMOddmc$ ls comdata data.txt /tmp/tmp.OPSGMOddmc$ file comdata comdata: gzip compressed data, was "data2.bin", last modified: Thu Sep 19 07:08:15 2024, max compression, from Unix, original size modulo 2^32 574
Look at that, it's a gzip file, so now we just change the extension to be gz because it's not gonna work otherwise, and put the command from earlier and keep going:
/tmp/tmp.OPSGMOddmc$ mv comdata comdata.gz /tmp/tmp.OPSGMOddmc$ gzip -d comdata.gz /tmp/tmp.OPSGMOddmc$ ls comdata data.txt /tmp/tmp.OPSGMOddmc$ file comdata comdata: bzip2 compressed data, block size = 900k /tmp/tmp.OPSGMOddmc$ mv comdata comdata.bz2 /tmp/tmp.OPSGMOddmc$ bzip2 -d comdata.bz2 /tmp/tmp.OPSGMOddmc$ la comdata data.txt /tmp/tmp.OPSGMOddmc$ ls comdata data.txt /tmp/tmp.OPSGMOddmc$ file comdata comdata: gzip compressed data, was "data4.bin", last modified: Thu Sep 19 07:08:15 2024, max compression, from Unix, original size modulo 2^32 20480 /tmp/tmp.OPSGMOddmc$ mv comdata comdata.gz /tmp/tmp.OPSGMOddmc$ gzip -d comdata.gz /tmp/tmp.OPSGMOddmc$ ls comdata data.txt /tmp/tmp.OPSGMOddmc$ file comdata comdata: POSIX tar archive (GNU) /tmp/tmp.OPSGMOddmc$ mv comdata comdata.tar /tmp/tmp.OPSGMOddmc$ tar -xf comdata.tar /tmp/tmp.OPSGMOddmc$ ls comdata.tar data5.bin data.txt /tmp/tmp.OPSGMOddmc$ file data5.bin data5.bin: POSIX tar archive (GNU) /tmp/tmp.OPSGMOddmc$ mv data5.bin cd5.tar /tmp/tmp.OPSGMOddmc$ tar -xf cd5.tar /tmp/tmp.OPSGMOddmc$ ls comdata.tar data6.bin data.txt cd5.tar /tmp/tmp.OPSGMOddmc$ file data6.bin data6.bin: bzip2 compressed data, block size = 900k /tmp/tmp.OPSGMOddmc$ mv data6.bin comdata.bz2 /tmp/tmp.OPSGMOddmc$ bzip2 -d comdata.bz2 /tmp/tmp.OPSGMOddmc$ ls comdata comdata.tar data.txt cd5.tar /tmp/tmp.OPSGMOddmc$ file comdata comdata: POSIX tar archive (GNU) /tmp/tmp.OPSGMOddmc$ mv comdata cd7.tar /tmp/tmp.OPSGMOddmc$ tar -xf cd7.tar /tmp/tmp.OPSGMOddmc$ ls cd7.tar comdata.tar data8.bin data.txt cd5.tar /tmp/tmp.OPSGMOddmc$ file data8.bin data8.bin: gzip compressed data, was "data9.bin", last modified: Thu Sep 19 07:08:15 2024, max compression, from Unix, original size modulo 2^32 49 /tmp/tmp.OPSGMOddmc$ mv data8.bin data8.gz /tmp/tmp.OPSGMOddmc$ gzip -d data8.gz /tmp/tmp.OPSGMOddmc$ ls cd7.tar comdata.tar data8 data.txt cd5.tar /tmp/tmp.OPSGMOddmc$ file data8 data8: ASCII text /tmp/tmp.OPSGMOddmc$ cat data8 The password is ttw6eXkWHrFGZDgATKirZ4a8a8NGG0Bq
And that's it, it worked! Now we should be good to go to the next level.
https://overthewire.org/wargames/bandit/bandit13.htmlNext Level Guide: Bandit Level 13 → Level 14