Skip to main content

Utility to fetch configuration values from remote sources that integrates with Pydantic settings models

Project description

pydantic-remote-config

Library that extends pydantic's BaseSettings model and integrates with various remote sources to fetch application secrets & configuration. Supported remote sources include:

Installation

For AWS services support:

$ pip install pydantic-remote-config[aws]

Usage

Simple Example

from pydantic_remote_config.aws import SecretsManager, SSMParam
from pydantic_remote_config import RemoteSettings

class Settings(RemoteSettings):
    param_1: str = SSMParam("/foo/bar/param")
    param_2: int = SSMParam("/foo/bar/num_param")
    secret: str = SecretsManager("test-secret")

settings = Settings()
print(settings)
#> Settings(param_1="remote param", param_2=101, secret="super secret code")

Templating strings

Strings can be templated using attributes that have been defined in the class and have corresponding environment variables set. This is useful in cases where a value is stored under a different path depending on the environment.

In this example if the environment variable ENV is set to dev, the /app-name/dev/db_password value will be retrieved.

from pydantic_remote_config.aws import SSMParam
from pydantic_remote_config import RemoteSettings


class Settings(RemoteSettings):
    env: str

    db_password: str = SSMParam("/app-name/{env}/db_password")

Accessing Nested Values

Key value pairs can be accessed by specifying the key arg. The example below illustrates an example where only the database password is retrieved from a json object.

SSM Param value for /app-name/database_info:

{
  "host": "foo.rds.aws.com",
  "port": 5432,
  "username": "db_user",
  "password": "super-secret-password"
}

Remote config implementation:

from pydantic_remote_config.aws import SSMParam
from pydantic_remote_config import RemoteSettings


class Settings(RemoteSettings):
    db_password: str = SSMParam("/app-name/database_info", key="password")

Class Configuration

Each remote source or class of sources has its own configuration class that can be set.

AWS

The AWS config class supports specifying an aws region to fetch configuration from. Note that this will override the default aws region configured on the machine or boto3.

from pydantic_remote_config.aws import SecretsManager, SSMParam
from pydantic_remote_config import RemoteSettings
from pydantic_remote_config.config import AWSConfig


class Settings(RemoteSettings):
    env: str
    param: str = SSMParam("/foo/bar")
    secret: dict = SecretsManager("test-secret")

    class Config:
        aws = AWSConfig(region='us-west-2')

MyPy Support

This library works with mypy!

Roadmap

This library aims to be the one stop shop for python applications that need to fetch configuration from remote sources regardless of source. Services that are supported or on the roadmap are listed below.

  • AWS Secrets Manager
  • AWS SSM Parameter Store
  • Hashicorp Vault
  • Hashicorp Consul
  • Azure Key Vault

If you'd like to add a service to our roadmap, please open an issue and we'll be happy to get it added.

Contributing

WIP

Development Dependencies

  • asdf for managing multiple python version
  • pre-commit for formatting & linting code before commits
  • poetry managing dependencies & publishing the package

Installing Development Dependencies

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

pydantic-remote-config-0.1.0.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

pydantic_remote_config-0.1.0-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file pydantic-remote-config-0.1.0.tar.gz.

File metadata

  • Download URL: pydantic-remote-config-0.1.0.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.1 CPython/3.7.13 Darwin/20.6.0

File hashes

Hashes for pydantic-remote-config-0.1.0.tar.gz
Algorithm Hash digest
SHA256 2952dbd4350c14142b15a3d64fa301e9a9264d874002e440911096d364b912da
MD5 195e62e23ed1347f0324d70b64bbab6d
BLAKE2b-256 7cbf00ff7ee649cc4e06ca4d6cc688d4fb2b416c658d9e3dd8607ad79fa6e0aa

See more details on using hashes here.

File details

Details for the file pydantic_remote_config-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pydantic_remote_config-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c43cb2dcc2493a9615ba54da402f6973e94d732c7b3656efc868f3717e5177c6
MD5 27cc9df8d2576ea521683f62cc438a7a
BLAKE2b-256 83df297619165c7a03b45e3edfa59ec68d9f0ed08f789ae8964a06843a4dab25

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