Skip to main content

A python wrapper package for the lego application written in Golang

Project description

pylego

pylego is a python extension package to utilize the certificate management application Lego written in Golang in python.

Installation

To install this package, all you need to do is run

pip install .

in your preferred Python venv.

Usage

You can import the lego command and run any function that you can run from the CLI:

from pylego import run_lego_command
test_env = {"NAMECHEAP_API_USER": "user", "NAMECHEAP_API_KEY": "key"}
run_lego_command(
    "something@gmail.com",
    "https://localhost/directory",
    b"-----BEGIN CERTIFICATE REQUEST----- ...",
    env=test_env,
    plugin="namecheap",
    private_key="-----BEGIN RSA PRIVATE KEY-----",
)
Argument Description
email The provided email will be registered to the ACME server. It may receive some emails notifying the user about certificate expiry.
server This is the full URL of a server that implements the ACME protocol. While letsencrypt is the most common one, there are other programs that provide this facility like Vault.
csr This must be a PEM string in bytes that is user generated and valid as according to the ACME server that is being provided above. Many providers have different requirements for what is allowed to be in the fields of the CSR.
plugin Provider to use: http (HTTP-01), tls (TLS-ALPN-01), or any LEGO DNS provider from here. If no plugin is provided, pylego uses HTTP-01 by default.
env The env is a dictionary mapping of strings to strings that will be loaded into the environment for LEGO to use. All plugins require some configuration values loaded into the environment. You can find them here
private_key The provided private key will be used to register the user to the ACME server (not the key that signed the CSR), if not provided pylego will generate a new one

On top of the environment variables that LEGO supports, we have some extra ones that we use to configure the library:

Key Description
SSL_CERT_FILE Path to a CA certificate file for pylego to trust. This can be used for trusting the certificate of the ACME server provided.
HTTP01_IFACE Interface for the HTTP-01 challenge (when no DNS plugin is used or when plugin=http). Any interface by default.
HTTP01_PORT Port for the HTTP-01 challenge (when no DNS plugin is used or when plugin=http). 80 by default.
TLSALPN01_IFACE Interface for the TLS-ALPN-01 challenge (when plugin=tls). Any interface by default.
TLSALPN01_PORT Port for the TLS-ALPN-01 challenge (when plugin=tls). 443 by default.

Error Handling

All errors raised by run_lego_command() are LEGOError exceptions with structured information:

from pylego import run_lego_command, LEGOError

try:
    result = run_lego_command(...)
except LEGOError as e:
    print(f"Error: {e}")              # Includes error code in message
    print(f"Type: {e.type}")          # "acme" (server) or "lego" (client)
    print(f"Code: {e.code}")          # e.g., "invalid_csr", "dns_provider_failed"
    print(f"Detail: {e.detail}")      # Human-readable message

    # ACME-specific fields
    if e.type == "acme":
        print(f"Status: {e.status}")      # HTTP status code
        print(f"Subproblems: {e.subproblems}")  # Validation details per domain

Common error codes: invalid_csr, invalid_private_key, dns_provider_failed, network_error, certificate_obtain_failed. ACME errors include codes like unauthorized, rateLimited, dns.

How does it work?

Golang supports building a shared c library from its CLI build tool. We import and use the LEGO application from GoLang, and provide a stub with C bindings so that the shared C binary we produce exposes a C API for other programs to import and utilize. pylego then uses the ctypes standard library in python to load this binary, and make calls to its methods.

The output binary, lego.so, is installed alongside pylego, and pylego exposes a python function called run_lego_command that will convert the arguments into a JSON message, and send it to LEGO.

On pip install, setuptools attempts to build this binary by running the command

go build -o lego.so -buildmode=c-shared lego.go

If we don't have a .whl that supports your environment, you will need to have Go installed and configured for Python to be able to build this binary.

License

The Lego library used in this project is licensed under the MIT License.

pylego itself is licensed under the Apache License, Version 2.0.

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

pylego-0.1.39.tar.gz (77.6 kB view details)

Uploaded Source

Built Distribution

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

pylego-0.1.39-py3-none-any.whl (34.8 MB view details)

Uploaded Python 3

File details

Details for the file pylego-0.1.39.tar.gz.

File metadata

  • Download URL: pylego-0.1.39.tar.gz
  • Upload date:
  • Size: 77.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pylego-0.1.39.tar.gz
Algorithm Hash digest
SHA256 4e2a4493db7a4c5cc240ccf17b4632d1507ca1f95a7d46b171fab2404c9040f5
MD5 177ad62d21d25e9e77eb552968995714
BLAKE2b-256 014268d9ba09975d59f60cbc6085d554fb1b779a0dd428cf0a4b45623973b3b5

See more details on using hashes here.

File details

Details for the file pylego-0.1.39-py3-none-any.whl.

File metadata

  • Download URL: pylego-0.1.39-py3-none-any.whl
  • Upload date:
  • Size: 34.8 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pylego-0.1.39-py3-none-any.whl
Algorithm Hash digest
SHA256 78593ff7110ab54b09c8528f709453b5e36a476c833ba17d2dcc80e530b4c6f8
MD5 5188eadbea5e563bf0d8dd62a8c56931
BLAKE2b-256 c03625722bdb3068a4269d143bff75dcf8a6eba133f61f8426f9e4131d302842

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