Skip to main content

envbee SDK for Python

Project description

envbee Python SDK

envbee SDK is a Python client for interacting with the envbee API (see https://envbee.dev). This SDK provides methods to retrieve variables, manage caching for improved performance, and populate environment variables directly from envbee.

Table of Contents

Installation

To install the envbee SDK, use pip:

pip install envbee-sdk

The SDK is tested with:

  • Python 3.10
  • Python 3.11
  • Python 3.12
  • Python 3.13
  • Python 3.14

Usage

Instantiate the Envbee class with your API credentials (either as parameters or via environment variables):

from envbee_sdk import Envbee

client = Envbee(
    api_key="your_api_key",
    api_secret=b"your_api_secret",
    enc_key=b"32-byte-encryption-key-goes-here",  # optional, could be a string or a 32 bytes buffer
    cache_path="/tmp/envbee-cache",  # optional custom cache path
    timeout_seconds=4  # optional request timeout in seconds (default 4)
)

# Retrieve a variable
value = client.get("VariableName")

# Retrieve multiple variables definitions
variables, metadata = client.get_variables()

You can also retrieve variables along with their values:

variables, metadata = client.get_variables_values()

Or automatically populate OS environment variables:

client.fill_env_vars()

This will fetch all variables and set them in the current process as environment variables.

You can also restrict which variables should be exported:

client.fill_env_vars(["DATABASE_URL", "REDIS_URL"])

Environment Variables

Instead of passing credentials and configuration parameters directly when instantiating the Envbee client, you can optionally use environment variables:

  • ENVBEE_API_KEY: your API key (required if api_key is not passed explicitly)
  • ENVBEE_API_SECRET: your API secret (required if api_secret is not passed explicitly)
  • ENVBEE_ENC_KEY: optional encryption key for decrypting encrypted variables

Example using environment variables:

export ENVBEE_API_KEY="your_api_key"
export ENVBEE_API_SECRET="your_api_secret"
export ENVBEE_ENC_KEY="32-byte-encryption-key-goes-here"

Then initialize the client with no parameters:

from envbee_sdk import Envbee

client = Envbee()

value = client.get("VariableName")

Explicit parameters take precedence over environment variables if both are provided.

Methods

get

get(variable_name: str) -> Any

Fetch a variable value by name.
If the API request fails, the SDK attempts to retrieve the value from the local cache.

get_variables

get_variables(offset: int | None = None, limit: int | None = None) -> tuple[list[Variable], Metadata]

Fetch variable definitions from the API.

Supports pagination using offset and limit.

get_variables_values

get_variables_values(offset: int | None = None, limit: int | None = None) -> tuple[list[VariableValue], Metadata]

Fetch variables along with their stored values.

Supports pagination.

fill_env_vars

fill_env_vars(variable_names: list[str] | None = None) -> None

Fetch variables and set them as environment variables in the current process.

Behavior:

  • If variable_names is None, all variables are exported.
  • If variable_names is provided, only those variables are exported.
  • Encrypted values are automatically decrypted before being set.
  • If the API is unavailable, the SDK attempts to load values from the local cache.

Environment variables are always stored as strings.

Data Models

The SDK returns typed dataclasses defined in:

envbee_sdk.model

These include:

  • Variable
  • VariableValue
  • Metadata
  • VariableType

Refer to the source file for the canonical definitions:

envbee_sdk/model.py

Encryption

Some variables stored in envbee are encrypted using AES-256-GCM (via the cryptography library). Encrypted values are prefixed with envbee:enc:v1:.

Behavior:

  • If an encrypted variable is fetched and you provide a correct decryption key (enc_key), the SDK decrypts it automatically.
  • If no key or an incorrect key is provided, a RuntimeError will be raised during decryption.
  • The encryption key is never sent to the API; all decryption is performed locally.
  • Cached values are stored exactly as received from the API (encrypted or plain-text).

Example with encryption key:

client = Envbee(
    api_key="your_api_key",
    api_secret=b"your_api_secret",
    enc_key=b"32-byte-encryption-key-goes-here"
)

Logging

Configure logging as needed. The SDK logger name is envbee_sdk. Example:

import logging

logging.basicConfig(level=logging.ERROR)

sdk_logger = logging.getLogger("envbee_sdk")
sdk_logger.setLevel(logging.DEBUG)  # for detailed logs

Caching

The SDK caches variables locally to provide fallback data when:

  • The API is unreachable
  • The client is offline

The cache is updated after each successful API call.

Properties:

  • Cached values are stored exactly as returned by the API.
  • Encryption keys are never stored in cache.
  • Decryption always happens locally.
  • If disk cache is unavailable (permission/path issues), the SDK logs a warning and falls back to in-memory cache for the current process.

API Documentation

For more information on envbee API endpoints and usage, visit the official API documentation.

License

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

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

envbee_sdk-1.9.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

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

envbee_sdk-1.9.0-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

Details for the file envbee_sdk-1.9.0.tar.gz.

File metadata

  • Download URL: envbee_sdk-1.9.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for envbee_sdk-1.9.0.tar.gz
Algorithm Hash digest
SHA256 2451900ae246139d39e2897101da56143b691b3cd9768ad579177d1f00eb846c
MD5 0565502fcb54d9628b478c15d0f3f1eb
BLAKE2b-256 4d33bfd8c850c2df645945bddb17ebe5b57a52a92b6972a1be2108d927286bcd

See more details on using hashes here.

File details

Details for the file envbee_sdk-1.9.0-py3-none-any.whl.

File metadata

  • Download URL: envbee_sdk-1.9.0-py3-none-any.whl
  • Upload date:
  • Size: 12.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for envbee_sdk-1.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 88c0755136c01fa945c7ea4aa61710712cfa09b3aa7ab8cb7dad2890a04fad94
MD5 2a8e86f36177f44b64cfdc123ec75122
BLAKE2b-256 06d17d90bcecba5feda0f94949d0fbec754f86502b44fcae446daa692ab6647e

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