Skip to main content

Configuration Enhanced & Easy ☕️ - A Hydra-like configuration parser helper package

Project description

Language: 한국어 | English

Hydra-style Configuration Management + Pydantic Type Safety + Typer-style Auto Help Generation

Python Version License: MIT Status


☕️ Overview

confee is a package that makes configuration management in Python applications simple, type-safe, and intuitive. It combines the best of Hydra and Pydantic, allowing you to manage configuration files, environment variables, and CLI arguments seamlessly.


✨ Key Features

  • 🎯 Type-Safe Configuration — Automatic type validation & IDE autocomplete with Pydantic V2
  • 📋 Multi-Format Support — Automatic detection and parsing of YAML and JSON
  • 🔄 Flexible Override System — Override values via CLI arguments and environment variables
  • 🏗️ Configuration Inheritance — Merge and combine parent-child configurations
  • 📁 File Reference — Load file contents with @file: & @config: prefixes
  • 🔐 Strict Mode — Reject unknown fields or control validation error handling
  • 📦 Zero Configuration — Ready to use with sensible defaults
  • ⚙️ Parse Order Control — Freely adjust priority of file/env/cli sources
  • 💬 Auto Help Generation — Display all options and defaults with --help flag
  • 🪆 Nested Field Access — Override nested fields with dot notation (database.host=localhost)
  • 🧾 Verbosity Control — Adjust output verbosity with --quiet/--verbose/--no-color flags

📦 Installation

pip install confee

Or with uv:

uv pip install confee

Or from source (development):

git clone https://github.com/bestend/confee.git
cd confee
pip install -e .

🚀 Quick Start

Basic Usage

from confee import ConfigBase

class AppConfig(ConfigBase):
    name: str
    debug: bool = False
    workers: int = 4

# Parse from all sources (file, environment, CLI)
config = AppConfig.load(config_file="config.yaml")

print(config.name)     # Type-safe access
print(config.debug)    # Full IDE support
print(config.workers)  # Auto-completion enabled

YAML Configuration File

name: production-app
debug: false
workers: 8

Command Line Override

python app.py name=my-app debug=true workers=16

Environment Variables

export CONFEE_NAME=my-app
export CONFEE_DEBUG=true
export CONFEE_WORKERS=16

python app.py

Help Display

python app.py --help

🎯 Advanced Features

Nested Configuration

from confee import ConfigBase

class DatabaseConfig(ConfigBase):
    host: str = "localhost"
    port: int = 5432

class AppConfig(ConfigBase):
    name: str
    database: DatabaseConfig

# Override nested fields from CLI
# python app.py database.host=prod.db database.port=3306
config = AppConfig.load()
print(config.database.host)  # "prod.db"

File References

# config.yaml
name: my-app
api_key: "@file:secrets/api_key.txt"
database_config: "@config:configs/database.yaml"

Custom Environment Prefix

# Use custom prefix instead of CONFEE_
# MYAPP_DEBUG=true instead of CONFEE_DEBUG=true
config = AppConfig.load(env_prefix="MYAPP_")

Custom Source Order

# Control which sources override others
config = AppConfig.load(
    config_file="config.yaml",
    source_order=["cli", "env", "file"]  # CLI highest priority
)

Strict/Non-Strict Modes

# Strict mode (default): Forbid unknown fields
class Config(ConfigBase):
    name: str

# Non-strict mode: Ignore unknown fields
config = Config.load(strict=False)

📚 Documentation


🎯 Use Cases

Environment-specific Configuration

# dev.yaml
debug: true
workers: 2

# prod.yaml
debug: false
workers: 32

# Load appropriate config
import os
env = os.getenv("APP_ENV", "dev")
config = AppConfig.load(config_file=f"{env}.yaml")

Kubernetes Environment Variables

# pod.yaml
containers:
  - env:
    - name: CONFEE_DEBUG
      value: "false"
    - name: CONFEE_WORKERS
      value: "16"

Configuration Validation

from pydantic import Field

class AppConfig(ConfigBase):
    workers: int = Field(ge=1, le=128)  # Validate range
    timeout: float = Field(gt=0)         # Must be positive

🔄 Integration Examples

With FastAPI

from fastapi import FastAPI
from confee import ConfigBase

class AppConfig(ConfigBase):
    title: str = "My API"
    debug: bool = False

config = AppConfig.load()
app = FastAPI(title=config.title, debug=config.debug)

With Click

import click
from confee import ConfigBase

class AppConfig(ConfigBase):
    name: str

config = AppConfig.load()

@click.command()
def main():
    click.echo(f"Hello {config.name}")

✅ Testing Your Configuration

def test_config_loading():
    config = AppConfig.load(
        config_file="tests/fixtures/config.yaml",
        cli_args=["debug=true"],
        strict=True
    )
    assert config.debug is True

🤝 Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Write tests for your changes
  4. Submit a pull request

📜 License

MIT License © 2025

See LICENSE for details.


💬 Support

For issues and questions:


Enjoy ☕️ configuration management!


Language: 한국어 | English

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

confee-0.1.3.tar.gz (729.4 kB view details)

Uploaded Source

Built Distribution

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

confee-0.1.3-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

Details for the file confee-0.1.3.tar.gz.

File metadata

  • Download URL: confee-0.1.3.tar.gz
  • Upload date:
  • Size: 729.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for confee-0.1.3.tar.gz
Algorithm Hash digest
SHA256 9cef1d504f4bd20f0b7f58bbb43adf1d6436dd044e7848ab97a9bbbec963d997
MD5 680ca17cceb36c23b93808ff4e12afe3
BLAKE2b-256 97a335fbf7183bb24e54519357a8f7508931053aa5e54d4ebdaadf7c66f898ea

See more details on using hashes here.

File details

Details for the file confee-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: confee-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 18.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for confee-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4e030fa90590e49970435d1518f9bb7d320273ca78d5e4796b540787f356114a
MD5 4d1e865d08510dea65627403d0ec8796
BLAKE2b-256 331b80df0e213abf1b39b064a7b8e4a9432d8e3d255bc9064e149dc02c3b7378

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