> launchdarkly
Manage feature flags with LaunchDarkly. Use when a user asks to implement feature flags, roll out features gradually, do A/B testing, control feature access by user segment, or implement kill switches for features.
curl "https://skillshub.wtf/TerminalSkills/skills/launchdarkly?format=md"LaunchDarkly
Overview
LaunchDarkly is the industry-standard feature flag platform. Control feature rollouts, A/B tests, and entitlements without deploying new code. Supports gradual rollouts, targeting rules, and instant kill switches.
Instructions
Step 1: Setup
npm install @launchdarkly/node-server-sdk # server
npm install launchdarkly-react-client-sdk # React
Step 2: Server-Side Flags
// lib/flags.ts — Feature flag evaluation on the server
import * as LaunchDarkly from '@launchdarkly/node-server-sdk'
const client = LaunchDarkly.init(process.env.LAUNCHDARKLY_SDK_KEY!)
await client.waitForInitialization()
export async function getFlag(flagKey: string, user: { key: string; email?: string; plan?: string }) {
const context = {
kind: 'user',
key: user.key,
email: user.email,
custom: { plan: user.plan },
}
return client.variation(flagKey, context, false) // false = default
}
// Usage
const showNewDashboard = await getFlag('new-dashboard', { key: userId, plan: 'pro' })
if (showNewDashboard) {
return renderNewDashboard()
}
Step 3: React Client
// components/FeatureFlag.tsx — Client-side feature flags
import { withLDProvider, useFlags } from 'launchdarkly-react-client-sdk'
function App() {
const { newCheckout, darkMode } = useFlags()
return (
<div className={darkMode ? 'dark' : ''}>
{newCheckout ? <NewCheckout /> : <OldCheckout />}
</div>
)
}
export default withLDProvider({
clientSideID: process.env.NEXT_PUBLIC_LD_CLIENT_ID!,
context: { kind: 'user', key: userId, email: userEmail },
})(App)
Step 4: Gradual Rollout
Configure in LaunchDarkly dashboard:
- Percentage rollout: 10% → 25% → 50% → 100% over days/weeks
- Targeting rules: enable for beta users first, then pro plan, then everyone
- Kill switch: instantly disable a feature if it causes issues
Guidelines
- LaunchDarkly evaluates flags locally (SDK caches rules) — near-zero latency.
- Use multi-variate flags for A/B testing (not just boolean on/off).
- Pricing starts at $10/seat/month. For free alternative, consider Unleash (open-source).
- Always set meaningful defaults — the app should work even if LaunchDarkly is unreachable.
> related_skills --same-repo
> zustand
You are an expert in Zustand, the small, fast, and scalable state management library for React. You help developers manage global state without boilerplate using Zustand's hook-based stores, selectors for performance, middleware (persist, devtools, immer), computed values, and async actions — replacing Redux complexity with a simple, un-opinionated API in under 1KB.
> zod
You are an expert in Zod, the TypeScript-first schema declaration and validation library. You help developers define schemas that validate data at runtime AND infer TypeScript types at compile time — eliminating the need to write types and validators separately. Used for API input validation, form validation, environment variables, config files, and any data boundary.
> xero-accounting
Integrate with the Xero accounting API to sync invoices, expenses, bank transactions, and contacts — and generate financial reports like P&L and balance sheet. Use when: connecting apps to Xero, automating bookkeeping workflows, syncing accounting data, or pulling financial reports programmatically.
> windsurf-rules
Configure Windsurf AI coding assistant with .windsurfrules and workspace rules. Use when: customizing Windsurf for a project, setting AI coding standards, creating team-shared Windsurf configurations, or tuning Cascade AI behavior.