Skip to main content

A unified YAML configuration manager supporting local files and dynamic Nacos configuration with hot-reloading, environment variable substitution, and built-in encryption (SM2/SM4) support.

Project description

YAML Configuration Management: Local Files + Nacos Dynamic Configuration

This project provides a unified YAML configuration loading solution, supporting configuration retrieval from both local files and the Nacos configuration center. It also supports hot updates, variable substitution, decryption of encrypted values, and other advanced features.

Install the base dependency:

pip install yamlpyconfig

Enable Nacos support:

pip install yamlpyconfig[nacos]

1. Local YAML Configuration Loading

In the specified configuration directory (config_dir, e.g., /config), the following files must exist:

  • application.yaml (required)
  • application-{profile}.yaml (optional)

1.1 Profile Resolution and Loading Order

When initializing ConfigManager, the effective profile is determined using the following priority (highest → lowest):

  1. base_profile explicitly passed to the ConfigManager constructor
  2. Environment variable APP_PROFILE
  3. Environment variable SPRING_PROFILES_ACTIVE
  4. The profile field inside application.yaml
  5. If none of the above is provided → no application-{profile}.yaml will be loaded

1.1.1 Notes

  • application.yaml must exist; otherwise an exception is raised.
  • If a profile is determined but the corresponding application-{profile}.yaml is not found, an exception is thrown.

1.2 Extended Configuration: extend-profiles

Extended configurations come from two sources, and both are loaded (merged):

  1. The extend-profiles field inside application.yaml or application-{profile}.yaml
  2. The extend_profiles parameter passed to the ConfigManager constructor

Both sources are comma-separated strings, where each entry represents one extension item.

Each extension item supports two forms.


1.2.1 Two Extension Item Formats

Type Example Loading Behavior
Explicit file file:/full/path/to/xxx.yaml Loads the file at the given path; missing file → error
Extension profile dev-ext Loads config_dir/application-dev-ext.yaml

1.2.2 Priority Rules

  • Constructor-passed extend_profiles has higher priority than extend-profiles in YAML
  • Within the same source, items appearing later have higher priority
  • All extension configurations override values from application.yaml and application-{profile}.yaml

1.3 Overall Priority of Local Configurations (Low → High)

  1. application.yaml
  2. application-{profile}.yaml
  3. extend-profiles (including both explicit file items and extension profile items)

2. Nacos Configuration Loading

To enable Nacos, define the config-sources.nacos section in application.yaml:

config-sources:
  nacos:
    server-addr: "192.168.30.36:9090"
    namespace: "dev"
    group: "DEFAULT_GROUP"
    username: "nacos"
    password: "{encrypted}VuFvNZOg/q7ZQoIUGWydBw=="
    imports:
      - data-id: "gateway.yaml"
      - data-id: "application-ext.yaml"

2.1 Nacos Configuration Merge Order (Low → High)

  1. Final merged result of all local configurations
  2. Nacos imports in declared order (later items have higher priority)

3. Key Features and Usage Examples


3.1 Basic Usage

The following example demonstrates how configurations are loaded automatically and updated in real time:

@pytest.mark.asyncio
async def test_config_manager_with_nacos(self):
    async with ConfigManager("./") as config_manager:
        logger.info(config_manager.get_config())
        while True:
            await asyncio.sleep(5)
            logger.info(config_manager.get_config())
    # Specify base_profile and extend_profiles
    async with ConfigManager("./", 
                             base_profile="dev", 
                             extend_profiles="file:./demo.yaml,dev-ext") as config_manager:
        logger.info(config_manager.get_config())
        while True:
            await asyncio.sleep(5)
            logger.info(config_manager.get_config())

Once inside the async with block:

  • Local configuration is loaded
  • If config-sources.nacos exists → connects to Nacos and enables hot updates

3.2 Environment Variable Placeholder Support

Local YAML files support Spring-style placeholders:

key-with-default: ${KEY1:DEFAULT_VALUE}
key: ${KEY2}

Behavior:

  • If the environment variable exists → use its value
  • If not, and a default is provided → use the default
  • If no default is provided → returns None

3.3 Encrypted Field Support (SM2 / SM4)

Sensitive fields (passwords, keys, etc.) can be declared with the {encrypted} prefix:

password: "{encrypted}VuFvNZOg/q7ZQoIUGWydBw=="

To enable automatic decryption, specify the algorithm and key when initializing ConfigManager:

@pytest.mark.asyncio
async def test_config_manager_with_nacos_decrypt(self):

    # Example using SM4 (symmetric key encryption)
    async with ConfigManager(
        "./",
        crypto_algorithm=AlgorithmEnum.SM4,
        key="lSU543Tes6wmjnb+PMVQNg=="
    ) as config_manager:

        logger.info(config_manager.get_config())

Notes:

  • SM4 → Symmetric encryption (a shared key is required)
  • SM2 → Asymmetric encryption (a private key must be provided)

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

yamlpyconfig-0.1.7.tar.gz (15.5 kB view details)

Uploaded Source

Built Distribution

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

yamlpyconfig-0.1.7-py3-none-any.whl (23.3 kB view details)

Uploaded Python 3

File details

Details for the file yamlpyconfig-0.1.7.tar.gz.

File metadata

  • Download URL: yamlpyconfig-0.1.7.tar.gz
  • Upload date:
  • Size: 15.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.8

File hashes

Hashes for yamlpyconfig-0.1.7.tar.gz
Algorithm Hash digest
SHA256 b6804a993aa19018d4b88e091491d035f8819233cc16f721b6b1fdf79330a5ff
MD5 ebc3f55efa97a94bc1c8f1b96a9e4f0a
BLAKE2b-256 bd6dd212a649d27d05e5a01f5037693ab250c2fef8fdb7e0525abb7911757398

See more details on using hashes here.

File details

Details for the file yamlpyconfig-0.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for yamlpyconfig-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 a504e226a157f1d7b2b56ef6d128cda0de33c22b6dc1bceef010954525578f50
MD5 e9cb4c6eb5694a8ef3e03d5ee0ed8661
BLAKE2b-256 f6ae4ee79005b2aae4b90f96667a10f7d6b2443cf91f172e1b86250d83158ea0

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