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:
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.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.DEBUG
is a boolean with a default ofFalse
. "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 byemail-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
Running tests
task test
Publishing to PyPI
NOTE Replace __VERSION__
with a semver identifier such as 0.9.3
- Ensure that you are on a clean master.
- Update
__version__
insrc/configur8/__about__.py
to__VERSION__
. - Update
CHANGELOG.md
with the new version and changes. -
git add src/configur8/__about__.py CHANGELOG.md git commit -m "Bump to __VERSION__" git tag v__VERSION__ git push origin --tags
- 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
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4bf64ac9d504740d76fb065f160b5ef29cbfc3da8dd289661a4fd644df0b779c |
|
MD5 | fc254be2c59cc222d3f2c9aade231296 |
|
BLAKE2b-256 | ce2e7a032647e427ae43cb9a81b2017b38b03400810c4e0cd010b2a0b7d285a9 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | e151bd553b8f7918b8aaa4d1acadd538df190527cb668e998e56b8ba8811b70b |
|
MD5 | d2a04359b60ce796ba67ad3d11b1515f |
|
BLAKE2b-256 | 4f92846c03d2cb3d6a252c47be70be90c1ae8242c47de5fee10f8cfe16a3e85f |