/gandalf

Collection of acquisition scripts for collecting digital forensic artefacts

Primary LanguagePythonMIT LicenseMIT

Logo

Forensics artefact acquisition scripts to be used in conjunction with elrond.

License: MIT Issues Forks Stars Subject Last Commit Code style: black

Table of Contents



About The Project

gandalf has been created to help fellow digitial forensicators with the live collection of forensic artefacts from a Windows, Linux and masOS hosts. Depending on the host OS, either gandalf.ps1 or gandalf.py will be required; to ensure compatibility for Windows and *nix hosts respectively. gandalf is designed to be faster, but additional features ({-Memory, -CollectFiles}/{-M, -A, -F}) may result is longer acquisitions times, subject to network speeds and latency of course.

Related Projects

gandalf is responsible for the acquisition-side of digital forensics, but what about analysis? elrond, converts all of the artefacts to either JSON or CSV and can then stand up an on-the-fly Splunk or elastic instance whilst mapping the evidence within those artefacts to the MITRE ATT&CK® Framework using ATT&CK Navigator, if desired.


Configuration

To collect privileged disk arterfacts, namely the $MFT, you will need to download the disk_tools.zip.enc archive (password is infected) and place the enclosed archive (disk_tools.zip) into gandalf\gandalf\tools\ before deploying and invoking gandalf.
Then copy the parent \gandalf\ directory into C:\TEMP, or /tmp/ of the acquisition host.

Prerequisites

You must have necessary admin rights to obtain the forensic artefacts from hosts within your environment. This is true for both Local and Remote acquisitions.
Ensure all respective intermediate firewalls do not block the acquisition

Windows Targets

Linux Targets

  • Ensure SSH is listening for open connections (for Linux/macOS targets)

Ensure you revert any changes made in preperation of forensic artefact acquisition.
Please review SUPPORT.md for instructions on how to leverage and deploy gandalf.


Usage

Please read the CONFIG.md file for instructions on how to enable PowerShell remoting (for Windows Targets) and SSH remoting (for Linux/macOS hosts).

Windows

  • Open 'Windows PowerShell' (not PowerShell Core) with Local Administrator privileges
    • Keyboard shortcut: WIN + X + A

.\Invoke-Gandalf.ps1 [-EncryptionObject <Key/Password/None>] [-Acquisition <Local/Remote>] [-OutputDirectory <C:\Path\To\Output\Location>] [-Memory] [-ShowProgress] [-CollectFiles]

Linux/macOS

  • Open 'Terminal' as root

sudo python3 gandalf.py [-h] <Key/Password/None> <Local/Remote> [-O <output_directory>] [-M] [-A] [-C]

Cross-Platform Acquisition (XPC)

Windows -> Linux/macOS

  • Open 'Windows PowerShell' (not PowerShell Core) with Local Administrator privileges

python3 gandalf.py [-h] <Key/Password/None> <Local/Remote> [-O <output_directory>] [-M] [-A] [-C]

Linux/macOS -> Windows

  • Open 'Terminal' as root

pwsh
./Invoke-Gandalf.ps1 [-EncryptionObject <Key/Password/None>] [-Acquisition <Local/Remote>] [-OutputDirectory <\Path\To\Output\Location>] [-Memory] [-ShowProgress] [-CollectFiles]


Artefacts

Below is a list of all the artefacts collected and processed from the respective operating systems.

Windows

_

Linux

_

macOS

_




Acknowledgements