HFS+ Data is Big Endian GPT is Liele Endian

B-­‐Tree Nodes HFS+ File System Format Reference Sheet By: Sarah Edwards Twi2er: @iamevltwin Email: oompa@csh.rit.edu •
•
•
Catalog File Four types of B-­‐Tree Nodes Only one Header Node per B-­‐Tree Each B-­‐Tree Specifies its size in the Node Size field of the Header Record Size (in bytes) LocaMon Data 0 2 4 8 12 16 20 24 28 32 36 40 44 48 52 56 60 64 68 72 80 2 2 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 8 4 Signature Version A2ributes Last Mounted Version Journal Info Block Create Date Modify Date Backup Date Checked Date File Count Folder Count Block Size Total Blocks Free Blocks Next AllocaMon rsrc Clump Size Data Clump Size Next Catalog ID Write Count Encoding Bitmap Finder Info Array [0] 84 88 92 96 100 104 108 112 192 272 352 432 4 4 4 4 4 4 4 80 80 80 80 80 Finder Info Array [1] Finder Info Array [2] Finder Info Array [3] Finder Info Array [4] Finder Info Array [5] Finder Info Array [6] Finder Info Array [7] AllocaMon File Size & LocaMon Extents File Size & LocaMon Catalog File Size & LocaMon A2ributes File Size & LocaMon Startup File Size & LocaMon Reserva7on Root Parent Root Folder Extents Overflow File Catalog File Bad Block File AllocaMon File Startup File A2ributes File Repair Catalog File Bogus Extent File First User Catalog Node Size Alternate VH Node Descriptor Record 1 Record 2 … Free Space Offset to Free Space … Offset to Record 2 Offset to Record 1 Special File Size & LocaMon / File Extents [80 bytes] Offset 0 8 12 16 20 24 28 32 36 40 44 48 52 56 60 64 68 72 76 Size (in bytes) Data 8 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 Logical Size Clump Size Total Blocks Extent 1 – Start Block Extent 1 – Block Count Extent 2 – Start Block Extent 2 – Block Count Extent 3 – Start Block Extent 3 – Block Count Extent 4 – Start Block Extent 4 – Block Count Extent 5 – Start Block Extent 5 – Block Count Extent 6 – Start Block Extent 6 – Block Count Extent 7 – Start Block Extent 7 – Block Count Extent 8 – Start Block Extent 8 – Block Count HFS+ Special File Extrac7on from Image File using The Sleuth Kit icat -f hfs –o <partitionoffset>
*.dd <inode> > special_file
Apple Tech Note 1150 – Available at dubeiko.com/development/FileSystems/HFSPLUS/tn1150.html The Sleuth Kit Source – Available at github.com/sleuthkit/sleuthkit/blob/master/tsk/fs/tsk_hfs.h Mac OS X Internals: A Systems Approach by Amit Singh – Chapter 12 Mac OS X and iOS Internals: To the Apple’s Core by Jonathan Levin – Chapter 16 Apple Open Source -­‐ h2p://www.opensource.apple.com/source/xnu/xnu-­‐2050.18.24/bsd/hfs/hfs_format.h Node Descriptor Header Record User Data Record Map Record Free Space Offset to Free Space Offset to Map Record Offset to User Data Record Offset to Header Record Header Node Leaf Node Leaf Node Index Node Index Node Leaf Node Leaf Node Index Node … Node Descriptor [14 bytes] Offset Size (in bytes) 4 4 1 Field 0 4 8 9 10 12 1 2 2 Height Number of Records Reserved Forward Link Backward Link Kind: 0xFF – Leaf Node (-­‐1) 0x00 – Index Node (0) 0x01 – Header Node (1) 0x02 – Map Node (2) Header Record [46 bytes] Header Node Header Record User Data Record Map Record Map Node Map Records* *See Alloca*on Table Format HFS+ File System Format References & Resources: •
•
•
•
•
Special File Node Layout 1024 bytes from beginning of the volume 512 bytes 1024 bytes from the end of the volume Catalog Node ID Reserva7ons CNID 1 2 3 4 5 6 7 8 14 15 16 Size 2 4
Field Key Length Parent CNID (or CNID of file/folder for thread records) Node Name (File or Folder Name) 2 Byte Length + Variable Unicode Name (<=255) Variable HFSUniStr255 Volume Header Offset Catalog File Key Index Node Pointer Records Size (in bytes) 2 Variable
4
Field Key Length Key (For Catalog File: Parent CNID + HFSUniStr255) Node Number Leaf Node Data Records Size (in bytes) 2 4
Variable
Field Key Length Parent CNID Data Size [2 bytes] + Data (Empty String 0x0000 in thread records) (+padding byte if key length is odd) Offset 0
2
6
10
14
18
20
22
26
30
32
36
Size (in bytes) 2
4
4
4
4
2
2
4
4
2
4
1
37
1
38
42
4
4
Field Tree Depth Root Node Leaf Records First Leaf Node Last Leaf Node Node Size Max Key Length Total Nodes Free Nodes Reserved Clump Size B-­‐tree Type: 0x00 – HFS B-­‐Tree (0) 0x80 – User B-­‐Tree (128) 0xFF – Reserved (255) Key Compare Type: 0xCF or 0xC7 -­‐ Case-­‐insensiMve 0xBC -­‐ Case-­‐sensiMve 0x00 -­‐ Unknown A2ributes: Reserved [16] (64 bytes) HFS+ Data is Big Endian GPT is Li2le Endian Catalog File/Folder Record [88 or 248 bytes] Catalog Thread Record Size (in bytes) 2
Size 2 Bytes Field Record Type (0x0001) – Folder Record (0x0002) – File Record 2
Flags 4
Valence (File Records -­‐ Reserved) 4
File or Folder ID (CNID) 4
Create Date 4
Content ModificaMon Date 4
A2ribute ModificaMon Date 4
Access Date 4
Backup Date HFSPlusBSDInfo [16 Bytes]
Permissions FolderInfo or FileInfo [16 Bytes]
User InformaMon ExtendedFolder or FileInfo [16 Bytes]
Finder InformaMon 4
Text Encoding 4
Reserved AddiMonal Fields for File Record – See “File Extents” Table HFSPlusForkData [80 Bytes] Data Fork HFSPlusForkData [80 Bytes] Resource Fork 2 Bytes 4 Bytes HFSUniStr255 Size (in bytes) 4
4
1
1
2
4 Field Record Type (0x0003) – Folder Thread Record (0x0004) – File Thread Record Reserved Parent ID (CNID) Node Name (File or Folder Name) 2 Byte Length + Variable <=255 Unicode Name HFSPlusBSDInfo Owner ID Group ID Admin Flags Owner Flags File Mode iNode Number or Link Count or Raw Device AOributes File A2ributes Key A2ributes Record Size (in bytes) 2 2 4 4 2 Variable Field Size (in bytes) Key Length Pad File ID (CNID) Start Block A2ribute Name Length A2ribute Name 4
8
4
Variable Field Record Type (0x00000010) Inline Data A2ribute Reserved A2ribute Size A2ribute Data Extents Overflow File Extents Overflow Key [12 bytes] Size (in bytes) 2
1
1
4
4
Extents Overflow Record Size (in bytes) Field Key Length Fork Type 0x00 -­‐ Data 0xFF -­‐ Resource Pad File ID (CNID) Start Block 4
4
Field (For Each Eight Extents) Start Block Block Count Alloca7on File (with Examples) 1 bit per allocaMon block (512 bytes), 8 blocks per byte (4,096) Most Significant Bit – Status of block with lowest number Least Significant Bit – Status of block with highest number Hex 0x00
0xFF
0x1F
0x80
0x07
0xF0
Binary 00000000
11111111
00011111
10000000
00000111
11110000
Alloca7on No Blocks Allocated All Blocks Allocated Lowest three blocks are unallocated Lowest block is allocated Highest three blocks are allocated Highest four blocks are unallocated Updated 7/2016
SANS FOR518 Reference Sheet By: Sarah Edwards | Twi2er: @iamevltwin | Email: oompa@csh.rit.edu Directory Commands cd ..
Change Directory…up one directory (../.. – two directories up) cd /var/log
Change Directory…to /var/log cd ~
Change Directory…to your home directory cd /
Change Directory…to the root directory ls
List Directory (Short LisMng) ls -l
List Directory (Long LisMng) ls -a
List Directory items…including hidden items (files beginning with “.”) ls -lh
List Directory items…with human readable sizes ls -R
List Directory items…recursively open .
Open Current Directory pwd
Print Working Directory mkdir
Create a Directory rmdir
Remove a Directory rmdir –R
Remove a Directory (and its contents) .
Current Directory ..
Parent Directory File Commands pico <filename>
xxd <filename>
open <filename>
open –a <programname> <filename>
cat <filename>
<command> | more
<command> | less
rm <filename>
cp <filename> <newfilename>
mv <filename> <newfilename>
<command> > <filename>
<command> >> <filename>
touch <filename>
head <filename>
tail <filename>
strings <filename>
exiftool <filename>
plutil –p <propertylist>
file <filename>
grep –i <searchterm> <filename>
python <file>.py
Miscellaneous Commands sudo <command>
sudo -s
su whoami
history
man <command>
Terminal Shortcuts Ctrl + A Ctrl + E Tab Ctrl + C Command + K or Ctrl + L Command + T Command + W Command +/-­‐ Open a file in a simple text editor (q – to quit editor) Open a file in a hex editor Opens a file in the default program Opens a file in a specified program Concatenate a file to the terminal screen Pipe command output to more to show contents screen by screen Pipe command output to less to show contents screen by screen (and be able to go back and forth) Remove File Copy File Move File Redirect command output to a file Append command output to a file Create an empty file Show first 10 lines of a file Show last 10 lines of a file (-f to watch appended input) Show the strings of a file Show the exif/metadata of the file Print the contents of a property list Show a file signature type Search for term within a file (case-­‐
insensiMve) Execute a Python program Execute program as another user (default is root user) Open a privileged shell SubsMtute User to root Display EffecMve User ID Command History Command Manual (q – to exit manual) Jump to beginning of line Jump to end of of line Tab CompleMon Kill Current Command Clear Screen (or clear command) New Terminal Tab Close Terminal Tab Increase or Decrease Terminal Font Size Generic Tool Compila7on and Installa7on tar –xvf <archive>.tar.gz
./configure
make
sudo make install
Live Response date
Local System Time (-­‐u for UTC) hostname
System Hostname uname –a
OS & Architecture InformaMon sw_vers
OS X Version & Build netstat –anf inet or netstat -an
AcMve Network ConnecMons lsof -i
AcMve Network ConnecMons (by process) netstat -rn
RouMng Table arp -an
ARP Table ifconfig
Network Interface ConfiguraMon lsof
List Open Files who –a, w
List Logged On Users last
List user logins ps aux
List Processes system_profiler -xml
System Profiler (XML, Full Detail Level) -detaillevel full > file.spx
Disk & Par77ons /dev/
Device Directory diskutil list
List Connected Disks diskutil info <disk>
Disk InformaMon (use Disks /dev/disk#, disk#, or parMMons /dev/disk#s#) pdisk –l /dev/disk3
List parMMons using Apple ParMMon Map Format gpt –r show [-l]
List parMMons using GUID ParMMon Table Format (-­‐l to show label rather than GUID) mmls <diskimage>
Display parMMons using The Sleuth Kit hdiutil imageinfo *.dmg
Disk Image InformaMon including ParMMon Data hdiiutil fsid *.dmg
Volume Header InformaMon of Disk Image User Domain dscl . -read /Users/
<useraccount>
strings *.keychain
security list-keychains
security dump-keychains
<keychain>
Extended AOributes xattr –xl <file>
xattr -p <attribute name> <file> |
>output_file.plist
istat /dev/disk# <CNID>
Eject Disk Log Analysis bzcat system.log.1.bz2 system.log.0.bz2
>> system_all.log
$ cat system.log >> system_all.log
syslog –f <file>
syslog –d <directory>
syslog –T utc –F raw –d /var/log/asl
mkdir /Volumes/dademurphy_image/ mkdir /Volumes/dademurphy_mounted/ sudo xmount --in ewf --out dmg ~/FOR518/dademurphy.E01 /Volumes/dademurphy_image/ hdiutil attach –nomount /Volumes/dademurphy_image/dademurphy.dmg
mount_hfs –j –o rdonly,noexec,noowners /dev/disk# /Volumes/dademurphy_mounted/
mkdir /Volumes/dademurphy_image/
mkdir /Volumes/dademurphy_mounted/
ewfmount ~/FOR518/dademurphy.E01 /Volumes/dademurphy_image/
ln –s /Volumes/dademurphy_image/ewf1 ~/FOR518/dadeimage.dmg
hdiutil attach -nomount ~/FOR518/dadeimage.dmg
mount_hfs -j -o rdonly,noexec,noowners /dev/disk# /Volumes/dademurphy_mounted/
diskutil list
diskutil eject /dev/disk#
mount
umount /Volumes/dademurphy_image/
Timestamp Formats HFS+/MacOS UNIX Epoch Mac Epoch/Mac Absolute/Cocoa/WebKit Property List Dates in Xcode Hostname 32-­‐bit -­‐ Number of seconds from 1/1/1904 00:00:00 UTC 32-­‐bit -­‐ Number of seconds from 1/1/1970 00:00:00 UTC 32-­‐bit -­‐ Number of seconds from 1/1/2001 00:00:00 UTC Local Host System Time Directory Command Username Show the strings of a Keychain file List Keychains on a system for a logged in user Dump contents of a Keychain xxd -r -p
$
$
$
$
$
$
$
$
$
$
$
$
$
$
$
Method 2 -­‐ mountewf Command-­‐line version of Directory UMlity, read user informaMon icat /dev/disk# <CNID>-<TSK Attribute Number>
praudit –xn /var/audit/*
Image Mount & Eject Method 1 -­‐ xmount Show Extended A2ributes of a file Extract embedded binary property list from extended a2ribute. Use The Sleuth Kit to view file informaMon including extended a2ributes. View a specific extended a2ribute using The Sleuth Kit Number of 512-­‐byte Blocks Used Create a “all-­‐in-­‐one” system.log file. nibble:/ sledwards$ ls -la
total 1014190
wheel
drwxr-xr-x@ 41 root
drwxr-xr-x@ 41 root
wheel
d--x--x--x+ 8 root
wheel
d-wx-wx-wt
2 root
wheel
-rw-r--r--+ 1 sledwards admin
1 root
wheel
srwxrwxrwx
wheel
lrwxr-xr-x@ 1 root
wheel
-rwxr-xr-x@ 1 root
1462
1462
272
68
312
0
11
8393032
Feb
Feb
Nov
Nov
Mar
Feb
Sep
Sep
16
16
5
4
9
15
23
29
21:14
21:14
01:11
21:05
2013
21:29
08:47
22:39
.
..
.DocumentRevisions-V100
.Trashes
.apdisk
.dbfseventsd
etc -> private/etc
mach_kernel
View ASL File View a directory of ASL Files Output ASL files the /var/log/asl directory and output in raw format with UTC Mmestamps. View audit logs in XML format without user/group resoluMon. Time Machine tmutil uniquesize <machinedirectory_path>/*
Show the unique sizes of each snapshot tmutil calculatedrift
Show the size changes (added/removed/changed) <machinedirectory_path>
between each snapshot. tmutil compare <snapshotdirectory1>
Compare the file changes (added/removed/
<snapshotdirectory2>
changed) between two snapshots.. Encrypted Containers hdiutil attach –readonly –nomount –stdinpass
Mount a FileVault volume using a filevault2image.dmg
password $ security unlock-keychain
Access and mount a FileVault volume FileVaultMaster.keychain
using a master password $ diskutil corestorage unlockvolume <UUID> recoverykeychain FileVaultMaster.keychain
diskutil corestorage unlockvolume <UUID> Mount a FileVault volume using the passphrase <recovery key>
Recovery Key hdiutil attach -readonly -nomount -stdinpass
Mount an Encrypted DMG File sekretstuff_USB.dmg
Spotlight
mdls <file>
List the Spotlight metadata for a file mdfind
Find files based on a specific metadata query mdimport -X
Print a list of a2ributes that can be queried. Disk Arbitra7on sudo launchctl load /System/Library/LaunchDaemons/com.apple.diskarbitrationd.plist
sudo launchctl unload /System/Library/LaunchDaemons/com.apple.diskarbitrationd.plist
ps auxw | grep diskarbitrationd
Enable Disable Determine Status GPT Header Offset Size (bytes) Field 0 8 Signature (EFI PART) 8 4 Revision (1.0) 12 4 Size of Header (bytes) 16 4 Header CRC32 20 4 Reserved 24 8 LBA of GPT Header 32 8 LBA of Backup GPT Header 40 8 48 GPT Reference GPT Table Entry Offset Size (bytes) Field 0 16 ParMMon Type GUID 16 16 Unique ParMMon GUID 32 8 StarMng LBA (Li2le Endian) 40 8 Ending LBA (Li2le Endian) First Usable LBA 48 8 A2ributes 8 Last Usable LBA 56 72 ParMMon Name 56 16 Disk GUID 128 Rest Reserved 72 8 80 4 84 4 StarMng LBA of GUID ParMMon Table (Li2le Endian) Number of ParMMon Entries Available (Li2le Endian) Size of ParMMon Entry 88 4 ParMMon Entry Array CRC32 92 Rest Reserved Type EFI System ParMMon HFS+ ParMMon Apple Boot ParMMon Apple Core Storage (FileVault) Basic Data ParMMon (Boot Camp) Common GPT Par77on GUIDs C12A7328-­‐F81F-­‐11D2-­‐BA4B-­‐00A0C93EC93B
48465300-­‐0000-­‐11AA-­‐AA11-­‐00306543ECAC
426F6F74-­‐0000-­‐11AA-­‐AA11-­‐00306543ECAC
53746F72-­‐6167-­‐11AA-­‐AA11-­‐00306543ECAC
EBD0A0A2-­‐B9E5-­‐4433-­‐87C0-­‐68B6B72699C7