data:image/s3,"s3://crabby-images/9f07e/9f07e587a64cef931c8901520e95e49c813b99a8" alt=""
I’ve been staring at the Hardware section of HackTheBox for a long time now. Having had a past career in the automotive world myself, I finally decided to give Unique a go.
The goal here is to find the VIN of the car that is repeated over and over again.
Here’s what you’ll learn:
- Serial/CAN Analysis with Logic2
- Some command line tricks for manipulating data
Discovery
When you download the ZIP file from hackthebox and extract it, you’re immediately greeted with one file –
With any strange files I’m no familiar with, I find I typically like to analyze what kind of file it is with commands like trace_captured.sal
.file
.
data:image/s3,"s3://crabby-images/48251/482519fc15394da2b4f17e96c780f97538f37e4e" alt=""
In this case, the .sal
file is actually Zip-compressed data and can be extracted like a normal Zip archive with Unzip. Unzipping the files leaves us with a few digital
and analog
binary files along with a meta.json
.
data:image/s3,"s3://crabby-images/986bb/986bb9345bce3c85757b46e545af3cd2a38800d8" alt=""
You can try to run the files through hexdump
and strings
, but the information might not be super interesting. However, viewing the header of the file gives us a clue:
data:image/s3,"s3://crabby-images/52cee/52cee5f0107032f299c8a43da1c768465a192415" alt=""
SALEAE is a company that creates debugging hardware and software. For the uninitiated, Saleae creates components that allow users to debug hardware by attacking probes to a device and analyzing the binary output transmitted. I’m no expert, but it sounds like someone did some hardware hacking on our target car. This means Saleae also has a debugging tool for Windows, Mac, and Linux. Proprietary software for proprietary file types? Let’s give it a go.
Once installed, the original trace_captured.sal
file can be opened. Now, let’s analyze.
data:image/s3,"s3://crabby-images/9b1df/9b1dfec4fe47ea6164428778bc2e1c606169322b" alt=""
Analyzing the .sal file
Logic2 comes with an “Analyzer” function which, I assume, contains different kinds of preset analysis options for reading raw protocols. For our use, since this is an automobile, we’ll want to use CAN.
data:image/s3,"s3://crabby-images/fc036/fc036768e18912c1902e3acdaede64a3c5f3fffe" alt=""
data:image/s3,"s3://crabby-images/e48ee/e48ee9762c42333501423a968176e71dabb3ae7d" alt=""
As an aside, Yogesh Ojha has a wonderful articles on car hacking 101 which cover the CAN protocol in more detail.
https://medium.com/@yogeshojha/car-hacking-101-practical-guide-to-exploiting-can-bus-using-instrument-cluster-simulator-part-i-cd88d3eb4a53
You’ll see below that after choosing a few different transfer rates between 120,000 and 130,000, we start to see some characters.
data:image/s3,"s3://crabby-images/12be2/12be25b67950a4b4c161b6ad33721cf5d3bbbc38" alt=""
One thing that’s interesting is that we see a string of characters that contain CRC:{?
which suspiciously looks like the syntax of a HTB flag. This Analyzer was used with the 125kb/s rate.
data:image/s3,"s3://crabby-images/86859/868598ed4974edc9351b15644e535b6bf9574c2b" alt=""
Logic2 lets you search in the data field and after coming across a few {
characters, I start to see something that makes sense.
data:image/s3,"s3://crabby-images/a35f1/a35f1cee881bff293f368d5f558bc00a441d1bb3" alt=""
Now, export the table to a csv file.
data:image/s3,"s3://crabby-images/af4f2/af4f2aa815fa491191fe0ffcc702f879c772777f" alt=""
Further glancing at the CSV file, you can now see that the HTB
characters are standing out. It’s just a matter of time before they’re extracted.
data:image/s3,"s3://crabby-images/12673/126730d5824f375971b1517c4f3dc3537868974a" alt=""
There are going to be tons of ways for you to extract the flag now that you know where things are heading. For me, a quick and dirty python script was enough for this task even if the output wasn’t pretty.
import csv
file = open("out.csv", 'r')
reader = csv.DictReader(file)
flag_string = ''
join_flag = False
for line in reader:
data = line['data']
print(data)
if data != '':
if data == 'H':
join_flag = True
flag_string += data
if join_flag:
flag_string += data
print(flag_string)
else:
pass
The output? Messy, but works!
data:image/s3,"s3://crabby-images/99971/99971b8d8df031aa3edf3c5a4ceaa3be4d2cf90f" alt=""