Skip to main content

Super config for python

Project description

SuperConf

SuperConf Logo

Github Repo Github Page Github Releases

PyPI - Python Version PyPI - Format PyPI - Status

Gitter PyPI PyPI - Downloads piwheels (including prereleases) GitHub commit activity License: GPL v3


This project is in Beta.

A powerful and flexible configuration management library for Python. SuperConf provides a clean, type-safe, and intuitive way to handle configuration from multiple sources including environment variables, configuration files, and dictionaries.

Inspired from Cafram, forked from ClassyConf.

Features

  • 🔒 Type-safe configuration with built-in validation
  • 🔄 Multiple configuration sources (environment variables, files, dictionaries)
  • 📦 Nested configuration support
  • 🎯 Default values and custom casting
  • 🚀 Easy to use and extend
  • 🔍 Strict type checking mode
  • 📝 Comprehensive field types (Boolean, Integer, String, List, Dict, etc.)
  • 🎨 Support for custom field types

Quickstart

Installation

Install using pip:

pip install superconf

Or install from source:

git clone https://github.com/mrjk/python-superconf.git
cd python-superconf
pip install -e .

Basic Usage

Here's a simple example of how to use SuperConf:

from superconf.configuration import Configuration
from superconf.fields import FieldString, FieldInt, FieldBool, FieldList

class AppConfig(Configuration):

    class Meta:
        loaders = [Environment()]  # Load from environment variables
    
    debug = FieldBool(default=False, help="Enable debug mode")
    port = FieldInt(default=8080, help="Server port")
    app_name = FieldString(default="myapp", help="Application name")
    plugins = FieldList(default=[], help="Enabled plugins")

# Create and use the configuration
config = AppConfig()
print(config.debug)  # False
print(config.port)   # 8080

# Use environment variables to override defaults
# export APP_PORT=9000
# export APP_DEBUG=true

Overview

Requirements

  • Python 3.9 or higher
  • Dependencies:
    • pyaml >= 24.12.1

FAQ

Q: How is SuperConf different from other configuration libraries?
A: SuperConf combines the best features of existing libraries with strong type safety, nested configurations, and a clean API.

Q: Can I use multiple configuration sources?
A: Yes, SuperConf supports multiple loaders that can be prioritized in order.

Q: Is it possible to extend SuperConf with custom field types?
A: Yes, you can create custom field types by extending the Field class.

Known Issues

  • String parsing for dictionary fields is not implemented yet
  • Cache settings need refinement
  • Some features are marked as WIP (Work in Progress)

Development

Setup Development Environment

  1. Clone the repository:
git clone https://github.com/mrjk/python-superconf.git
cd python-superconf
  1. Install development dependencies:
poetry install

Development Commands

SuperConf uses Taskfile for development tasks:

  • Run tests: task test
  • Run linting: task test_lint
  • Fix linting issues: task fix_lint
  • Generate documentation: task gen_doc_class_graph

Running Tests

task test        # Run all tests
task test_pytest # Run pytest suite
task test_recap  # View test coverage report

Project Information

License

This project is licensed under the GPLv3 License.

Author

Support

For support, please:

  1. Check the documentation
  2. Open an issue on GitHub

Related Projects

Roadmap

  • Implement string parsing for dictionary fields
  • Improve caching mechanism
  • Add more configuration sources
  • Create comprehensive documentation site
  • Add more examples and use cases
  • Implement configuration validation hooks

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

superconf-0.1.4.tar.gz (43.9 kB view details)

Uploaded Source

Built Distribution

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

superconf-0.1.4-py3-none-any.whl (46.8 kB view details)

Uploaded Python 3

File details

Details for the file superconf-0.1.4.tar.gz.

File metadata

  • Download URL: superconf-0.1.4.tar.gz
  • Upload date:
  • Size: 43.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.10.11 Linux/6.6.65-1-MANJARO

File hashes

Hashes for superconf-0.1.4.tar.gz
Algorithm Hash digest
SHA256 a7d46df66b187182c425223e0872f290117db4dd9f0bd6a481d8629d7ca9cf6c
MD5 eb08efb1f9df22b0b2c50b8ed5add0d0
BLAKE2b-256 561775aac0071b36d27ae00ac41bbd8a0cdc0d4aead680a51db40b986738b209

See more details on using hashes here.

File details

Details for the file superconf-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: superconf-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 46.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.10.11 Linux/6.6.65-1-MANJARO

File hashes

Hashes for superconf-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e9c9e4bee44be54023caa7b4099f59e1ff0293650b9d09893f62d05646a33837
MD5 9164f367c1091f38c38f9b4b97181da6
BLAKE2b-256 4ebc44f8dc26a7ff1df264f4d1085ff4ae52cd8ca78051f0aaa00e4abebdacf4

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