Skip to main content

A tool to build YAML configurations by merging multiple files

Project description

pydantic-config-builder

A tool to build YAML configurations by merging multiple files.

Features

  • Merge multiple YAML files into a single configuration file
  • Support for base configuration files with overlay files
  • Recursive merging of dictionaries and arrays
  • Use built configurations as base for other configurations
  • Configuration file based build management
  • Command line interface tool
  • Support for relative and absolute paths
  • Home directory expansion with ~

Installation

pip install pydantic-config-builder

Usage

Create a configuration file named pydantic_config_builder.yml in your project directory:

# New format (recommended)
development:
  input:
    - base/*.yaml              # All YAML files in base directory
    - path/to/base.yaml        # Specific file
  output:
    - default.yaml             # Local output
    - ~/.config/app.yaml       # Global config
    - build/dev.yaml           # Build output

production:
  input:
    - default.yaml             # Use output of another configuration
    - configs/**/*.yaml        # All YAML files in configs and subdirectories
    - /path/to/overlay-*.yaml  # All overlay files in specific directory
  output:
    - prod.yaml
    - /etc/app/config.yaml

# Legacy format (still supported)
default.yaml:
  - base/*.yaml
  - path/to/base.yaml

Then run the builder:

# Use default configuration file (pydantic_config_builder.yml)
pydantic_config_builder

# Or specify a configuration file
pydantic_config_builder -c path/to/config.yml

# Enable verbose output
pydantic_config_builder -v

Path Resolution

  • Absolute paths (starting with /) are used as is
  • Paths starting with ~ are expanded to the user's home directory
  • Relative paths are resolved relative to the configuration file's directory
  • Glob patterns (*, ?, []) are supported for source files
    • *.yaml matches all YAML files in the current directory
    • **/*.yaml matches all YAML files recursively in subdirectories
    • If a pattern matches no files, a warning is printed and the pattern is skipped

Merging Behavior

  • Dictionaries are merged recursively, with later files overwriting earlier ones
  • Arrays are replaced entirely (not appended or merged by index)

Example

Given these files:

base.yaml:

database:
  host: localhost
  port: 5432
  credentials:
    username: admin
logging:
  level: info

overlay.yaml:

database:
  port: 5433
  credentials:
    password: secret
logging:
  format: json

And this configuration:

# pydantic_config_builder.yml
config.yaml:
  - base.yaml
  - overlay.yaml

The resulting config.yaml will be:

database:
  host: localhost
  port: 5433
  credentials:
    username: admin
    password: secret
logging:
  level: info
  format: json

Documentation

For more detailed documentation, please see the GitHub repository.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page