casemanagement is a Python Flask-powered application designed to streamline the management of forensic cases. It provides an intuitive interface for investigators to upload evidence and receive the analyzed results.
- Case Management: Easily create, update, and delete forensic cases.
- Evidence Tracking: Upload and analyze forensic case data.
- User Authentication: Secure user authentication and authorization system.
- Automatic reporting: Automatically send analyzed data to Splunk backend.
- Customizable: Adapt the application to fit your specific forensic investigation workflow.
To run the application, you need to set the following environment variables:
- SECRET_KEY: varchar(100) secret value for cookie "salt" in Flask
- SECURITY_PASSWORD_SALT: varchar(100) secret value for password salting
- SPLUNK_URL: url(
https://{ip}:{port}
) for Splunk api port 8089 - SPLUNK_TOKEN: JWT for Splunk access via api as bearer
- PROD_DB_STRING: PostgreSQL connection string as
postgesql://{username}:{password}@{hostname}:{port}/{database}?sslmode=require
- ADMIN_PASSWORD: Admin user password
- ADMIN_EMAIL: Admin user emailaddress
- HAYABUSA_WORKER_URL: Hayabusa worker url with /upload [explained further down below]
- HAYABUSA_ACCESS_TOKEN: Hayabusa accesstoken for the workers [explained further down below]
- Pull image:
docker pull ghcr.io/tobiass1402/casemanagement:main
- Set-up docker-compose
cp docker-compose-example.yml docker-compose.yml
-
Edit variables
-
Run
docker compose up
- Clone the repository:
git clone https://github.com/tobiass1402/casemanagement
cd casemanagement
- Install dependencies:
pip install -r requirements.txt
- Set-up docker-compose
cp docker-compose-example.yml docker-compose.yml
-
Edit variables
-
Run and build
docker compose up --build
The application should now be running and accessible at http://0.0.0.0:9000
.
Contributions are welcome! If you have any suggestions, feature requests, or bug reports, please open an issue or submit a pull request.
- seperate Celery task files
- seperate files for functions and classes
- create error view for tasks
- create retry button for failed tasks
- create database connection task storage