An attacker may be interested in changing the timestamps of files to avoid being detected.
It's possible to find the timestamps inside the MFT in attributes $STANDARD_INFORMATION
__and __$FILE_NAME
.
Both attributes have 4 timestamps: Modification, access, creation, and MFT registry modification (MACE or MACB).
Windows explorer and other tools show the information from $STANDARD_INFORMATION
.
This tool modifies the timestamp information inside $STANDARD_INFORMATION
but not the information inside $FILE_NAME
. Therefore, it's possible to identify suspicious activity.
The USN Journal (Update Sequence Number Journal), or Change Journal, is a feature of the Windows NT file system (NTFS) which maintains a record of changes made to the volume.
It's possible to use the tool UsnJrnl2Csv to search for modifications of this record.
The previous image is the output shown by the tool where it can be observed that some changes were performed to the file.
All metadata changes to a file system are logged to ensure the consistent recovery of critical file system structures after a system crash. This is called write-ahead logging.
The logged metadata is stored in a file called “$LogFile”, which is found in a root directory of an NTFS file system.
It's possible to use tools like LogFileParser to parse this file and find changes.
Again, in the output of the tool it's possible to see that some changes were performed.
Using the same tool it's possible to identify to which time the timestamps were modified:
- CTIME: File's creation time
- ATIME: File's modification time
- MTIME: File's MFT registry modifiction
- RTIME: File's access time
Another way to identify suspicions modified files would be to compare the time on both attributes looking for mismatches.
NTFS timestamps have a precision of 100 nanoseconds. Then, finding files with timestamps like 2010-10-10 10:10:00.000:0000 is very suspicious.
This tool can modify both attributes $STARNDAR_INFORMATION
and $FILE_NAME
. However, from Windows Vista it's necessary a live OS to modify this information.
NFTS uses a cluster and the minimum information size. That means that if a file occupies uses and cluster and a half, the reminding half is never going to be used until the files is deleted. Then, it's possible to hide data in this slack space.
There are tools like slacker that allows to hide data in this "hidden" space. However, an analysis of the $logfile
and $usnjrnl
can show that some data was added:
Then, it's possible to retrieve the slack space using tools like FTK Imager. Note that this can of tools can save the content obfuscated or even encrypted.
This is a tool that will turn off the computer is any change in the USB ports is detected.
A way to discover this would be to inspect the running processes and review each python script running.
These distros are executed inside the RAM memory. The only way to detect them is in case the NTFS file-system is mounted with write permissions. If it's mounted just with read permissions it won't be possible to detect the intrusion.
https://github.com/Claudio-C/awesome-data-sanitization
It's possible to disable several windows logging methods to make the forensics investigation much harder.
This is a registry key that maintains dates and hours when each executable was run by the user.
Disabling UserAssist requires two steps:
- Set two registry keys,
HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Start_TrackProgs
andHKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Start_TrackEnabled
, both to zero in order to signal that we want UserAssist disabled. - Clear your registry subtrees that look like
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\UserAssist\<hash>
.
This will save information about the applications executed with the goal of improving the performance of the Windows system. However, this can also be useful for forensics practices.
- Rexecute
regedit
- Select the file path
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SessionManager\Memory Management\PrefetchParameters
- Right-click on both
EnablePrefetcher
andEnableSuperfetch
- Select Modify on each of these to change the value from 1 (or 3) to 0
- Restart
Whenever a folder is opened from an NTFS volume on a Windows NT server, the system takes the time to update a timestamp field on each listed folder, called the last access time. On a heavily used NTFS volume, this can affect performance.
- Open the Registry Editor (Regedit.exe).
- Browse to
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem
. - Look for
NtfsDisableLastAccessUpdate
. If it doesn’t exist, add this DWORD and set its value to 1, which will disable the process. - Close the Registry Editor, and reboot the server.
All the USB Device Entries are stored in Windows Registry Under USBSTOR registry key that contains sub keys which are created whenever you plug a USB Device in your PC or Laptop. You can find this key here HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USBSTOR
. Deleting this you will delete the USB history.
You may also use the tool USBDeview to be sure you have deleted them (and to delete them).
Another file that saves information about the USBs is the file setupapi.dev.log
inside C:\Windows\INF
. This should also be deleted.
List shadow copies with vssadmin list shadowstorage
Delete them running vssadmin delete shadow
You can also delete them via GUI following the steps proposed in https://www.ubackup.com/windows-10/how-to-delete-shadow-copies-windows-10-5740.html
To disable shadow copies:
- Go to the Windows start button and type "services" into the text search box; open the Services program.
- Locate "Volume Shadow Copy" from the list, highlight it, and then and the right-click > Properties.
- From the "Startup type" drop-down menu, select Disabled, and then click Apply and OK.
It's also possible to modify the configuration of which files are going to be copied in the shadow copy in the registry HKLM\SYSTEM\CurrentControlSet\Control\BackupRestore\FilesNotToSnapshot
- You can use a Windows tool:
cipher /w:C
This will indicate cipher to remove any data from the available unused disk space inside the C drive. - You can also use tools like Eraser
- Windows + R --> eventvwr.msc --> Expand "Windows Logs" --> Right click each category and select "Clear Log"
for /F "tokens=*" %1 in ('wevtutil.exe el') DO wevtutil.exe cl "%1"
Get-EventLog -LogName * | ForEach { Clear-EventLog $_.Log }
reg add 'HKLM\SYSTEM\CurrentControlSet\Services\eventlog' /v Start /t REG_DWORD /d 4 /f
- Inside the services section disable the service "Windows Event Log"
WEvtUtil.exec clear-log
orWEvtUtil.exe cl
fsutil usn deletejournal /d c: