launchdarkly-flag-targeting
npx machina-cli add skill launchdarkly/agent-skills/launchdarkly-flag-targeting --openclawLaunchDarkly Flag Targeting & Rollout
You're using a skill that will guide you through changing who sees what for a feature flag. Your job is to understand the current state of the flag, figure out the right targeting approach for what the user wants, make the changes safely, and verify the resulting state.
Prerequisites
This skill requires the remotely hosted LaunchDarkly MCP server to be configured in your environment.
Required MCP tools:
get-flag— understand current state before making changestoggle-flag— turn targeting on or off for a flag in an environmentupdate-rollout— change the default rule (fallthrough) variation or percentage rolloutupdate-targeting-rules— add, remove, or modify custom targeting rulesupdate-individual-targets— add or remove specific users/contexts from individual targeting
Optional MCP tools:
copy-flag-config— copy targeting configuration from one environment to another
Core Concept: Evaluation Order
Before making any targeting changes, understand how LaunchDarkly evaluates flags. This determines what your changes actually do:
- Flag is OFF → Serve the
offVariationto everyone. Nothing else matters. - Individual targets → If the context matches a specific target list, serve that variation. Highest priority.
- Custom rules → Evaluate rules top-to-bottom. First matching rule wins.
- Default rule (fallthrough) → If nothing else matched, serve this variation or rollout.
This means: if you add a targeting rule but the flag is OFF, nobody sees the change. If you set a percentage rollout on the default rule but there's an individual target, that targeted user bypasses the rollout.
Workflow
Step 1: Understand Current State
Before changing anything, check what's already configured.
- Confirm the environment. "Turn it on" without specifying an environment is ambiguous. Always confirm which environment the user means. Default to asking rather than assuming.
- Fetch the flag. Use
get-flagwith the target environment to see:on— Is targeting currently enabled?fallthrough— What's the default rule? (variation or percentage rollout)offVariation— What serves when the flag is off?rules— Any custom targeting rules?targets— Any individually targeted users/contexts?prerequisites— Any flags this depends on?
- Assess complexity. A flag with no rules and no individual targets is simple. A flag with multiple rules, targets, and prerequisites needs more care.
Step 2: Determine the Right Approach
Based on what the user wants and what you found, choose the right tool and strategy. See Targeting Patterns for the full reference.
Common scenarios:
| User wants | Tool | Notes |
|---|---|---|
| "Turn it on" | toggle-flag with on: true | Simplest change |
| "Turn it off" | toggle-flag with on: false | Serves offVariation to everyone |
| "Roll out to X%" | update-rollout with rolloutType: "percentage" | Weights must sum to 100 |
| "Enable for beta users" | update-targeting-rules — add a rule with clause | Rules are ANDed within, ORed between |
| "Add specific users" | update-individual-targets | Highest priority, overrides all rules |
| "Full rollout" | update-rollout with rolloutType: "variation" | Serve one variation to everyone |
| "Copy from staging" | copy-flag-config | Promote tested config to production |
Step 3: Run the Safety Checklist
Before applying changes, especially in production, run through the Safety Checklist. The key checks:
- Right environment? Double-check you're targeting the intended environment.
- Approval required? Some environments require approval workflows. If
toggle-flagor other tools returnrequiresApproval: true, surface this to the user with the approval URL. - Prerequisite flags? If this flag has prerequisites, they must be met before targeting works as expected.
- Rule ordering impact? If adding rules, consider where they fall in evaluation order. Rules evaluate top-to-bottom, first match wins.
- Include a comment. Always add an audit trail comment, especially for production changes.
Step 4: Apply Changes
Use the appropriate tool for the change. Key notes:
toggle-flag: Specifyon: trueoron: false, theenv, and acomment.update-rollout: UserolloutType: "percentage"with human-friendly weights (e.g., 80 for 80%) that sum to 100, orrolloutType: "variation"with avariationIndex.update-targeting-rules: Instructions supportaddRule,removeRule,updateRuleVariationOrRollout,addClauses,removeClauses,reorderRules.update-individual-targets: Instructions supportaddTargets,removeTargets,addContextTargets,removeContextTargets,replaceTargets.
See Targeting Patterns for detailed instruction examples.
Step 5: Verify
After applying changes, confirm the result:
- Fetch the updated flag. Use
get-flagagain to verify the new state. - Confirm what the user expects. Describe the resulting targeting in plain language:
- "The flag is now ON in production, serving
trueto 25% of users andfalseto 75%." - "Beta users now see variation A. Everyone else gets the default (variation B)."
- "The flag is now ON in production, serving
- Check for side effects. If there are rules or individual targets, make sure the change interacts correctly with them.
Important Context
update-rolloutuses human-friendly percentages. Pass 80 for 80%, not 80000. The tool handles the internal weight conversion.- Weights must sum to 100. For percentage rollouts, the weights across all variations must total exactly 100.
- Rule ordering matters. Rules evaluate top-to-bottom. Reordering rules can change behavior without changing any individual rule.
- Individual targets are highest priority. They override all rules and the default. Adding someone as an individual target means rules don't apply to them.
- "Launched" flags are still ON. A flag with status "launched" is serving a single variation to everyone. If you want to remove the flag, use the cleanup skill, not targeting changes.
References
- Targeting Patterns — Rollout strategies, rule construction, individual targeting, and cross-environment copying
- Safety Checklist — Pre-change verification, approval workflows, environment awareness
Source
git clone https://github.com/launchdarkly/agent-skills/blob/main/skills/feature-flags/launchdarkly-flag-targeting/SKILL.mdView on GitHub Overview
This skill guides you through inspecting and changing who sees a LaunchDarkly feature flag. It covers turning targeting on or off, applying percentage rollouts, adding or updating targeting rules, and managing individual targets, plus copying configurations between environments. These controls help you safely promote changes and tailor exposure.
How This Skill Works
Requires a configured remote LaunchDarkly MCP server and uses MCP tools to read and modify flag state. Tools include get-flag, toggle-flag, update-rollout, update-targeting-rules, update-individual-targets, and copy-flag-config. Changes follow the evaluation order so you can predict impact and then verify the final state.
When to Use It
- Turn on a flag in a specific environment
- Turn off a flag so everyone sees offVariation
- Roll out to a percentage of users
- Enable targeting rules for beta or internal users
- Copy flag configuration between environments
Quick Start
- Step 1: Confirm the environment and fetch the current flag state with get-flag.
- Step 2: Apply changes using the appropriate MCP tool (toggle-flag, update-rollout, update-targeting-rules, update-individual-targets, or copy-flag-config).
- Step 3: Verify the result by re-fetching the flag state and checking the evaluation order
Best Practices
- Always confirm the target environment before mutating state
- Fetch current state with get-flag before changes
- Consider evaluation order to predict outcomes
- Make incremental rollouts and validate results
- Verify the final state with get-flag and manual checks
Example Use Cases
- Turn on a flag in prod after QA passes
- Roll out a new feature to 20% of users and monitor
- Add a rule for internal users to receive a different variation
- Add specific users to the target list to ensure early access
- Copy a working configuration from staging to production