Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/antagon/TCHunt-ng
Reveal encrypted files stored on a filesystem.
https://github.com/antagon/TCHunt-ng
cryptography encryption forensics security truecrypt
Last synced: 2 months ago
JSON representation
Reveal encrypted files stored on a filesystem.
- Host: GitHub
- URL: https://github.com/antagon/TCHunt-ng
- Owner: antagon
- License: gpl-3.0
- Created: 2016-10-18T06:24:27.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-11-09T18:01:15.000Z (about 6 years ago)
- Last Synced: 2024-08-04T22:15:24.486Z (6 months ago)
- Topics: cryptography, encryption, forensics, security, truecrypt
- Language: C
- Homepage:
- Size: 4.83 MB
- Stars: 52
- Watchers: 5
- Forks: 8
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- License: COPYING
Awesome Lists containing this project
- awesome-anti-forensic - Tchunt-ng
README
# TCHunt-ng
TCHunt-ng attempts to reveal encrypted files stored on a filesystem. The program is successful in finding ***TrueCrypt***, ***VeraCrypt***, ***CipherShed*** containers; ***LUKS***, ***EncFS***, ***PGP/GPG*** encrypted files; ***OpenSSH*** and ***PEM*** private keys; password databases; files made up of random data. The code is based on ideas laid out in the project of Stephen Judge named *TCHunt*, hence the name. The original code has aged badly, having unnecessary dependencies and unfixed bugs. A rewrite seemed like a good idea.
TCHunt-ng is a free software licensed under **GPLv3**.
## Methodology
TCHunt-ng performs following tests against content of a file to determine if it is of interest:
1. Test against a database of well known file-types provided by *libmagic*.
2. Test the size of a file to be greater than 19 kiB and of modulo 512. The test is performed only in *TCHunt compatibility mode*.
3. *Chi-squared test*.## Usage
Usage: ./tchuntng [options] [file ...]
Options:
-p preserve access time of files analyzed
-q quietly treat no result as success
-s show a file's classification
-T enable TCHunt compatibility mode
-v show version information
-h show usage information### Examples
Test a single file:
$ tchuntng ./test/samples/message.txt.asc
Test multiple files located in the same directory:
$ tchuntng ./*.*
Traverse a directory tree testing all the files:
$ find ./ -type f | tchuntng -
## Environment
The behavior of TCHunt-ng is affected by the following environment variables.
The environment variable MAGIC can be used to override default magic file name. Please note that doing so may affect other programs that rely on *libmagic*.
## Exit status
TCHunt-ng exits with one of the following exit codes:
* `0` - content of a file is *likely* to be encrypted.
* `1` - a generic error occured.
* `2` - content of a file is not encrypted.
* `3` - interrupted by a signal.## Dependencies
* libmagic >= 5.0
* glibc >= 2.0
## Installation
On Ubuntu:
sudo apt-get install libmagic-dev
On Fedora:
sudo dnf install file-devel
Compile the source code and install the executable:
make && sudo make install
## Limitations
TCHunt-ng has no way to tell apart a genuinely encrypted file and a file made up of random data. Files smaller than 32 bytes, unless recognized by its type, are ignored.
## References
https://github.com/stephenjudge/TCHunt
https://github.com/file/file
https://en.wikipedia.org/wiki/Chi-squared_test
http://forensicswiki.org/wiki/TrueCrypt#Detection