Easily parse configurations across various formats (YAML, JSON, etc.) with recursive class binding, environment variables resolution and type safety.
Project description
config-binder
Simple configuration parsing with recursive class binding, environment variables resolution and types safety.
Installation
pip install config-binder
Simple example
input.yaml
host: ${MYAPP_HOST:localhost}
port: 5432
username: admin
password: ${MYAPP_PASSWORD}
ENV exposure
export MYAPP_PASSWORD=123
With binding:
class MySettings:
host: str
port: int
username: str
password: str
source_urls: List[str]
config = ConfigBinder.load('input.yaml')
print(f"type: {type(config).__name__}, config: host:{config.host} port:{config.port} source_urls:{config.source_urls}")
# Output:
# type: MySettings, config: host:localhost port:5432 source_urls:['some-url.com', 'another-url.com']
Without binding
in this case data will be returned in dict with just all the environment variables resolved
config = ConfigBinder.load('input.yaml')
print(f"type: {type(config).__name__}, config: {config}")
# Output:
# type: dict, config: {'host': 'localhost', 'port': 5432, 'username': 'admin', 'password': '123', 'source_urls': ['some-url.com', 'another-url.com']}
More complex example
input.yaml
name: MyApplication
logging_level: INFO
redis_config:
host: ${MYAPP_REDIS_HOST:127.0.0.1}
post: ${MYAPP_REDIS_PORT:6379}
password: ${MYAPP_REDIS_PASS}
encryption_Key: ${MYAPP_REDIS_ENCRYPTION_KEY}
sources_configs:
orders:
url: some-url.com/orders
token: ${MYAPP_ORDERS_SOURCE_TOKEN}
retry_policy:
max_attempts: 5
backoff_seconds: 10
products:
url: another-url.com/products
token: ${MYAPP_ORDERS_products_TOKEN}
retry_policy:
max_attempts: 3
backoff_seconds: 5
ENV exposure
export MYAPP_REDIS_PASS=redis_pass
export MYAPP_REDIS_ENCRYPTION_KEY=very_strong_key
export MYAPP_ORDERS_SOURCE_TOKEN=orders_token
export MYAPP_ORDERS_PRODUCTS_TOKEN=products_token
Config classes definition
class RedisConfig:
host: str
port: int
password: str
encryption_key: str
class RetryPolicy:
max_attempts: int
backoff_seconds: int
class SourceConfig:
url: str
token: str
retry_policy: RetryPolicy
class AppConfig:
name: str
logging_level: Literal['DEBUG', 'INFO', 'ERROR']
redis_config: RedisConfig
sources_configs: Dict[str, SourceConfig]
Binding from file
config = ConfigBinder.load('input.yaml', AppConfig)
Binding from str
variable
input_yaml is variable with the same yaml specified above
config = ConfigBinder.read(ConfigType.yaml, input_yaml, AppConfig)
Results
input yaml is now bound to AppConfig class with env variables resolution and types validation
print(config.name)
print(config.logging_level)
print(f"type: {type(config.redis_config).__name__}, config: {str(vars(config.redis_config))}")
print(f"type: {type(config.sources_configs['orders']).__name__}, config: {str(vars(config.sources_configs['orders']))}")
print(f"type: {type(config.sources_configs['products']).__name__}, config: {str(vars(config.sources_configs['products']))}")
# Output:
# MyApplication
# INFO
# type: RedisConfig, config: {'host': '127.0.0.1', 'port': 6379, 'password': 'redis_pass', 'encryption_key': 'None'}
# type: SourceConfig, config: {'url': 'some-url.com/orders', 'token': 'orders_token', 'retry_policy': <__main__.RetryPolicy object at 0x7f268fe2fe00>}
# type: SourceConfig, config: {'url': 'another-url.com/products', 'token': 'products_token', 'retry_policy': <__main__.RetryPolicy object at 0x7f268fe2fe30>}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
config_binder-0.2.0.tar.gz
(5.1 kB
view details)
Built Distribution
File details
Details for the file config_binder-0.2.0.tar.gz
.
File metadata
- Download URL: config_binder-0.2.0.tar.gz
- Upload date:
- Size: 5.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c8b8c00cfded37d9f1cb1edbf45628c4f0fe3f1c8662194e5c4b990aea2cdb04 |
|
MD5 | f638b69ea0c3dd4750ac2120f26a8d77 |
|
BLAKE2b-256 | 467f6e8479a02254414198449b51551153ed11d05da1ca9f6eaa750b6634780e |
File details
Details for the file config_binder-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: config_binder-0.2.0-py3-none-any.whl
- Upload date:
- Size: 5.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5d5814254edcc77bb0031e304b0278f851cd68d16bd06427885f61530f5ce004 |
|
MD5 | af56a015adfd8a1847bc3af8408d6cb4 |
|
BLAKE2b-256 | 1d9e7caed2daab7e50ff3af48da10564ee3f7739b8048a7fbbae15da01bb9940 |