Python SDK for Featureflip - a feature flag SaaS platform
Project description
Featureflip Python SDK
Python SDK for Featureflip - evaluate feature flags locally with near-zero latency.
Installation
pip install featureflip
Quick Start
from featureflip import FeatureflipClient
# Initialize the client (blocks until flags are loaded)
client = FeatureflipClient(sdk_key="your-sdk-key")
# Evaluate a feature flag
enabled = client.variation("my-feature", {"user_id": "user-123"}, default=False)
if enabled:
print("Feature is enabled!")
else:
print("Feature is disabled")
# Clean shutdown
client.close()
Configuration
from featureflip import FeatureflipClient, Config
client = FeatureflipClient(
sdk_key="your-sdk-key",
config=Config(
base_url="https://eval.featureflip.io", # Evaluation API URL
streaming=True, # Use SSE for real-time updates (default)
poll_interval=30.0, # Polling interval if streaming=False
send_events=True, # Enable analytics event tracking
flush_interval=30.0, # Event flush interval in seconds
init_timeout=10.0, # Max seconds to wait for initialization
)
)
The SDK key can also be set via the FEATUREFLIP_SDK_KEY environment variable.
Context Manager
with FeatureflipClient(sdk_key="your-sdk-key") as client:
enabled = client.variation("my-feature", {"user_id": "123"}, default=False)
# Automatically closes and flushes events on exit
Evaluation
# Boolean flag
enabled = client.variation("feature-key", {"user_id": "123"}, default=False)
# String flag
tier = client.variation("pricing-tier", {"user_id": "123"}, default="free")
# Number flag
limit = client.variation("rate-limit", {"user_id": "123"}, default=100)
# JSON flag
config = client.variation("ui-config", {"user_id": "123"}, default={"theme": "light"})
Detailed Evaluation
detail = client.variation_detail("feature-key", {"user_id": "123"}, default=False)
print(detail.value) # The evaluated value
print(detail.reason) # "RULE_MATCH", "FALLTHROUGH", "FLAG_DISABLED", etc.
print(detail.rule_id) # Rule ID if reason is RULE_MATCH
Event Tracking
# Track custom events
client.track("checkout-completed", {"user_id": "123"}, metadata={"total": 99.99})
# Identify users for segment building
client.identify({"user_id": "123", "email": "user@example.com", "plan": "pro"})
# Force flush pending events
client.flush()
Testing
Use the test client for deterministic unit tests:
from featureflip import FeatureflipClient
# Create a test client with fixed values (no network calls)
client = FeatureflipClient.for_testing({
"my-feature": True,
"pricing-tier": "pro",
})
# Evaluations return the configured values
assert client.variation("my-feature", {}, default=False) is True
assert client.variation("pricing-tier", {}, default="free") == "pro"
# Unknown flags return the default
assert client.variation("unknown", {}, default="fallback") == "fallback"
# Update values at runtime
client.set_test_value("my-feature", False)
Features
- Client-side evaluation - Near-zero latency after initialization
- Real-time updates - SSE streaming with polling fallback
- Event tracking - Automatic batching and flushing of analytics events
- Test support -
for_testing()factory for deterministic unit tests - Type-safe - Full type hints with mypy strict mode compliance
Requirements
- Python 3.10+
Development
# Install development dependencies
pip install -e ".[dev]"
# Run tests
pytest
# Run linting
ruff check src/featureflip tests
# Run type checking
mypy src/featureflip --strict
License
MIT
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
featureflip-0.1.0.tar.gz
(34.8 kB
view details)
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 featureflip-0.1.0.tar.gz.
File metadata
- Download URL: featureflip-0.1.0.tar.gz
- Upload date:
- Size: 34.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
05e4c1a4eade0ded69b62f8e67b459ffac6822adf80512b130beb72b8b44d2e4
|
|
| MD5 |
f2600efce410264caa8193f6fc8d2df4
|
|
| BLAKE2b-256 |
29be91dfb6c0e83ceeec25b8ba7ebc28ae1f3fd13f6500b3e22aee6e3cd54efa
|
File details
Details for the file featureflip-0.1.0-py3-none-any.whl.
File metadata
- Download URL: featureflip-0.1.0-py3-none-any.whl
- Upload date:
- Size: 22.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
20729f51ebe230484b6581564d8a83955c1d9e7aacf7f9eeb8c6883784c7a2a0
|
|
| MD5 |
0735065413b08839464c77fbf4423cfc
|
|
| BLAKE2b-256 |
705713d824cc027d9f3dcd3868f95223baaaf188c35bf85001b70789a2d7b6f4
|