Configuration tool for all Navigator Services Tool for accessing Config info from different sources.
Project description
Navigator NavConfig
NavConfig is a configuration tool for getting variables from environment and other sources. Is used by Navigator Framework, but is possible to use in other applications as well.
Navigator NavConfig can load Configuration directives from different sources:
- Environment files (.env)
- Memcached Variables
- INI files (using configParser)
- Redis Server
The main goal of NavConfig is centralize configuration access in a single and immutable unique point of truth.
NavConfig can be shared across several modules.
Motivation
Any Application require too many configuration options, some configuration options need to be secrets, credentials, etc, and also, can be dependable of the environment an application runs (development, testing, production, etc.).
Instead of creating python files, we are using python-dotenv + INI files to separate concerns (secrets vs configuration options), NavConfig support also getting data instead of INI files from YAML or TOML files (for complex types).
Installation
pip install navconfig
Quickstart
First of all, let's create a simple configuration environment.
Creates a directory for an .INI file and the environment (.env) file.
mkdir {env,etc}
put a .env file inside of the "env" folder, the first line is the directive to know where the "INI" file lives (even if we can put the . INI file outside of the current dir).
the directory tree is very clear:
|- myapp/
| |- __init__.py
| |- env/
| | |- .env
| | |- dev/
| | |- .env
| | |- prod/
| | |- .env
| |- etc/
| | |- myconfig.ini
| | ...
# file: .env
CONFIG_FILE=etc/myconfig.ini
APP_NAME=My App
Then, in your code, call navconfig "config" object, and start getting your environment variables inside your application.
from navconfig import config
APP_NAME = config.get('APP_NAME')
# the result is "My App".
but also you can use config as a object:
from navconfig import config
APP_NAME = config.APP_NAME
# the result is "My App".
Working with Environments
NavConfig can load all environment variables (and the .INI files associated within the .env file) from different directories, every directory works as a new Environment and you can split your configuration for different environments, like this:
env/
.
├── dev
| |- .env
├── prod
| |- .env
├── staging
| |- .env
└── experimental
| |- .env
Then, you can load your application using the "ENV" environment variable:
ENV=dev python app.py
Configure Logging
NavConfig has owns logging facility, if you load logging_config from Navconfig, you will get a logging configuration using the Python dictConfig format.
also, if you put an environment variable called "logstash_enabled = True", there is a ready to use Logging facility using Logstash.
import logging
from navconfig.logging import (
logdir,
loglevel,
logging_config
)
from logging.config import dictConfig
dictConfig(logging_config)
To use just the logger as expected with logging.getLogger(), e.g.
logger = logging.getLogger('MY_APP_NAME')
logger.info('Hello World')
By default, the current logging configuration make echo to the standard output:
[INFO] 2022-03-11 19:31:39,408 navigator: Hello World
Custom Settings
with Navconfig, users can create a python module called "settings.py" on package "settings" to create new configuration options and fine-tune their configuration.
|- myapp/
| |- settings/
| |- __init__.py
| |- settings.py
on "settings.py", we can create new variables using python code:
from navconfig import config, DEBUG
print('::: LOADING SETTINGS ::: ')
# we are in local aiohttp development?
LOCAL_DEVELOPMENT = (DEBUG is True and sys.argv[0] == 'run.py')
SEND_NOTIFICATIONS = config.get('SEND_NOTIFICATIONS', fallback=True)
And those variables are reachable using "navconfig.conf" module:
from navconfig.conf import LOCAL_DEVELOPMENT
if LOCAL_DEVELOPMENT is True:
print('We are in a Local instance.')
Dependencies
- ConfigParser
- Python-Dotenv
- pytomlpp
- PyYAML
- redis
- pylibmc
Requirements
- Python >= 3.8
- asyncio (https://pypi.python.org/pypi/asyncio/)
- python-dotenv
Contribution guidelines
Please have a look at the Contribution Guide
- Writing tests
- Code review
- Other guidelines
Who do I talk to?
- Repo owner or admin
- Other community or team contact
License
NavConfig is released under MIT license.
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 Distributions
Built Distributions
Hashes for navconfig-0.10.8-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 08de553a24f49ef63e5be5c7686308a66c2e277f92e4eeda6a2ff19a652af903 |
|
MD5 | 75904b6b8fefc74cb088069ce2c7b324 |
|
BLAKE2b-256 | aa0973e79c52f4c559257dc2b810dc1731708d0dad4b0d37efb35b77d6719716 |
Hashes for navconfig-0.10.8-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | dac20ce2301272359e2cace6b3c18e37ccc570d35feb1031824456888049e336 |
|
MD5 | 743cb643a28a50fda0941fbec19442bd |
|
BLAKE2b-256 | bb52473016557a39681ff1e97df6df817b2b0a14b76aaf8f092c0014957c2dd0 |