Unleash / Unleash Client Python
Licence: mit
Unleash client for Python π‘π‘π‘
Stars: β 44
Programming Languages
python
139335 projects - #7 most used programming language
Projects that are alternatives of or similar to Unleash Client Python
ruby-server-sdk
LaunchDarkly Server-side SDK for Ruby
Stars: β 25 (-43.18%)
Mutual labels: feature-flags, feature-toggles
python-client
Python SDK client for Split Software
Stars: β 12 (-72.73%)
Mutual labels: feature-flags, feature-toggles
toggler
toggler is a feature flag service to decouple deployment, feature enrollment and experiments
Stars: β 27 (-38.64%)
Mutual labels: feature-flags, feature-toggles
Javascript Client
NodeJS and Browser SDK client for Split Software
Stars: β 30 (-31.82%)
Mutual labels: feature-flags, feature-toggles
Flopflip
πFlip or flop features in your React application in real-time backed by flag provider of your choice π¦
Stars: β 334 (+659.09%)
Mutual labels: feature-flags, feature-toggles
featurehub
FeatureHub - cloud native feature flags, A/B testing and remote configuration service. Real-time streaming feature updates. Provided with Java, JavaScript, Go, .Net, Android and Flutter SDKs.
Stars: β 136 (+209.09%)
Mutual labels: feature-flags, feature-toggles
ios-client-sdk
LaunchDarkly Client-side SDK for iOS (Swift and Obj-C)
Stars: β 45 (+2.27%)
Mutual labels: feature-flags, feature-toggles
CloudKitFeatureFlags
A library that lets you setup feature flagging for your iOS app using CloudKit
Stars: β 91 (+106.82%)
Mutual labels: feature-flags, feature-toggles
Unleash
Unleash is the open source feature toggle service.
Stars: β 4,679 (+10534.09%)
Mutual labels: feature-flags, feature-toggles
Flags
β³οΈ Feature Flags for Next.js
Stars: β 277 (+529.55%)
Mutual labels: feature-flags, feature-toggles
erlang-server-sdk
LaunchDarkly Server-Side SDK for Erlang/Elixir
Stars: β 16 (-63.64%)
Mutual labels: feature-flags, feature-toggles
Featuretoggle
Simple, reliable feature toggles in .NET
Stars: β 641 (+1356.82%)
Mutual labels: feature-flags, feature-toggles
feature-flag-android
A Gradle plugin to achieve feature flag based development for Android applications.
Stars: β 82 (+86.36%)
Mutual labels: feature-flags, feature-toggles
jest-launchdarkly-mock
Easily unit test LaunchDarkly feature flagged components with jest
Stars: β 14 (-68.18%)
Mutual labels: feature-flags, feature-toggles
flagsmith-js-client
Javascript Client for Flagsmith. Ship features with confidence using feature flags and remote config. Host yourself or use our hosted version at https://www.flagsmith.com/
Stars: β 42 (-4.55%)
Mutual labels: feature-flags, feature-toggles
react-client-sdk
LaunchDarkly Client-side SDK for React.js
Stars: β 42 (-4.55%)
Mutual labels: feature-flags, feature-toggles
unleash-client-java
Unleash client SDK for Java
Stars: β 86 (+95.45%)
Mutual labels: feature-flags, feature-toggles
PowerShell-FeatureFlags
PowerShell module containing a Feature Flags implementation based on a local config file.
Stars: β 15 (-65.91%)
Mutual labels: feature-flags, feature-toggles
Tweek
Tweek - an open source feature manager
Stars: β 268 (+509.09%)
Mutual labels: feature-flags, feature-toggles
Feature Flags
Feature flags API written in Go
Stars: β 375 (+752.27%)
Mutual labels: feature-flags, feature-toggles
unleash-client-python
This is the Python client for Unleash. It implements Client Specifications 1.0 and checks compliance based on spec in unleash/client-specifications
What it supports:
- Default activation strategies using 32-bit Murmerhash3
- Custom strategies
- Full client lifecycle:
- Client registers with Unleash server
- Client periodically fetches feature toggles and stores to on-disk cache
- Client periodically sends metrics to Unleash Server
- Tested on Linux (Ubuntu), OSX, and Windows
Check out the project documentation and the changelog.
Installation
Check out the package on Pypi!
pip install UnleashClient
Usage
Initialization
from UnleashClient import UnleashClient
client = UnleashClient("https://unleash.herokuapp.com/api", "My Program")
client.initialize_client()
To clean up gracefully:
client.destroy()
Arguments
Argument | Description | Required? | Type | Default Value |
---|---|---|---|---|
url | Unleash server URL | Y | String | N/A |
app_name | Name of your program | Y | String | N/A |
environment | Name of current environment | N | String | default |
instance_id | Unique ID for your program | N | String | unleash-client-python |
refresh_interval | How often the unleash client should check for configuration changes. | N | Integer | 15 |
metrics_interval | How often the unleash client should send metrics to server. | N | Integer | 60 |
disable_metrics | Disables sending metrics to Unleash server. | N | Boolean | F |
disable_registration | Disables registration with Unleash server. | N | Boolean | F |
custom_headers | Custom headers to send to Unleash. | N | Dictionary | {} |
custom_strategies | Custom strategies you'd like UnleashClient to support. | N | Dictionary | {} |
Checking if a feature is enabled
A check of a simple toggle:
client.is_enabled("My Toggle")
Specifying a default value:
client.is_enabled("My Toggle", default_value=True)
Supplying application context:
app_context = {"userId": "[email protected]"}
client.is_enabled("User ID Toggle", app_context)
Supplying a fallback function:
def custom_fallback(feature_name: str, context: dict) -> bool:
return True
client.is_enabled("My Toggle", fallback_function=custom_fallback)
- Must accept the fature name and context as an argument.
- Client will evaluate the fallback function only if exception occurs when calling the
is_enabled()
method i.e. feature flag not found or other general exception. - If both a
default_value
andfallback_function
are supplied, client will define the default value byOR
ing the default value and the output of the fallback function.
Getting a variant
Checking for a variant:
context = {'userId': '2'} # Context must have userId, sessionId, or remoteAddr. If none are present, distribution will be random.
variant = client.get_variant("MyvariantToggle", context)
print(variant)
> {
> "name": "variant1",
> "payload": {
> "type": "string",
> "value": "val1"
> },
> "enabled": True
> }
For more information about variants, see the Variant documentation.
Note that the project description data, including the texts, logos, images, and/or trademarks,
for each open source project belongs to its rightful owner.
If you wish to add or remove any projects, please contact us at [email protected].