Skip to main content

Read config from environment for 12 factor apps

Project description

PyPI Build Status Coverage Report

Python module for reading config from environment for 12-factor apps. Supports Python 3.4+

Rationale

In a 12-factor app, config comes from the environment. For example, on Heroku, config variables are set using heroku config:set on the command line, then passed to the application in the environment.

Reading and parsing config from the environment is tedious and error-prone. For example, a Django app has settings.DEBUG which should be either True or False. The operator runs heroku config:set DJANGO_DEBUG off intending to disable it, but the application only sees a non-empty string and treats the value as True.

This sort of problem can be handled case-by-case but doesn’t need to be. Clearly a configuration setting with a fallback boolean value should be interpreted as boolean from the environment. Likewise a fallback integer setting indicates the associated environment variable should be converted from string to int.

Sounds like a job for a small and well-tested Python module, right?

Installation

Install from PyPI:

pip install bienvenue

Usage

Bienvenue provides the function make_env_reader which returns a new function for accessing the environment. For example:

from bienvenue import make_env_reader

env = make_env_reader(prefix='MY_')

DEBUG = env('DEBUG', False)
SECRET_KEY = env('SECRET_KEY', 'fallback-secret-for-dev')
ALLOWED_HOSTS = env('ALLOWED_HOSTS', [])

The env reader looks for MY_DEBUG in os.environ. If it’s not there, the default value False will be returned. However if it’s found, then the value there will be interpreted according to the type of the default, in this case boolean. Common strings such as on/off, true/false and yes/no are interpreted into True or False.

Likewise SECRET_KEY will be extracted from MY_SECRET_KEY and then interpreted as a string value.

ALLOWED_HOSTS will be extracted from MY_ALLOWED_HOSTS and JSON decoded as a list, since the default value is a list.

If bienvenue encounters unknown types or values during parsing, it will log an error and fall back to the provided default.

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

bienvenue-3.0.1.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

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

bienvenue-3.0.1-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file bienvenue-3.0.1.tar.gz.

File metadata

  • Download URL: bienvenue-3.0.1.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.9.1 pkginfo/1.3.2 requests/2.18.4 setuptools/39.2.0 requests-toolbelt/0.8.0 tqdm/4.19.6 CPython/3.6.6

File hashes

Hashes for bienvenue-3.0.1.tar.gz
Algorithm Hash digest
SHA256 9cafe50a37e9df8b4f31fcecccc9c36a7e939f7523da6cd860205d6b2afd4962
MD5 b66ef4ffe4e4241b01976d156ecd0c12
BLAKE2b-256 79283ac12e1d5632c4f6f5523b4f6789eed93ed588591b98287f479b0dae8ca2

See more details on using hashes here.

File details

Details for the file bienvenue-3.0.1-py3-none-any.whl.

File metadata

  • Download URL: bienvenue-3.0.1-py3-none-any.whl
  • Upload date:
  • Size: 7.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.9.1 pkginfo/1.3.2 requests/2.18.4 setuptools/39.2.0 requests-toolbelt/0.8.0 tqdm/4.19.6 CPython/3.6.6

File hashes

Hashes for bienvenue-3.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e1b2232d64016414e67203855a805d30e7db969d3d72b7eb4f6b320174c14b2e
MD5 c5c890ab14329e1287316a009d5e4024
BLAKE2b-256 b40cf9164f6430f6b12437205c02679bf065bdb069e0d64480ed452216c41e53

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