Skip to content

jhm-ciberman/phantom-desktop

Repository files navigation

Phantom Desktop Logo

Build For Windows For Linux Language English Language Spanish

Phantom Desktop is an application for forensic digital image processing.

Main screen

Download

Phantom Desktop can be downloaded from the releases section. The application is available for Windows and Linux. The first time you run the application, it will download the necessary files. After that, you can use it offline.

IMPORTANT: Requires a CPU that supports AVX Instructions (Any modern CPU > 2011) otherwise the application won't even start. If you want to use it on an older CPU, you can need to compile it from source.

Releases were tested in Windows 10 and Ubuntu 22.04 LTS.

Wiki

The wiki contains information about the application and how to use it.

Contributing

Initial setup:

After cloning, create a virtual environment, activate it, and install the pip requirements:

git clone git@github.com:jhm-ciberman/phantom-desktop.git
cd phantom-desktop
python -m venv .env
source .env/Scripts/activate
pip install -r requirements.txt

Running

To run Phantom Desktop from the command line, use the following command:

python main.py

Or in VSCode, you can use the "Run" command, it's already configured for this project in the launch.json file.

Building

To generate an executable file that can be distributed, run the following command:

python setup.py build

This will use cx_Freeze to generate an executable file according to the current operating system. The output files will be placed in the build folder ready to be distributed.

Code conventions

This project uses Qt and thus, it tries to follow the Qt style for all classes that inherit from QObject. The rest of the code follows the PEP8 style guide.

For more info please refer to this blog post.

For Docstrings, the project uses the Google style.

The project has some type hints, but it's only for basic IDE autocomplete. It's not intended for use with static type checkers.

Phantom Project File format

The phantom project file format (*.phantom) is an open format and it's specification can be found here.

License

About

A desktop application for forensic digital image processing.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages