
Product
Introducing Webhook Events for Alert Changes
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.
@reflag/cli
Advanced tools
Command-line interface for interacting with Reflag services. The CLI allows you to manage apps, flags, authentication, and generate TypeScript types for your Reflag flags. With this tool, you can streamline your flagging workflow directly from your terminal.
Install the CLI as a development dependency in your project:
# npm
npm install --save-dev @reflag/cli
# yarn
yarn add --dev @reflag/cli
Run the new command from your project's root directory to initialize the CLI, create a flag, and generate TypeScript types in one step:
# npm
npx reflag new
# yarn
yarn reflag new
If you're migrating from the Bucket CLI, here are the key changes to be aware of:
bucket to reflagfeatures.d.ts to flags.d.ts (manually remove the old file if it was committed).bucket-auth to .reflag-auth (rename or remove the old file)bucket.config.json to reflag.config.json (rename or remove the old file)features command is now flagsREFLAG_API_KEY instead of BUCKET_API_KEYImportant: Update your scripts, build steps, and .gitignore patterns to reflect these changes.
For more control, you can run each command individually:
# Initialize Reflag in your project (if not already setup)
npx reflag init
# Create a new flag
npx reflag flags create "My Flag"
# Generate TypeScript types for your flags
npx reflag flags types
The CLI creates a reflag.config.json file in your project directory when you run reflag init. This file contains all the necessary settings for your Reflag integration.
Here are all the configuration options available in the reflag.config.json file:
{
"$schema": "https://unpkg.com/@reflag/cli@latest/schema.json",
"baseUrl": "https://app.reflag.com",
"apiUrl": "https://app.reflag.com/api",
"appId": "ap123456789",
"typesOutput": [
{
"path": "gen/flags.d.ts",
"format": "react"
}
]
}
| Option | Description | Default |
|---|---|---|
$schema | Autocompletion for the config. latest can be replaced with a specific version. | "https://unpkg.com/@reflag/cli@latest/schema.json" |
baseUrl | Base URL for Reflag services. | "https://app.reflag.com" |
apiUrl | API URL for Reflag services (overrides baseUrl for API calls). | "https://app.reflag.com/api" |
appId | Your Reflag application ID. | Required |
typesOutput | Path(s) where TypeScript types will be generated. Can be a string or an array of objects with path and format properties. Available formats: react and node. | "gen/flags.ts" with format "react" |
You can override these settings using command-line options for individual commands.
reflag initInitialize a new Reflag configuration in your project. This creates a reflag.config.json file with your settings and prompts for any required information not provided via options.
npx reflag init [--overwrite]
Options:
--overwrite: Overwrite existing configuration file if one exists.--app-id <id>: Set the application ID.--key-format <format>: Set the key format for flags.reflag new [flagName]All-in-one command to get started quickly. This command combines init, flag creation, and type generation in a single step. Use this for the fastest way to get up and running with Reflag.
npx reflag new "My Flag" [--app-id ap123456789] [--key my-flag] [--key-format custom] [--out gen/flags.ts] [--format react]
Options:
--key: Specific key for the flag.--app-id: App ID to use.--key-format: Format for flag keys (custom, snake, camel, etc.).--out: Path to generate TypeScript types.--format: Format of the generated types (react or node).If you prefer more control over each step, you can use the individual commands (init, flags create, flags types) instead.
reflag loginAuthenticate with your Reflag account. This stores your credentials securely for subsequent operations.
npx reflag login
reflag logoutSign out from your Reflag account and remove stored credentials.
npx reflag logout
reflag flagsManage your Reflag flags with these subcommands:
reflag flags create [flagName]Create a new flag in your Reflag app. The command guides you through the flag creation process with interactive prompts if options are not provided.
npx reflag flags create "My Flag" [--app-id ap123456789] [--key my-flag] [--key-format custom]
Options:
--key: Specific key for the flag.--app-id: App ID to use.--key-format: Format for flag keys.reflag flags listList all flags for the current app. This helps you visualize what flags are available and their current configurations.
npx reflag flags list [--app-id ap123456789]
Options:
--app-id: App ID to use.reflag flags typesGenerate TypeScript types for your flags. This ensures type safety when using Reflag flags in your TypeScript/JavaScript applications.
npx reflag flags types [--app-id ap123456789] [--out gen/flags.ts] [--format react]
Options:
--app-id: App ID to use.--out: Path to generate TypeScript types.--format: Format of the generated types (react or node).reflag appsCommands for managing Reflag apps.
These options can be used with any command:
--debug: Enable debug mode for verbose output.--base-url <url>: Set the base URL for Reflag API.--api-url <url>: Set the API URL directly (overrides base URL).--api-key <key>: Reflag API key for non-interactive authentication.--help: Display help information for a command.Reflag provides powerful AI-assisted development capabilities through rules and Model Context Protocol (MCP). These features help your AI development tools better understand your flags and provide more accurate assistance.
The rules command helps you set up AI-specific rules for your project. These rules enable AI tools to better understand how to work with Reflag flags and how they should be used in your codebase.
npx reflag rules [--format <cursor|copilot>] [--yes]
Options:
--format: Format to add rules in:
cursor: Adds rules to .cursor/rules/reflag.mdc for Cursor IDE integration.copilot: Adds rules to .github/copilot-instructions.md for GitHub Copilot integration.--yes: Skip confirmation prompts and overwrite existing files without asking.This command adds rules to your project that provide AI tools with context about how to set up and use Reflag flags. For the copilot format, the rules are added to a dedicated section in the file, allowing you to maintain other copilot instructions alongside Reflag's rules.
The Model Context Protocol (MCP) is an open protocol that provides a standardized way to connect AI models to different data sources and tools. In the context of Reflag, MCP enables your code editor to understand your flags, their states, and their relationships within your codebase. This creates a seamless bridge between your flag management workflow and AI-powered development tools. The MCP server is hosted by Reflag, making it easy to get started.
**Note: The Reflag mcp CLI command was previously used for a _local server. However, in recent versions of the Reflag CLI, the mcp command has been repurposed to help you connect to the new remote MCP server.**_
The mcp command helps you configure your editor or AI client to connect with Reflag's remote MCP server. This allows your AI tools to understand your flags and provide more contextual assistance.
npx reflag mcp [--editor <editor>] [--scope <local|global>]
Options:
--editor: The editor/client to configure:
cursor: Cursor IDEvscode: Visual Studio Codeclaude: Claude Desktopwindsurf: Windsurf--scope: Whether to configure settings globally or locally for the project.The command will guide you through:
Note: The setup uses mcp-remote as a compatibility layer allowing the remote hosted Reflag MCP server to work with all editors/clients that support MCP STDIO servers. If your editor/client supports HTTP Streaming with OAuth you can connect to the Reflag MCP server directly.
The Reflag CLI is designed to work seamlessly in CI/CD pipelines. For automated environments where interactive login is not possible, use the --api-key option or specify the API key in the REFLAG_API_KEY environment variable.
# Generate types in CI/CD
npx reflag apps list --api-key $REFLAG_API_KEY
Important restrictions:
--api-key, the login and logout commands are disabledapps list will only return the bound appExample CI workflow:
# GitHub Actions example
- name: Generate types
run: npx reflag flags types --api-key ${{ secrets.REFLAG_API_KEY }}
# GitHub Actions example (using environment):
- name: Generate types (environment)
run: npx reflag flags types
env:
REFLAG_API_KEY: ${{ secrets.REFLAG_CI_API_KEY }}
# Build the CLI
yarn build
# Run the CLI locally
yarn reflag [command]
# Lint and format code
yarn lint
yarn format
MIT License Copyright (c) 2025 Bucket ApS
FAQs
CLI for Reflag service
We found that @reflag/cli demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.

Security News
ENISA has become a CVE Program Root, giving the EU a central authority for coordinating vulnerability reporting, disclosure, and cross-border response.

Product
Socket now scans OpenVSX extensions, giving teams early detection of risky behaviors, hidden capabilities, and supply chain threats in developer tools.