Giter Site home page Giter Site logo

slack_handler's Introduction

Slack_handler Build & Test

Slack_handler is a python tool for extracting File slacks in raw format and writing their details to a CSV file.

The File slacks considered are both RAM and DISK file slacks which represent the data between the none multiple size of the file and the allocated size in clusters. No volume slack is considered.

  • A presentation is available on Youtube (~17min).
  • A description article is available on IEEE Xplore.

Features

Implemented so far:

  • extract all file slacks from raw or ewf disk image to a directory.
  • display file slacks in LATIN-1 or Hex encoding to the console/terminal.
  • pretty print all found file slack data in the provided disk image.
  • Write-out File slacks details to a CSV file including: the original file, the file slack size, the parent directories, MD5 and SHA1 hashes, etc.
  • Support for 'RAW' disk images.
  • Support for 'EWF' disk images.
  • Add CI using Github action.
  • Add a helper function for MD5_calc and SHA1_calc in 'utils' module for factoring the code.
  • Add EWF disk image to test_data.
  • add more tests 'test__file_slack_nbr' and computed MD5 hashs.
  • fix shenanigans of compressed files.
  • add more tests 'test__file_slack_content' (inspection at binary level).
  • add a test case for no_file_slack file.
  • Add relative/absolute location details to CSV report file.
  • cache and optimize Github actions.
  • Add support for disk images in AFF formats.
  • Optimize the way it locates the File slack space.
  • Simulate user behaviors in test disk images using a Bash script.
  • Generate more disk images for validation.
  • add XML description file of each disk image using fiwalk or fls.
  • package everything.

Installation on a Debian/GNU Linux for developers

  • Create a Virtual environment
  • Download the latest release
  • Clone pytsk repository
  • update the repo (get libtsk) python setup.py update
  • build (libtsk) python setup.py build
  • install (which will install pytsk bindings) python setup.py ìnstall
  • pip list now you should see pytsk installed if everything is ok!
  • clone pyewf repository
  • ./synclibs.sh : Script that synchronizes the local library dependencies
  • ./autogen.sh
  • ./configure --enable-python
  • python setup.py build
  • python setup.py install

For further details, please check the steps of the job Build used in Github actions process.

Installation from Pypi (In progress ... )

The tool is hosted on Pypi

  • pip3 install slack-handler
  • slack_handler --version

Usage

To dump all File slacks to 'slacks/' folder and extract all the information to CSV format file named 'report.csv' from a raw image 'USB-NTFS.dd' :

slack_handler --type raw --dump slacks/ --csv report.csv images/USB-NTFS.dd

Help:

usage: slack_handler [-h] [-e ENCODING] -t TYPE [-p] [-d DUMP] [-c CSV] [-v] [--version] disk image

Extract the file slack spaces.

positional arguments:
  disk image

optional arguments:
  -h, --help            show this help message and exit
  -e ENCODING, --encoding ENCODING
                        Display slack space in LATIN-1 or Hex. Supported options 'latin-1', 'hex'.
  -t TYPE, --type TYPE  Type of the disk image. Currently supported options 'raw' and 'ewf'.
  -p, --pprint          Pretty print all found file slack spaces.
  -d DUMP, --dump DUMP  Dump file slack spaces of each file in raw format to a directory if specified, by default temporary dir.
  -c CSV, --csv CSV     Write file slacks information to a CSV file.
  -v, --verbose         Control the verbosity of the output.
  --version             show program's version number and exit

LICENSE

Feel free to read the file LICENSE.

History

Special Thanks fly to

  • Joachim Metz for providing an initial feedback on the little tool related to the different types of disk slack space and the licensing.
  • David Cowen for the awesome serie of "How-to on programming using libtsk and python".
  • Any feedback is a welcome via Github issues or reach out via The Open Source DFIR Slack community using the registration link.

slack_handler's People

Contributors

sim4n6 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.