Skip to main content

A simple configuration files manager package

Project description

ConfigDmanager

Installation

A simple pip install will do :

python -m pip install ConfigDmanager

Use

  • Suppose we have two Configuration files ( of json type ) :

    • ParentConfig.json :

      {
      "__name": "ParentConfig",
      "param1": "Value 1"
      }
      
    • MainConfig.json :

      • The __parent parameter specifies the path to another configuration file that will give us default values ( Think of it as inheritance ).
      • The text contained between brackets will be reinterpreted in runtime :

      in the example below ${param1} will be reinterpreted as "Value 1"

      • The use of environment variables for sensitive data like passwords is also possible : through this text ${os_environ[password]}
      • You can also read the content of a text file with a simple : ${read_file[file_path]} as shown in the example below.
      {
        "__name": "MainConfig",
        "__parent": "demo.ParentConfig",
        "param2": "Value 2 and ${param1}",
        "user_info": {"user": "username", "password": "${os_environ[password]}"},
        "long_text": "${read_file[./demo.py]}"
      }
      
  • To import those configuration using configDmanager, use this demo code :

from configDmanager import import_config


class RandomClass:
    def __init__(self, param1, param2, user_info, long_text):
        print(f"param1: {param1}")
        print(f"param2: {param2}")
        print(f'my user: {user_info.user}')
        print(f'my user: {user_info.password}')
        print(f'my long text: "{long_text[:40]}"')


config = import_config('MainConfig')

print("## Object 1")
obj = RandomClass(**config)


# You can also select specific keys
print("## Object 2")
another_obj = RandomClass(param2='Another Value', long_text="Not so long", **config[['param1', 'user_info']])

Export Config file

You can export a Config by simply using the export_config function

from configDmanager import export_config, Config

config = Config({'my_param': 'my_value'})

export_config(config, 'NewConfig')

If you wish to modify an existing config, you can use update_config function :

from configDmanager import update_config

# You can use a dict to update Config values
update_config({'param' : 'value'}, 'MyConfig')

# You can also use a callable that takes the config returns a dict
update_config(lambda conf: {'numeric': conf['numeric'] + 1}, 'MyConfig')

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

ConfigDmanager-0.2.0.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

ConfigDmanager-0.2.0-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file ConfigDmanager-0.2.0.tar.gz.

File metadata

  • Download URL: ConfigDmanager-0.2.0.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0.post20200210 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.6

File hashes

Hashes for ConfigDmanager-0.2.0.tar.gz
Algorithm Hash digest
SHA256 310fa89da0b18e551e91d9585e2bd82aa80f4bf8638fcbc39e2eaa54fcafcfed
MD5 aec38a2ca0866db726211eeb02495445
BLAKE2b-256 8fe50d2c7de8b1c4df84dd4fc4e60146dd251ac6378f0859852c92775b7d170f

See more details on using hashes here.

File details

Details for the file ConfigDmanager-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: ConfigDmanager-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0.post20200210 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.6

File hashes

Hashes for ConfigDmanager-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 310e44d75e7c13184ea3f3dbe825ad83ac991f311c2e72f8ee77a561d7bdbebc
MD5 6036f309382915cd4ae4c5995b8665c0
BLAKE2b-256 bcb8b3179b90461602780004d82f01ae5bb34b48e6d763270b9dee705bd06bfe

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