Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Pytlicek/fastapi-featureflags
FastAPI Feature Flags
https://github.com/Pytlicek/fastapi-featureflags
api fastapi fastapi-featureflags feature-flags featureflags hacktoberfest hacktoberfest-accepted python python-framework python-library serverless
Last synced: 3 months ago
JSON representation
FastAPI Feature Flags
- Host: GitHub
- URL: https://github.com/Pytlicek/fastapi-featureflags
- Owner: Pytlicek
- License: mit
- Created: 2021-11-23T17:22:43.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-06-10T13:35:59.000Z (8 months ago)
- Last Synced: 2024-08-31T01:21:37.168Z (5 months ago)
- Topics: api, fastapi, fastapi-featureflags, feature-flags, featureflags, hacktoberfest, hacktoberfest-accepted, python, python-framework, python-library, serverless
- Language: Python
- Homepage: https://pypi.org/project/fastapi-featureflags/
- Size: 90.8 KB
- Stars: 52
- Watchers: 4
- Forks: 7
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-fastapi - FastAPI FeatureFlags - Simple implementation of feature flags for FastAPI. (Third-Party Extensions / Utils)
- awesome-fastapi - FastAPI FeatureFlags - Simple implementation of feature flags for FastAPI. (Third-Party Extensions / Utils)
README
[![Test Python package](https://github.com/Pytlicek/fastapi-featureflags/actions/workflows/python-package.yml/badge.svg?branch=main)](https://github.com/Pytlicek/fastapi-featureflags/actions/workflows/python-package.yml)
[![codecov](https://codecov.io/gh/Pytlicek/fastapi-featureflags/branch/main/graph/badge.svg?token=CVULQJ2SSA)](https://codecov.io/gh/Pytlicek/fastapi-featureflags)
[![Upload Python Package to PyPI](https://github.com/Pytlicek/fastapi-featureflags/actions/workflows/python-publish.yml/badge.svg)](https://github.com/Pytlicek/fastapi-featureflags/actions/workflows/python-publish.yml)
![PythonVersions](https://img.shields.io/badge/python-3.8%20%7C%203.9%20%7C%203.10%20%7C%203.11%20%7C%203.12-blue)
[![Sourcery](https://img.shields.io/badge/Sourcery-enabled-brightgreen)](https://sourcery.ai)
[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/ambv/black)
[![Snyk](https://snyk-widget.herokuapp.com/badge/pip/sheet2dict/badge.svg)](https://snyk.io/advisor/python/fastapi-featureflags)
[![Downloads](https://pepy.tech/badge/fastapi-featureflags)](https://pepy.tech/project/fastapi-featureflags)
[![Twitter Follow](https://img.shields.io/twitter/follow/Pytlicek?color=1DA1F2&logo=twitter&style=flat)](https://twitter.com/Pytlicek)# FastAPI Feature Flags
Very simple implementation of feature flags for FastAPI.
- Minimum configuration required
- No unnecessary dependencies
- Does its job## Installing
To install the package from pip, first run:
```bash
pip install fastapi-featureflags
```## Usage
A simple example of feature flags:
```python
from fastapi_featureflags import FeatureFlags, feature_flag, feature_enabledFeatureFlags(conf_from_url="https://pastebin.com/raw/4Ai3j2DC")
print("Enabled Features:", FeatureFlags.get_features())@feature_flag("web_1")
def web_1_enabled():
print("Feature Should be enabled: web_1")web_1_enabled()
if feature_enabled("web_2"):
print("Feature Should be disabled: web_2")
```You can get FF (feature flags) from a **File**, **URL**, **Dictionary or ENV Variables**:
```python
FeatureFlags.load_conf_from_url("https://pastebin.com/raw/4Ai3j2DC")
FeatureFlags.load_conf_from_json("tests/features.json")
FeatureFlags.load_conf_from_dict({"web_1": True, "web_2": False})FeatureFlags.reload_feature_flags()
```
There is also a handler that recognizes if the "@feature_flag" wrapper is used and the flag is not registered in the config.
This way you can also use FF at runtime. Defaults to False, so it's safer if you forget the feature flag in the code.Function `get_features` returns a list of all registered FF
You can enable or disable functions on the fly with `enable_feature` or `enable_feature`When needed you can reload all feature flags with `reload_feature_flags`,
this is useful when you want to read and change features from URL.
All unregistered or on-the-fly created FF, that are not in the configuration will be omitted.For non-production testing, a router is available,
so you can see the paths in swagger-ui docs.
Use `include_in_schema=False` when defining the router for public deployments
```python
from fastapi_featureflags import router as ff_router
app.include_router(ff_router, prefix="/ff", tags=["FeatureFlags"])
```
---# Contributing and Code of Conduct
### Contributing to fastapi-featureflags
As an open source project, fastapi-featureflags welcomes contributions of many forms.
Please read and follow our [Contributing to fastapi-featureflags](CONTRIBUTING.md)### Code of Conduct
As a contributor, you can help us keep the fastapi-featureflags project open and inclusive.
Please read and follow our [Code of Conduct](CODE_OF_CONDUCT.md)