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

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

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.10.0.tar.gz (199.1 kB view details)

Uploaded Source

Built Distribution

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

procustodibus_agent-1.10.0-py3-none-any.whl (59.3 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for procustodibus_agent-1.10.0.tar.gz
Algorithm Hash digest
SHA256 e8ab64e3e636241b9686d3684250eff4c8495874fd1dbd9f0835c4a6906d4aa8
MD5 7efc540105bf5159c3014a1296634927
BLAKE2b-256 01e80ac4235186a82cf381daeff71373dbe02bba2bde4037454bddacce7631ad

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for procustodibus_agent-1.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5bad04fd689536795e5389a8e6cbdca6c423d5d1a28370f74e0713074ff5a1a9
MD5 fe451f1ed3845e0dba5b2c8630de53ea
BLAKE2b-256 e97153465c56617e842bb776a54c200ac7eeb11d26a8fc76de91e7ba7446730a

See more details on using hashes here.

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