launchdarkly-flag-targeting

作成者: launchdarkly

LaunchDarklyの機能フラグターゲティングを制御します。フラグのオン/オフ切り替え、パーセンテージロールアウト、ターゲティングルール、個別ターゲット、フラグのコピーなどを含みます。

npx skills add https://github.com/launchdarkly/agent-skills --skill launchdarkly-flag-targeting

LaunchDarkly 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 changes
  • toggle-flag: turn targeting on or off for a flag in an environment
  • update-rollout: change the default rule (fallthrough) variation or percentage rollout
  • update-targeting-rules: add, remove, or modify custom targeting rules
  • update-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
  • create-approval-request: create an approval request when direct changes are blocked
  • list-approval-requests: check on pending approval requests for a flag
  • apply-approval-request: apply an already-approved approval request

Core Concept: Evaluation Order

Before making any targeting changes, understand how LaunchDarkly evaluates flags. This determines what your changes actually do:

  1. Flag is OFF -> Serve the offVariation to everyone. Nothing else matters.
  2. Individual targets -> If the context matches a specific target list, serve that variation. Highest priority.
  3. Custom rules -> Evaluate rules top-to-bottom. First matching rule wins.
  4. 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.

  1. 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.
  2. Fetch the flag. Use get-flag with 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?
  3. 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 wantsToolNotes
"Turn it on"toggle-flag with on: trueSimplest change
"Turn it off"toggle-flag with on: falseServes 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 clauseRules are ANDed within, ORed between
"Add specific users"update-individual-targetsHighest priority, overrides all rules
"Full rollout"update-rollout with rolloutType: "variation"Serve one variation to everyone
"Copy from staging"copy-flag-configPromote tested config to production

Step 3: Run the Safety Checklist

Before applying changes, especially in production, run through the Safety Checklist. The key checks:

  1. Right environment? Double-check you're targeting the intended environment.
  2. Approval required? Some environments require approval workflows. If any mutation tool returns requiresApproval: true:
    • Inform the user that this environment requires approvals.
    • Share the approvalUrl if provided.
    • Offer to create an approval request using create-approval-request with the same instructions (returned in the instructions field of the response).
    • Do NOT attempt to bypass approval or auto-approve.
    • See Approval Workflows for the full process.
  3. Prerequisite flags? If this flag has prerequisites, they must be met before targeting works as expected.
  4. Rule ordering impact? If adding rules, consider where they fall in evaluation order. Rules evaluate top-to-bottom, first match wins.
  5. 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: Specify on: true or on: false, the env, and a comment.
  • update-rollout: Use rolloutType: "percentage" with human-friendly weights (e.g., 80 for 80%) that sum to 100, or rolloutType: "variation" with a variationIndex.
  • update-targeting-rules: Instructions support addRule, removeRule, updateRuleVariationOrRollout, addClauses, removeClauses, reorderRules.
  • update-individual-targets: Instructions support addTargets, removeTargets, addContextTargets, removeContextTargets, replaceTargets.

See Targeting Patterns for detailed instruction examples.

Step 5: Verify

After applying changes, confirm the result:

  1. Fetch the updated flag. Use get-flag again to verify the new state.
  2. Confirm what the user expects. Describe the resulting targeting in plain language:
    • "The flag is now ON in production, serving true to 25% of users and false to 75%."
    • "Beta users now see variation A. Everyone else gets the default (variation B)."
  3. Check for side effects. If there are rules or individual targets, make sure the change interacts correctly with them.

Handling Approval-Required Environments

When any mutation tool returns requiresApproval: true, the direct change was blocked because the environment requires approvals. Follow the Approval Workflows reference to:

  1. Create an approval request with create-approval-request using the instructions from the blocked response
  2. Inform the user about the pending approval and share the approval request details
  3. Check on approval status later with list-approval-requests if requested
  4. Apply the request with apply-approval-request once a reviewer has approved it (reviewStatus is "approved")
  5. Verify the result with get-flag after applying

Important Context

  • update-rollout uses 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
  • Approval Workflows: Creating, checking, and applying approval requests

launchdarklyのその他のスキル

aiconfig-agent-graphs
launchdarkly
エージェントグラフを作成・管理します — ハンドオフロジックを持つエッジで接続されたAIコンフィグの有向グラフです。コンフィグが連携するマルチエージェントワークフローを構築する際に使用します…
official
aiconfig-ai-metrics
launchdarkly
既存のコードベースにLaunchDarkly AI Configトラッキングを導入します。4段階のラダー(管理ランナー → プロバイダーパッケージ → カスタム抽出器 +…)を進めます。
official
aiconfig-create
launchdarkly
LaunchDarklyでAI Configを作成・設定します。エージェントモードと完了モードの選択、設定の作成、モデルとプロンプトによるバリエーションの追加などを支援します。
official
aiconfig-custom-metrics
launchdarkly
AI Configs向けのカスタムビジネスメトリクスを作成、追跡、取得、更新、削除します。完全なライフサイクルをカバー:API経由でメトリクス種類を定義、SDK経由でイベントを発行、…
official
aiconfig-migrate
launchdarkly
ハードコードされたLLMプロンプトを含むアプリケーションを、LaunchDarkly AI Configsの完全な実装に5段階で移行します:コードの監査、呼び出しのラップ、プロンプトの移動…
official
aiconfig-online-evals
launchdarkly
AI Configのバリエーションに判定機能を追加し、LLM-as-a-judgeによる自動評価を実現します。カスタム判定機能を作成し、サンプリングレートを設定して、品質スコアを監視できます。
official
aiconfig-projects
launchdarkly
コードベースでLaunchDarklyプロジェクトをセットアップするためのガイド。スタックの評価、適切なアプローチの選択、プロジェクト管理の統合を支援します…
official
aiconfig-snippets
launchdarkly
プロンプトスニペットを作成・管理します。AI Configのバリエーションプロンプト内で参照される再利用可能なテキストブロックです。共通の指示、ペルソナ、ガードレールを保持します…
official