Skip to main content

Serve local payload directories and generate transfer-ready HTTP or SMB targets.

Project description

payload-server

payload-server is a CLI for serving a local payload directory over HTTP or SMB and generating copyable transfer targets during pentest and red-team workflow.

It is designed to pair cleanly with artifact-locker pull:

artifact-locker pull
payload-server linux
payload-server windows 8000 443

By default it serves ~/tools/payloads:

~/tools/payloads/
├── linux/
│   └── pspy64
└── windows/
    ├── Rubeus.exe
    ├── RunasCs.exe
    ├── nc.exe
    ├── PowerView.ps1
    └── Invoke-ConPtyShell.ps1

Install

Preferred:

pipx install payload-server

For local development:

python3 -m venv .venv
. .venv/bin/activate
python3 -m pip install -e .

Usage

Use payload-server when you want to:

  • serve a local payload directory over HTTP
  • optionally expose the same directory over SMB
  • save the active serving context for follow-on commands
  • select a currently served file and copy its HTTP URL, SMB path, or local path

Serve Linux payloads over HTTP:

payload-server linux

Serve Windows payloads and write a staged ConPtyShell launcher:

payload-server windows 8000 443

Use SMB instead of HTTP:

payload-server windows --smb

Reuse the active serving context:

payload-server status
payload-server pick http
payload-server pick smb   # requires an active state started with --smb
payload-server pick local
payload-server pick ask

Behavior

  • Detects tun0, tun1, wg0, tap0, then eth0 for LHOST
  • Writes serving state to ~/.local/state/payload-server/state.json
  • Uses a fuzzy built-in HTTP server by default
  • Supports --updog and --plain-http as alternate HTTP backends
  • Uses impacket-smbserver or smbserver.py when --smb is enabled

Optional Runtime Tools

Some features depend on tools that are discovered at runtime instead of being hard install requirements:

  • rofi for interactive picking
  • wl-copy, xclip, or xsel for clipboard copy
  • tree for compact directory previews
  • updog for the alternate upload-capable HTTP backend
  • impacket-smbserver or smbserver.py for SMB serving
  • ip for interface and route based LHOST detection

If those tools are absent, the related feature fails with a direct error message while the rest of the CLI remains usable.

Relationship To artifact-locker

payload-server does not ship payloads. It serves a user-managed local directory. The intended workflow is:

  1. Curate and publish with artifact-locker
  2. Pull the approved mirror locally with artifact-locker pull
  3. Serve the synced directory with payload-server

Current artifact-locker builds keep the local payload tree flat (/windows/winpeas.exe, /windows/PowerView.ps1). The fuzzy server still understands older caches that used per-artifact UUID subdirectories, so short paths continue to work during migration.

Tests

python3 -m unittest discover -s tests
python3 -m compileall src tests

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

payload_server-0.1.3.tar.gz (12.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

payload_server-0.1.3-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file payload_server-0.1.3.tar.gz.

File metadata

  • Download URL: payload_server-0.1.3.tar.gz
  • Upload date:
  • Size: 12.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for payload_server-0.1.3.tar.gz
Algorithm Hash digest
SHA256 acbe04abbf9c1c601d2e2a4c5a15ff625cd0bde38107df78a1f9dea355d4ea10
MD5 f1ab9b8192156122d60a1c34de4b3ab4
BLAKE2b-256 fcad0e464dcda3da816b9f99d644b53eb9a3fb59363fe8331462b3494ffceaff

See more details on using hashes here.

Provenance

The following attestation bundles were made for payload_server-0.1.3.tar.gz:

Publisher: publish-pypi.yml on CameronCandau/Payload-Server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file payload_server-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: payload_server-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for payload_server-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 029f28141faef36074ab850d59c8c636b297feecd0f523f01e74e139338f4306
MD5 f20adad43c8d1b0a594b94e0168e483f
BLAKE2b-256 d0d33151dd5ed454bb41d592ed788ebe716a51bfb5938172995e0cc1d2da877f

See more details on using hashes here.

Provenance

The following attestation bundles were made for payload_server-0.1.3-py3-none-any.whl:

Publisher: publish-pypi.yml on CameronCandau/Payload-Server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page