Skip to main content

Python sdk for Reforge Feature Flags and Config as a Service: https://www.reforge.com

Project description

reforge-python

Python client for reforge.com, providing Config, FeatureFlags as a Service

Example usage

from sdk_reforge import ReforgeSDK, Options
import sdk_reforge

options = Options(
    sdk_key="your-reforge-sdk-key"
)

context = {
  "user": {
    "team_id": 432,
    "id": 123,
    "subscription_level": 'pro',
    "email": "alice@example.com"
  }
}


sdk_reforge.set_options(options)

result = sdk_reforge.get_sdk().enabled("my-first-feature-flag", context=context)

print("my-first-feature-flag is:", result)

Protocol Buffer Types

If you need to work with the underlying Protocol Buffer types, the following are re-exported for convenience:

from sdk_reforge import ConfigValue, StringList, ProtoContext, ContextSet, ContextShape, LogLevel, Json, Schema

# Create a config value
config_value = ConfigValue(string="example value")

# Create a JSON value
json_value = ConfigValue(json=Json(json='{"key": "value"}'))

# Create a Schema value
schema_value = Schema(definition='{"type": "object", "properties": {"name": {"type": "string"}}}')

See full documentation https://docs.reforge.com/docs/sdks/python

Development

  1. Ensure that poetry is installed: https://python-poetry.org/docs/#installation
  2. From the root of this directory, run poetry install to ensure dependencies are installed
  3. poetry run python to open a Python REPL with access to the project dependencies

Running tests

To run all tests, including integration tests

poetry run pytest tests

To run only local tests and skip integration tests

poetry run pytest tests -k "not integration"

To run only one specific test file

poetry run pytest tests/name_of_test_file.py

Examples

There are examples in examples

Releasing

  1. Run pre-commit hooks to check and fix formatting, other rule enforcement. poetry run pre-commit run --show-diff-on-failure --color=always --all-files
  2. On a branch
    1. Update the version in pyproject.toml
    2. Update CHANGELOG.md
  3. Merge the branch
  4. git tag <version> && git push --tags
  5. poetry publish --build
    1. To do this you will need an pypi.org account, and to be added to this project (ask Michael for an invitation)

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

sdk_reforge-1.0.0.tar.gz (35.6 kB view details)

Uploaded Source

Built Distribution

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

sdk_reforge-1.0.0-py3-none-any.whl (44.7 kB view details)

Uploaded Python 3

File details

Details for the file sdk_reforge-1.0.0.tar.gz.

File metadata

  • Download URL: sdk_reforge-1.0.0.tar.gz
  • Upload date:
  • Size: 35.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sdk_reforge-1.0.0.tar.gz
Algorithm Hash digest
SHA256 28cebc6f151ba519438c2531653763495861f450689904141e611272a9f9726f
MD5 e5cae31e67b17a8c0a228e498af1188a
BLAKE2b-256 38373fa7a34fe9e98a77d18f8e5c30db8e2b5418592d7b7edea4e463a4ad56f2

See more details on using hashes here.

Provenance

The following attestation bundles were made for sdk_reforge-1.0.0.tar.gz:

Publisher: publish.yml on ReforgeHQ/sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sdk_reforge-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: sdk_reforge-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 44.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sdk_reforge-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7f90d962b6dfea7774b75a3ef4a6f36cb293184f4d874df7c2afa4f354fbcc81
MD5 f94f41600185fbfecae02b92f22949ad
BLAKE2b-256 9c65944868c2c675c4bb6f91487aa2876ea6eb7c5c16e0af4c2676addcfeaef7

See more details on using hashes here.

Provenance

The following attestation bundles were made for sdk_reforge-1.0.0-py3-none-any.whl:

Publisher: publish.yml on ReforgeHQ/sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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