Skip to main content

Firebase Remote Config SDK

Project description

Firebase Remote Config SDK for Python

A Python SDK for managing Firebase Remote Config, built as a typed abstraction over the Firebase REST API. This package provides a convenient way to get, validate, update and upload remote config templates.

Features

  • Provides SDK for managing Remote Config for mobile clients that is missing from Google firebase-admin package
  • Type-safe interface using Pydantic models
  • Minimal DSL for building and manipulating condition expressions
  • Enables parsing condition expressions into Pydantic models

Capabilities

  • Fetch and update Remote Config templates
  • Validate template updates before deployment
  • List template versions and perform rollbacks
  • Add, query, and update conditions and parameters
  • Serialize and parse condition expressions to/from structured form

Installation

pip install firebase-remote-config

Requirements

  • Python 3.9 or higher
  • Firebase project with Remote Config enabled
  • Service account credentials with necessary permissions (Firebase Admin / Firebase Remote Config Admin)

Usage

Getting Started

First, initialize the client with your Firebase credentials:

from google.oauth2 import service_account
from firebase_remote_config import RemoteConfigClient

# Initialize the client
credentials = service_account.Credentials.from_service_account_file('path/to/service-account.json')
client = RemoteConfigClient(credentials, 'your-project-id')

# Get current Remote Config template
config = client.get_remote_config()

# Upload template to Firebase Remote Config
updated_config = client.update_remote_config(config)

Use Cases

1. Creating and Updating Parameters

import firebase_remote_config as rc

# Add new parameter to the remote config template
new_param = rc.RemoteConfigParameter(
    defaultValue=rc.RemoteConfigParameterValue(value="default_value"),
    valueType=rc.ParameterValueType.STRING,
    description="A new parameter"
)
config.template.parameters["new_parameter"] = new_param

# find parameter in the template
param = config.find_param_by_key("new_parameter")
param.description = "My new parameter"

2. Working with Conditional Values

import firebase_remote_config as rc

# Create condition object
condition = rc.RemoteConfigCondition(
    name="ios_users",
    expression="device.os == 'ios'",
    tagColor=rc.TagColor.BLUE,
)

# Insert condition to rconfig template
config.insert_condition(condition)

# Use newly created condition in a conditional value
config.set_conditional_value(
    param_key="my_parameter",
    param_value=rc.RemoteConfigParameterValue(value="my_value"),
    param_value_type=rc.ParameterValueType.STRING,
    condition_name="ios_users",
)

3. Building Complex Conditions with ConditionBuilder

import firebase_remote_config as rc
from firebase_remote_config.conditions import ConditionBuilder

# Create a complex condition
builder = ConditionBuilder()
builder.CONDITION().APP_VERSION().GTE("1.2.0")
builder.CONDITION().APP_USER_PROPERTY("total_purchases_usd").GTE(5)
builder.CONDITION().DEVICE_COUNTRY().IN(["US", "CA"])
cond_expr = builder.build()

# Serialize condition as string
cond_expr_str = str(cond_expr)
# app.version.>=(['1.2.0']) && app.userProperty['total_purchases_usd'] >= 5 && device.country in ['US', 'CA']

# Insert condition to remote config template
config.insert_condition(rc.RemoteConfigCondition(
    name="active_premium_users",
    expression=cond_expr_str,
    tagColor=rc.TagColor.GREEN,
))

4. Parsing condition expression

from firebase_remote_config.conditions import ConditionParser

# Parse condition expression
parser = ConditionParser()
cond_expr = "dateTime >= dateTime('2025-01-01T09:00:00') && app.userProperty['my_property'].contains(['abc', 'def'])"
condition = parser.parse(cond_expr)

# Compare string representations of the condition to the original expression
print(str(condition) == cond_expr)
# True

5. Version Management

# List recent versions
versions, _ = client.list_versions(page_size=30)

# Rollback to a previous version
rolled_back_config = client.rollback(version_number="42")

License

This project is licensed under the terms of the LICENSE file in the root of this repository.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

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

firebase_remote_config-0.1.10.tar.gz (23.5 kB view details)

Uploaded Source

Built Distribution

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

firebase_remote_config-0.1.10-py3-none-any.whl (23.2 kB view details)

Uploaded Python 3

File details

Details for the file firebase_remote_config-0.1.10.tar.gz.

File metadata

  • Download URL: firebase_remote_config-0.1.10.tar.gz
  • Upload date:
  • Size: 23.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for firebase_remote_config-0.1.10.tar.gz
Algorithm Hash digest
SHA256 c1a8ba7efdbdf47c8e9ca67ce8dde1d37c0900290bd10dc74f4e6b6b1ceb278b
MD5 1f9b8c44565aac4a0cc5754e3c623b49
BLAKE2b-256 84775b089b9087e7a640ea2b89fe594e6be8f9a5f6813211b8a1133bae0c95ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for firebase_remote_config-0.1.10.tar.gz:

Publisher: publish.yml on apprevenew-com/firebase-remote-config-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 firebase_remote_config-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for firebase_remote_config-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 dcff0d3a2067c5c9bff8ef14300ad51294022fc153ccad32ca05feb3195ad7dd
MD5 71ec99b6bcf6a5f2f8cd520748a42c9a
BLAKE2b-256 8fdca77a18ed5a0e37a2beee626a97b5e12815ceff064c0e2989daf8f881c072

See more details on using hashes here.

Provenance

The following attestation bundles were made for firebase_remote_config-0.1.10-py3-none-any.whl:

Publisher: publish.yml on apprevenew-com/firebase-remote-config-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