Nemesis CLI
January 14, 2026 ยท View on GitHub
A command-line interface for the Nemesis platform that provides file submission, monitoring, and C2 connector functionality.
Purpose
This CLI tool serves as the primary interface for uploading files to Nemesis, monitoring directories for new files, and synchronizing data from C2 frameworks like Mythic, Cobalt Strike and Outflank.
Features
- File submission: Upload single files or entire directories to Nemesis
- Directory monitoring: Real-time monitoring of folders for new files
- C2 connectors: Synchronize data from Mythic, Cobalt Strike and Outflank C2 frameworks
- Stress testing: Load testing capabilities for the Nemesis API
- Module testing: Execute file enrichment modules standalone for development
Commands
submit
Upload files or directories to Nemesis for processing.
Key options:
-r, --recursive: Process subdirectories recursively-w, --workers: Number of concurrent upload threads (default: 10)--project: Project name for metadata (default: assess-test)--agent-id: Agent identifier for tracking uploads
monitor
Monitor a directory for new files and automatically submit them to Nemesis.
Key options:
--only-monitor: Skip existing files, only watch for new ones-w, --workers: Number of threads for initial submission
connect-mythic
Synchronize data between Mythic C2 framework and Nemesis.
Configuration:
- Uses
settings_mythic.yamlconfiguration file --showconfig: Display example configuration
connect-outflank
Ingest data from Outflank Stage1 C2 into Nemesis.
Configuration:
- Uses
settings_outflank.yamlconfiguration file --showconfig: Display example configuration
connect-cobaltstrike
Ingest data from Cobalt Strike into Nemesis.
Configuration:
- Uses
settings_cobaltstrike.yamlconfiguration file --showconfig: Display example configuration
Additional Tools
- stress_test: Load testing tool for API performance evaluation
- module_runner: Standalone execution of file enrichment modules for development and testing
Authentication
All commands support basic authentication with configurable username and password options (default: n/n).
Manually running with Python
- Navigate to the cli directory. Perform all the following steps from this directory.
cd Nemesis/projects/cli
- Install system dependencies required for building native packages:
# Debian/Ubuntu
sudo apt-get install -y libleveldb-dev
# macOS
brew install leveldb
- Install dependencies and run it:
uv sync
uv run python -m cli
Manually Building and Using with Docker
- Navigate to the cli directory. Perform all the following steps from this directory.
cd Nemesis/projects/cli
- Build the base images:
docker compose -f ../../compose.base.yaml build
- Build the nemesis-cli image:
docker build -t nemesis-cli --target prod --no-cache -f Dockerfile ../..
Validate --target arguments are prod or dev.
- Run the nemesis-cli container:
docker run --network host -v /:/data --rm nemesis-cli submit /data/etc/issue
Using Docker Compose
Pull the published production image and run it
- Navigate to the cli directory. Perform all the following steps from this directory.
cd Nemesis/projects/cli
- Pull the published production container and run it:
docker compose -f compose.yaml run --rm cli
Build and run the dev/production images
- Navigate to the cli directory. Perform all the following steps from this directory.
cd Nemesis/projects/cli
- Build the base images:
docker compose -f ../../compose.base.yaml build
- Build and run the dev or production containers.
To run the development container, run the following. This mounts CLI's code into container and uses the dev base image. It implicitly merges compose.yaml and compose.override.yaml.
docker compose run --rm cli
Alternatively, you can build the production image and run it with the following:
docker compose -f compose.yaml -f compose.prod.build.yaml run --rm cli
Using submit.sh (in dev)
Building the dev image
- Navigate to the cli directory. Perform all the following steps from this directory.
cd Nemesis/projects/cli
- Build the base images:
docker compose -f ../../compose.base.yaml build
- Build the nemesis-cli image:
docker build -t nemesis-cli --target dev --no-cache -f Dockerfile ../..
- Export NEMESIS_CLI_IMAGE
export NEMESIS_CLI_IMAGE=nemesis-cli:latest
- Run ./submit.sh as normal:
cd ../..
./tools/submit.sh --help