Skip to main content

A Python port of daemontools' envdir.

Project description

Linux Build Status Windows Build Status

This is a Python port of daemontools’ tool envdir. It works on Windows and other systems which can run Python. It’s well tested and doesn’t need a compiler to be installed.

envdir runs another program with a modified environment according to files in a specified directory.

So for example, imagine a software you want to run on a server but don’t want to leave certain configuration variables embedded in the program’s source code. A common pattern to solve this problem is to use environment variables to separate configuration from code.

envdir allows you to set a series of environment variables at once to simplify maintaining complicated environments, for example in which you have multiple sets of those configuration variables depending on the infrastructure you run your program on (e.g. Windows vs. Linux, Staging vs. Production, Old system vs. New system etc).

Let’s have a look at a typical envdir:

$ tree envs/prod/
envs/prod/
├── DJANGO_SETTINGS_MODULE
├── MYSITE_DEBUG
├── MYSITE_DEPLOY_DIR
├── MYSITE_SECRET_KEY
└── PYTHONSTARTUP

0 directories, 3 files
$ cat envs/prod/DJANGO_SETTINGS_MODULE
mysite.settings
$

As you can see each file has a capitalized name and contains the value of the environment variable to set when running your program. To use it, simply prefix the call to your program with envdir:

$ envdir envs/prod/ python manage.py runserver

That’s it, nothing more and nothing less. The way you structure your envdir is left to you but can easily match your configuration requirements and integrate with other configuration systems. envdirs contain just files after all.

An interesting summary about why it’s good to store configuration values in environment variables can be found on the 12factor site.

Changelog

1.0.0 (26/03/2018)

  • Drop python 2.6, 3.2 and 3.3

  • Add explicit support for python 3.6

  • Add support for symlinks

  • Improved support for windows

0.7 (08/10/2014)

  • Use exec (os.execvpe) to replace the envdir process with the child process (fixes #20).

  • Change isenvvar() to only check for = in var names.

0.6.1 (12/23/2013)

  • Fixed handling SIGTERM signals to make sure all children of the forked process are killed, too. Thanks to Horst Gutmann for the report and help fixing it.

0.6 (12/03/2013)

  • Rewrote tests with pytest.

  • Vastly extended Python API.

  • Added Sphinx based docs: https://envdir.readthedocs.io/

  • Fixed killing child process when capturing keyboard interrupt.

  • Added standalone script based on PEPs 441 and 397, compatible with Python Launcher for Windows. See the installation instructions for more info.

0.5 (09/22/2013)

  • Added check if the the provided path is a directory and throw an error if not. This adds compatibility to the daemontools’ envdir.

  • Make sure to convert Nulls (\0) to newlines as done so in daemontools’ envdir.

0.4.1 (08/21/2013)

  • Fixed envdir.read() to actually work with already existing environment variables. Extended docs to test Python use.

0.4 (08/09/2013)

  • Added envshell command which launches a subshell using the environment as defined in the given envdir. Example:

    $ envshell ~/mysite/envs/prod/
    Launching envshell for /home/jezdez/mysite/envs/prod. Type 'exit' or 'Ctrl+D' to return.
    $ python manage.py runserver
    ..

0.3 (07/30/2013)

  • Catch KeyboardInterrupt exceptions to not show a traceback from envdir but the repsonse from the called command.

  • Allow multiline environment variables. Thanks to Horst Gutmann for the suggestion. This is a departure from daemontools’ standard which only allows the first line of the environment variable file.

0.2.1 (07/11/2013)

  • Fixed python -m envdir

  • Extended README to better describe the purpose

0.2 (07/10/2013)

  • Added ability to use envdir from Python.

0.1 (07/10/2013)

  • Initial release.

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

envdir-1.0.1.tar.gz (20.5 kB view details)

Uploaded Source

Built Distribution

envdir-1.0.1-py2.py3-none-any.whl (13.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file envdir-1.0.1.tar.gz.

File metadata

  • Download URL: envdir-1.0.1.tar.gz
  • Upload date:
  • Size: 20.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for envdir-1.0.1.tar.gz
Algorithm Hash digest
SHA256 ede06bacc4da4a74bff86b0aca7a9c174f60750ff8ff78e2dc6b183df02a566b
MD5 241867305eb259360fad31438f608077
BLAKE2b-256 26b3583f3b1481f8af69ca01ba15079435152e9402543a3f8423ead98879c5fa

See more details on using hashes here.

File details

Details for the file envdir-1.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for envdir-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 54ed3f965fa33f433f989a2bfb26bcd04035f27d105217c33a72783971224d0d
MD5 2033336d8d2bb1709628419c6aa9e8a8
BLAKE2b-256 75dd817dc77edf4807fc2c29e28046ab83aa7ccfe27e79d24ca37d7aaa1e36bb

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