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.9.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.9-py3-none-any.whl (23.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: yamlpyconfig-0.1.9.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.9.tar.gz
Algorithm Hash digest
SHA256 3bab05fbf7369cc677081bb016265de159127f35edcc083a118e78acedf93791
MD5 293663787141941683b0188854f0a0a0
BLAKE2b-256 f8850c4165eb4ca7e717425a60b221045c3dcba7f767a3e3719fce37d781612a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yamlpyconfig-0.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 445d035041d77fd486755afa55cc30b09c1228edb0ef3cae25f1a0c6c9de493c
MD5 7fbdb61bf9968bdf91115ae1507c25ff
BLAKE2b-256 0a688696aeed1734d7575cda94d0ba2babb0aed144014880639477fc857a19f7

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