Python SDK for the Bella Baxter secret management platform
Project description
bella-baxter
Python SDK for the Bella Baxter secrets management platform. Includes built-in end-to-end encryption and webhook signature verification.
When to use bella-baxter directly
Most applications should use a framework integration instead:
| Framework | Package |
|---|---|
| Django | bella-baxter-django |
| FastAPI | bella-baxter-fastapi |
| Flask | bella-baxter-flask |
| Scripts, tools, custom integrations | bella-baxter (this package) |
Installation
pip install bella-baxter
Quickstart
from bella_baxter import BaxterClient, BaxterClientOptions
client = BaxterClient(BaxterClientOptions(
baxter_url="https://api.bella-baxter.io",
api_key="bax-...",
))
# Fetch all secrets (sync — works in Django, Flask, scripts)
secrets = client.get_all_secrets()
db_url = secrets.secrets["DATABASE_URL"]
# Async (FastAPI, asyncio)
secrets = await client.get_all_secrets_async()
Authentication
API key (recommended for apps and CI/CD)
# Generate a key via the CLI
bella api-keys create --env production --name "MyApp Production"
# Returns: bax-<keyId>-<secret>
import os
from bella_baxter import BaxterClient, BaxterClientOptions
client = BaxterClient(BaxterClientOptions(
baxter_url=os.environ["BELLA_BAXTER_URL"],
api_key=os.environ["BELLA_BAXTER_API_KEY"],
))
API keys encode the project and environment slug — no config file needed.
Generate via bella api-keys create or the Bella WebApp.
OAuth (local dev)
bella login # opens browser, stores token in .bella file
bella exec -- python app.py # injects BELLA_BAXTER_API_KEY + BELLA_BAXTER_URL automatically
End-to-end encryption
Secret values are encrypted client-side using ECIES (Elliptic Curve Integrated Encryption Scheme) before being sent to the Baxter API. Decryption happens transparently in the SDK.
E2EE is included — no extra install needed (cryptography>=41 is a core dependency).
Lightweight version polling
For long-running processes that need to detect secret rotations:
# Check if secrets have changed without fetching values
version = client.get_secrets_version()
if version.version != last_known_version:
secrets = client.get_all_secrets()
last_known_version = version.version
Webhook signature verification
from bella_baxter import verify_webhook_signature
is_valid = verify_webhook_signature(
payload=request.body,
signature_header=request.headers["X-Bella-Signature"],
secret="whsec-...",
)
Full API access (Kiota client)
# Access the underlying Kiota client for full API coverage
kiota = client.client
# List projects
projects = await kiota.api.v1.projects.get()
# Manage environments, providers, users, API keys, etc.
Regenerating the generated client
bella-baxter embeds a Kiota-generated HTTP client. To regenerate after an API change:
cd apps/sdk
./generate.sh
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 bella_baxter-0.1.1rc41.tar.gz.
File metadata
- Download URL: bella_baxter-0.1.1rc41.tar.gz
- Upload date:
- Size: 117.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
89507486dda3a6849ea5448c9785778f52773dcd501b054af15cdfcd5de9fe6d
|
|
| MD5 |
d678ff8a2b5c9c3e25e292b4c9320dc0
|
|
| BLAKE2b-256 |
693f31faafe99d1c342db8116845cef5ff9210cb6570c416a15870cb4d6bcada
|
Provenance
The following attestation bundles were made for bella_baxter-0.1.1rc41.tar.gz:
Publisher:
publish.yml on Cosmic-Chimps/bella-baxter-python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bella_baxter-0.1.1rc41.tar.gz -
Subject digest:
89507486dda3a6849ea5448c9785778f52773dcd501b054af15cdfcd5de9fe6d - Sigstore transparency entry: 1249830316
- Sigstore integration time:
-
Permalink:
Cosmic-Chimps/bella-baxter-python@813d71c1ceae8c9795e0cf8fee5cb71d224cd1eb -
Branch / Tag:
refs/tags/v0.1.1-preview.41 - Owner: https://github.com/Cosmic-Chimps
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@813d71c1ceae8c9795e0cf8fee5cb71d224cd1eb -
Trigger Event:
push
-
Statement type:
File details
Details for the file bella_baxter-0.1.1rc41-py3-none-any.whl.
File metadata
- Download URL: bella_baxter-0.1.1rc41-py3-none-any.whl
- Upload date:
- Size: 551.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4197d8f2d4c4a39a19ad05dfa622c6ce3605d69a5d0b0f98f24b46bd4cd3b416
|
|
| MD5 |
b4af871639bf16fda06bb02f8da6b5cd
|
|
| BLAKE2b-256 |
9d9b74d6212260b7666991aae3ebfd65f77e25b9ef43fb511237de0d05ad6624
|
Provenance
The following attestation bundles were made for bella_baxter-0.1.1rc41-py3-none-any.whl:
Publisher:
publish.yml on Cosmic-Chimps/bella-baxter-python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bella_baxter-0.1.1rc41-py3-none-any.whl -
Subject digest:
4197d8f2d4c4a39a19ad05dfa622c6ce3605d69a5d0b0f98f24b46bd4cd3b416 - Sigstore transparency entry: 1249830319
- Sigstore integration time:
-
Permalink:
Cosmic-Chimps/bella-baxter-python@813d71c1ceae8c9795e0cf8fee5cb71d224cd1eb -
Branch / Tag:
refs/tags/v0.1.1-preview.41 - Owner: https://github.com/Cosmic-Chimps
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@813d71c1ceae8c9795e0cf8fee5cb71d224cd1eb -
Trigger Event:
push
-
Statement type: