Skip to main content

Synchronizes your WireGuard settings with Pro Custodibus.

Project description

Pro Custodibus Agent

Pro Custodibus is a service that makes WireGuard networks easy to deploy and manage. You run the Pro Custodibus agent on each WireGuard host you want to manage, and the agent monitors and synchronizes the hosts' WireGuard settings with the remote Pro Custodibus service.

Installing

Requires python 3.8 or newer and libsodium. Installer script can install requirements, plus the agent itself, on most linuxes, FreeBSD, OpenBSD, and macOS (if macOS has Homebrew). Install from source like the following:

./install.sh --install

Or run it like the following to see more options:

./install.sh --help

See the Installer Documentation for full details (or to download the pre-built Windows installer).

Docker

The docker/wireguard.dockerfile is built weekly and pushed to the docker.io/procustodibus/wireguard repository. It produces a base WireGuard image without the agent.

The docker/agent.dockerfile is built weekly and pushed to the docker.io/procustodibus/agent repository. It produces a Docker image with WireGuard and the latest agent installed together.

Run either image by placing your WireGuard or Pro Custodibus configuration files in a host directory like /srv/containers/wireguard/conf, and then running the image like the following:

docker run \
    --cap-add NET_ADMIN \
    --publish 51820:51820/udp \
    --name wireguard \
    --rm \
    --volume /srv/containers/wireguard/conf:/etc/wireguard \
    procustodibus/agent

See the Container Documentation for full details.

Development

Set up dev env

Install uv, and from this project root run:

uv python install
uv sync

Dev tasks

Run unit tests:

uv run pytest

Run unit tests in watch mode:

uv run ptw .

Run unit tests with coverage report:

uv run pytest --cov --cov-report term-missing

Run linter and auto-fix where possible:

uv run ruff check --fix

Run formatter:

uv run ruff format

Build and run docker dev image (with *.conf files in /srv/containers/wireguard/conf):

docker/dev.sh dev
docker run \
    --cap-add NET_ADMIN \
    --publish 51820:51820/udp \
    --name wireguard \
    --rm \
    --volume /srv/containers/wireguard/conf:/etc/wireguard \
    procustodibus-agent:dev

Run all (docker-based) installer tests:

docker compose -f test_install/docker-compose.yml build --pull
uv run pytest test_install

Build Windows MSI

Install uv, and from this project root run:

uv run --python 3.12 --group freeze cx_freeze_setup.py bdist_msi

The MSI package will be built as dist\procustodibus_agent-x.x.x-win64.msi.

Build Windows installer exe

  1. Install uv.

  2. Install Inno Setup.

  3. Build the Windows executables with cx_freeze:

    uv run --python 3.12 --group freeze cx_freeze_setup.py build_exe
    
  4. Build the Windows installer with Inno Setup:

    "C:\Program Files (x86)\Inno Setup 6\ISCC.exe" installer\windows.iss
    

The installer will be built as dist\ProCustodibusAgentInstaller.exe.

Contributing

Resources

License

The MIT License

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

procustodibus_agent-1.8.0.tar.gz (196.5 kB view details)

Uploaded Source

Built Distribution

procustodibus_agent-1.8.0-py3-none-any.whl (57.1 kB view details)

Uploaded Python 3

File details

Details for the file procustodibus_agent-1.8.0.tar.gz.

File metadata

File hashes

Hashes for procustodibus_agent-1.8.0.tar.gz
Algorithm Hash digest
SHA256 91651e630332fd929860affd292f863b4a2610ab2e118da650a1c65231957bf0
MD5 95d59ed5fad4e114a2b64f93572d8a42
BLAKE2b-256 2f98f06202d3d40133f46d827e575d67baf1010e904998118af469b6b6831065

See more details on using hashes here.

File details

Details for the file procustodibus_agent-1.8.0-py3-none-any.whl.

File metadata

File hashes

Hashes for procustodibus_agent-1.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 28f0ced7e053ba24dceee47cca69a1dcf2ab3ff0618e505d208c0d7223dd5942
MD5 f6bc800dd1c242d146102545b4661ea6
BLAKE2b-256 ee265980431809ef24e698279d0dd7efc268b7f557b06bd20810e0fc61f9611b

See more details on using hashes here.

Supported by

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