Organize your project settings and secrets with ease
Project description
Easily manage your application settings and secrets
Welcome to Stela
Stela were the "information files" of ancient times. This library helps you manage your project settings and secrets with ease, using a simple and consistent approach.
What is Stela?
Stela is a Python library that simplifies how you handle:
- Settings: Non-sensitive values that can be committed to your repository (API URLs, timeouts, etc.)
- Secrets: Sensitive values that should not be committed (passwords, tokens, etc.)
- Environment-specific configurations: Different values for development, testing, and production
TL;DR
- In a new project run
pip install stela - On terminal, run
stela init --default --no-confirm - Uncomment the
MY_SECRETline in.env - Add
from stela import envand runprint(env.MY_SECRET)in your code - Uncomment the
MY_SECRETline in.env.localand get the code again. - Add
export MY_SECRET=memory_valuein your terminal and get the code again.
New to multi-environment setups? Start with the Quick Setup guide: https://megalus.github.io/stela/quick_setup/
Install
pip install stela
Documentation
For detailed documentation, visit: https://megalus.github.io/stela/
Key Features
- Learn once, use everywhere - Works with any Python project or framework
- Separate settings from secrets - Use multiple dotenv files to organize your configuration
- Environment-specific settings - Easily switch between development, testing, and production environments
- Simple API - Access your settings with
from stela import env - Extensible - Not limited to dotenv files, can load settings from any source (AWS Parameter Store, Vault, etc.)
Quick Start Guide
Step 1: Initialize Your Project
Run the Stela initialization command to set up your project:
stela init --default
This creates four files:
.env- Store your default settings (will be committed to git).env.local- Store your secrets (will be ignored by git).stela- Stela configuration file- Updates
.gitignoreto exclude sensitive files
Step 2: Configure Your Settings and Secrets
Add your settings to .env:
# .env - This file WILL be committed to your repository
# Store default settings and fake credentials here
API_URL="http://localhost:8000"
DB_URL="db://fake_user:fake_password@local_db:0000/name"
Add your real secrets to .env.local:
# .env.local - This file will NOT be committed (ignored by git)
# Store real credentials and secrets here
DB_URL="db://real_user:real_password@real_db:0000/name"
Step 3: Access Your Settings in Code
Use the simple API to access your settings and secrets:
# my_script.py
from stela import env
# Access your settings with dot notation
API_URL = env.API_URL # http://localhost:8000
DATABASE_URL = env.DB_URL # db://real_user:real_password@real_db:0000/name
Stela automatically loads values from .env first, then overrides them with values from .env.local.
Precedence at a glance
When the same key is defined in multiple places, Stela resolves it using this order (top wins):
- Value already present in the process environment (os.environ). Stela will not overwrite existing env vars.
- .env.{environment}.local
- .env.{environment}
- .env.local
- .env
If a key is missing everywhere, Stela raises a StelaValueError by default (configurable).
Environment-Specific Configuration
Stela makes it easy to manage different environments (development, testing, production):
Step 1: Create Environment-Specific Files
Create a file for each environment:
# .env.development
API_URL="http://localhost:8000"
# .env.production
API_URL="https://api.example.com"
Step 2: Set the Environment
Set the STELA_ENV environment variable to specify which environment to use:
# For development
export STELA_ENV=development
# For production
export STELA_ENV=production
Step 3: Access Your Settings
Your code remains the same, but Stela will load the appropriate values:
from stela import env
# Will be "http://localhost:8000" when STELA_ENV=development
# Will be "https://api.example.com" when STELA_ENV=production
API_URL = env.API_URL
Advanced: Custom Data Sources
Stela isn't limited to dotenv files. You can load settings from any source:
Step 1: Configure a Final Loader
Add a final loader in your .stela configuration file:
# .stela
[stela]
final_loader = "path.to.my.final_loader"
Step 2: Create Your Loader Function
# my_loaders.py
from typing import Any
from stela.config import StelaOptions
def final_loader(options: StelaOptions, env_data: dict[str, Any]) -> dict[str, Any]:
"""Load settings from a custom source and merge into env_data.
Args:
options: Stela configuration options (includes current_environment).
env_data: Data already loaded from dotenv files.
Returns:
Updated data dictionary.
"""
# Example: pretend we fetched data from an external source
external = {"API_TIMEOUT": "5", "FEATURE_FLAG": "true"}
# Merge/override values
env_data.update(external)
return env_data
Step 3: Use Your Settings as Usual
from stela import env
# Values can come from dotenv files or your custom source
API_URL = env.API_URL
DB_PASSWORD = env.DB_PASSWORD
API_TIMEOUT = env.API_TIMEOUT # From custom loader
Need Help?
- Documentation: For detailed guides and examples, visit the documentation
- Issues: Found a bug? Have a question? Open an issue
- Contribute: Pull requests are welcome!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file stela-8.1.2.tar.gz.
File metadata
- Download URL: stela-8.1.2.tar.gz
- Upload date:
- Size: 17.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.12.1 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8a1afcb1c693128b7273fa3e2e63a198a6e98fda077521a487f1f3b101ec4479
|
|
| MD5 |
970f16b008174fafe4ff207f7a8f93c3
|
|
| BLAKE2b-256 |
5639820e925ed70d6c1f4ee358f6d291e6b30412114c00c1c60308b3996244dc
|
File details
Details for the file stela-8.1.2-py3-none-any.whl.
File metadata
- Download URL: stela-8.1.2-py3-none-any.whl
- Upload date:
- Size: 20.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.12.1 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
be0497507092e7ba533563e02455ce39917874e0af88f7bdfac3ee62c686138e
|
|
| MD5 |
62a5b1e063a1a3b4174bf8df90695d08
|
|
| BLAKE2b-256 |
0cb1e660829c0879e0c439c85c1ec4b286b6b4b20948afb979427ce5e3250833
|