firebase-remote-config-basics
firebase/agent-skills
Manage feature flags and app behavior dynamically with Firebase Remote Config.
What is firebase-remote-config-basics?
Firebase Remote Config lets you change app behavior and appearance without publishing updates by maintaining a cloud-based configuration template. Use this skill when setting up Remote Config, managing feature flags, or updating app configuration dynamically.
- Fetch and activate remote configuration values from Firebase backend
- Define in-app default values for offline functionality
- Manage Remote Config templates via CLI with version history tracking
- Deploy configuration changes using Firebase CLI
- Support real-time listener updates for instant app changes
- Implement fetching strategies to optimize performance and user experience
How to install firebase-remote-config-basics
npx skills add https://github.com/firebase/agent-skills --skill firebase-remote-config-basics- Firebase project and Firebase app (Android or iOS)
- Firebase CLI (optional but recommended; can use npx -y firebase-tools@latest)
- Node.js and npm for CLI access
How to use firebase-remote-config-basics
- 1.Set up Remote Config in your app code using the appropriate SDK (Android or iOS)
- 2.Define in-app default values in your application code
- 3.Fetch the Remote Config template locally: npx -y firebase-tools@latest remoteconfig:get -o remote_config.json
- 4.Edit remote_config.json to add parameters and conditions (e.g., device.country, percent-based targeting)
- 5.Review your changes and verify accuracy before deployment
- 6.Create or update firebase.json with remoteconfig template mapping if needed
- 7.Deploy changes: npx -y firebase-tools@latest deploy --only remoteconfig
- 8.Verify deployment by listing version history: npx -y firebase-tools@latest remoteconfig:versions:list
Use cases
- Enable or disable features for specific user segments without app updates
- Roll out A/B tests by serving different configurations to user groups
- Update pricing, messaging, or UI elements dynamically across your user base
- Gradually roll out new features using percentage-based conditions
- Manage feature flags across Android and iOS apps from a single template
- Mobile app developers (Android/iOS)
- Product managers managing feature rollouts
- Teams implementing A/B testing or canary deployments
- Backend engineers managing app configuration
firebase-remote-config-basics FAQ
Firebase CLI is optional but recommended for template management and deployment. You can access it via npx -y firebase-tools@latest or install it globally with npm install -g firebase-tools.
Try using the local firebase command directly if installed globally. If that fails, inform the user of the registry error and explore alternative setup paths.
Run npx -y firebase-tools@latest login:list to check login status. If logged in but no project is active, ask the user for their Firebase Project ID and append --project <PROJECT_ID> to commands.
Load new values for next startup by activating previously fetched values on startup and fetching new values in the background. This minimizes user wait time. Alternatively, use real-time listeners for instant updates.
Yes, Remote Config works with both Android and iOS. Refer to the platform-specific setup guides (android_setup.md or ios_setup.md) for SDK integration details.
Full instructions (SKILL.md)
Source of truth, from firebase/agent-skills.
name: firebase-remote-config-basics
description: Comprehensive guide for Firebase Remote Config, including template management and SDK usage. Use this skill when the user needs help setting up Remote Config, managing feature flags, or updating app behavior dynamically.
compatibility: This skill is best used with the Firebase CLI, but does not require it. Firebase CLI can be accessed through npx -y firebase-tools@latest.
Remote Config
This skill provides a complete guide for getting started with Remote Config on Android or iOS. Remote Config allows you to change the behavior and appearance of your app without publishing an app update by maintaining a cloud-based configuration template.
Prerequisites
Provisioning Remote Config requires both a Firebase project and a Firebase app,
either Android or iOS. To manage the Remote Config template and conditions via
the command line, use the Firebase CLI. See the firebase-basics skill for
references on project initialization.
Troubleshooting Execution
Handling npx 403 Forbidden Errors
If npx -y firebase-tools@latest fails due to registry permissions (403 error):
- Inform the user: "I am unable to fetch the latest Firebase tools via npx due to a registry error."
- Fallback: Attempt to use the local
firebasecommand directly if the user confirms it is installed globally (npm install -g firebase-tools).
Handling Project Context Issues
If a command fails because "no active project is selected":
- Check login: Run
npx -y firebase-tools@latest login:list. - Prompt for ID: If logged in but no project is active, ask the user: "Please provide your Firebase Project ID to proceed."
- Use Flag: Append
--project <PROJECT_ID>to every subsequent command.
SDK Setup
To learn how to set up Remote Config in your application code, choose your platform:
- Android: android_setup.md
- iOS: ios_setup.md
Best Practices and Template Management
Follow these guidelines and use the associated CLI tools to ensure efficient and safe use of Remote Config.
Fetching Strategies
To optimize app performance and user experience, follow these recommended patterns (see Loading Strategies):
- Load new values for next startup: The most effective pattern is to activate previously fetched values immediately on startup and fetch new values in the background to be used next time. This minimizes user wait time.
- Real-time Updates: Use the SDK's real-time listener to update the app instantly without a refresh when server-side configuration changes.
Template Management via CLI
Use the following commands to manage your Remote Config template and version history through the terminal:
Template Management via CLI
Use the following commands to manage your Remote Config template and version history through the terminal:
-
Get current template: Save the remote template to a local JSON file for auditing or modification.
npx -y firebase-tools@latest remoteconfig:get -o remote_config.json -
Autonomous Editing & Discovery : Modify the local
remote_config.jsondirectly. Determine the correct signal (e.g., device.country or percent) and update the "conditions" array and "parameters" map accordingly. -
MANDATORY: User Review and Verification : STOP and ask the user to verify your changes before proceeding to deployment.
- Action: Inform the user: "I have prepared the changes in remote_config.json. Please review the file for accuracy. Once you are satisfied, tell me to 'deploy' to make the changes live."
-
Deployment Orchestration : To push changes, you must ensure the environment is configured for deployment.
- Config Mapping: If a firebase.json file is missing, create one to map the local JSON to the Remote Config service:
{ "remoteconfig": { "template": "remote_config.json" } }- Deploy: Execute the partial deployment command
npx -y firebase-tools@latest deploy --only remoteconfig
-
Verification: After deployment, verify the update by listing the version history.
npx -y firebase-tools@latest remoteconfig:versions:list
The SDK provides a number of features to make your application dynamic and responsive to user segments.
- Set In-App Defaults: Define baseline values to ensure the app functions offline or before the first fetch.
- Fetch and Activate: Retrieve values from the Firebase backend and apply them to the local UI/Logic.
- Template Management: Use the Firebase CLI to version-control, get, and deploy your config JSON files.
Related skills
More from firebase/agent-skills and the wider catalog.
firebase-basics
Firebase CLI setup, authentication, and project management for agent workflows
firebase-auth-basics
Set up Firebase Authentication for user sign-in, management, and secure data access.
firebase-hosting-basics
Deploy static web apps, SPAs, and microservices to Firebase Hosting with a single command.
firebase-app-hosting-basics
Deploy full-stack Next.js and Angular apps with Firebase App Hosting.
firebase-data-connect
Build and deploy PostgreSQL-backed Firebase backends with GraphQL, auto-generated queries, and type-safe SDKs.
developing-genkit-js
Develop AI-powered applications using Genkit in Node.js/TypeScript with flows, tools, and multi-provider support.