Skip to main content

Type-safe configuration and validation library

Project description

configur8

Python type-safe configuration and validation library.

Introduction

Configuration validation is a common problem in Python. This library aims to provide a simple, type-safe way to validate configuration either by file or environment variables.

An example:

/path/to/config.yaml:

mysql:
   host: localhost
   port: 3306
   user: not_root
   password: my_password
import configur8
from configur8 import env


class MySQL:
   # define the fields and their types
   host: str
   # default values are supported
   port: int = 3306
   # default values can programmatically be defined, e.g. from an env var
   user: str = env.str("MYSQL_USER", "definitely_not_root")
   password: str


class Config:
   mysql: MySQL


config = configur8.load(Config, "/path/to/config.yaml")

assert isinstance(config.mysql, MySQL)  # True

The above example will load the configuration from the file at /path/to/config.yaml and validate it against the Config class. If the configuration is invalid, an exception will be raised.

Environment only

An example:

from configur8 import env


SECRET_KEY = env.str("SECRET_KEY")
NUM_WORKERS = env.int("NUM_WORKERS", 2)
DEBUG = env.bool("DEBUG", False)

In the example above:

  1. SECRET_KEY is a required environment variable - attempting execute the code without it defined will result in an exception. This is typically what you want so that apps and services don't start in an unintended state.
  2. NUM_WORKERS will be parsed into an integer. If the env var is not defined, 2 will be used as a default. If a non integer value is parsed, an error will be raised.
  3. DEBUG is a boolean with a default of False. "Truthy" values can be used, e.g. "on", "1", etc.

Everything is designed to be type safe.

Types of values supported

  • String - env.str
  • Integer - env.int
  • Float - env.float
  • Boolean - env.bool
  • Url - env.url
  • Path - env.path
  • Email - env.email - Validation provided by email-validator Each type can support optional values and work with lists:
from configur8 import env

ALLOWED_HOSTS = env.url.list("ALLOWED_HOSTS")

Given the environment:

ALLOWED_HOSTS=http://localhost,http://my-staging-server

The python value of ALLOWED_HOSTS would be:

["http://localhost", "http://my-staging-server"]

Boolean flags

Boolean values are supported. See configur8.env.BOOLEAN_TRUTHY_VALUES:

  • true
  • 1
  • on
  • yes
  • ok

Will all result in a True Python value. Anything else will result in False.

Urls

These are augmented objects that have extra attributes in case you need them:

from configur8 import env

# https://my-bucket.s3.us-west-2.amazonaws.com
bucket = env.url("S3_BUCKET_URL")

assert bucket.protocol == "https"
assert bucket.host == "my-bucket.s3.us-west-2.amazonaws.com"

There are a bunch more properties - see configur8.url.Url.

Paths

These are augmented objects that have extra attributes in case you need them:

from configur8 import env

# /var/run/secrets/my-mounted-volume/my-secret
my_creds = env.path("SERVICE_CREDS").read()

# my_creds will hold the contents of the file in the env var

Development

  1. Install PDM
  2. Install Task

Running tests

task test

Publishing to PyPI

NOTE Replace __VERSION__ with a semver identifier such as 0.9.3

  1. Ensure that you are on a clean master.
  2. Update __version__ in src/configur8/__about__.py to __VERSION__.
  3. Update CHANGELOG.md with the new version and changes.
  4. git add src/configur8/__about__.py CHANGELOG.md
    git commit -m "Bump to __VERSION__"
    git tag v__VERSION__
    git push origin --tags
    
  5. Wait for Github Actions to succeed and publish the library to the public PyPI.

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

configur8-2.0.1.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

configur8-2.0.1-py3-none-any.whl (10.6 kB view details)

Uploaded Python 3

File details

Details for the file configur8-2.0.1.tar.gz.

File metadata

  • Download URL: configur8-2.0.1.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.4.7 CPython/3.11.2

File hashes

Hashes for configur8-2.0.1.tar.gz
Algorithm Hash digest
SHA256 4bf64ac9d504740d76fb065f160b5ef29cbfc3da8dd289661a4fd644df0b779c
MD5 fc254be2c59cc222d3f2c9aade231296
BLAKE2b-256 ce2e7a032647e427ae43cb9a81b2017b38b03400810c4e0cd010b2a0b7d285a9

See more details on using hashes here.

File details

Details for the file configur8-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: configur8-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.4.7 CPython/3.11.2

File hashes

Hashes for configur8-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e151bd553b8f7918b8aaa4d1acadd538df190527cb668e998e56b8ba8811b70b
MD5 d2a04359b60ce796ba67ad3d11b1515f
BLAKE2b-256 4f92846c03d2cb3d6a252c47be70be90c1ae8242c47de5fee10f8cfe16a3e85f

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 Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page