name: feature-flags description: >- Create, modify, and remove feature flags in RedisInsight. Use when adding a new feature flag, introducing a dev flag, promoting a dev flag to regular, cleaning up old flags, or the user mentions feature flags, feature toggles, or gating features.
Feature Flags
RedisInsight has its own feature flag system. Flags are defined in a remote JSON config, fetched by the backend, and served to the frontend via API. This skill covers how to add, promote, and remove flags.
Flag Types
| Type | Naming | flag value |
Strategy | Purpose |
|---|---|---|---|---|
| Dev flag | dev-<name> (e.g. dev-browser) |
false |
CommonFlagStrategy |
Hide incomplete features during development |
| Regular flag | camelCase (e.g. azureEntraId) |
true |
CommonFlagStrategy |
Standard on/off toggle |
| Regular with data | camelCase |
true |
WithDataFlagStrategy |
Flag + extra config payload in data |
| Switchable (overridable) | camelCase |
true |
SwitchableFlagStrategy |
User can override locally via ~/.redis-insight/config.json |
Files to Change
Every new flag touches these files (in order):
Backend (required)
redisinsight/api/config/features-config.jsonAdd the flag entry withflag,perc, optionalfiltersanddata. Bump theversionnumber.redisinsight/api/src/modules/feature/constants/index.tsAdd to theKnownFeaturesenum.redisinsight/api/src/modules/feature/constants/known-features.tsAdd entry to theknownFeaturesrecord withnameandstorage(usuallyFeatureStorage.Database).redisinsight/api/src/modules/feature/providers/feature-flag/feature-flag.provider.tsRegister the flag with its strategy (see Strategy Types below).
Frontend (required if the flag gates UI)
redisinsight/ui/src/constants/featureFlags.tsAdd to theFeatureFlagsenum.redisinsight/ui/src/slices/app/features.tsAdd default state entry ininitialState.featureFlags.featureswith{ flag: false }.
Consuming code
- Use the flag in components/hooks to gate functionality.
Strategy Selection
Choose the strategy based on what the flag needs:
CommonFlagStrategy → Most flags (dev and regular on/off)
WithDataFlagStrategy → Flag needs to carry extra data payload
SwitchableFlagStrategy → Flag should be overridable via local config.json
Register in feature-flag.provider.ts:
this.strategies.set(
KnownFeatures.YourFeature,
new CommonFlagStrategy(this.featuresConfigService, this.settingsService),
);
Config JSON Structure
Minimal (dev flag)
"dev-myFeature": {
"flag": false,
"perc": [[0, 100]]
}
With filters (Electron-only)
"myFeature": {
"flag": true,
"perc": [[0, 100]],
"filters": [
{ "name": "config.server.buildType", "value": "ELECTRON", "cond": "eq" }
]
}
Gradual rollout (10% of users)
"myFeature": {
"flag": true,
"perc": [[0, 10]]
}
With data payload
"myFeature": {
"flag": true,
"perc": [[0, 100]],
"data": { "strategy": "ioredis" }
}
Filter Conditions
Filters compare a value from server state against the filter value.
| Condition | Meaning |
|---|---|
eq |
equals |
neq |
not equals |
gt / gte |
greater than / greater or equal |
lt / lte |
less than / less or equal |
Common name paths: config.server.buildType (ELECTRON, DOCKER_ON_PREMISE, REDIS_STACK), config.server.packageVersion (uses semver), agreements.analytics, env.<VAR_NAME>.
Filters support and/or composition for complex conditions.
Workflows
Add a dev feature flag
Use for features under active development that should not be visible in production.
features-config.json→ add"dev-myFeature": { "flag": false, "perc": [[0, 100]] }constants/index.ts→ addDevMyFeature = 'dev-myFeature'toKnownFeaturesconstants/known-features.ts→ add record entryfeature-flag.provider.ts→ register withCommonFlagStrategyui/src/constants/featureFlags.ts→ adddevMyFeature = 'dev-myFeature'ui/src/slices/app/features.ts→ add default{ flag: false }
Promote dev flag to regular flag
When the feature is complete and ready for rollout.
- Rename
dev-myFeature→myFeaturein all the files above - Set
flag: trueinfeatures-config.json - Optionally set
percfor gradual rollout (e.g.[[0, 10]]) - Change strategy if needed (e.g. to
SwitchableFlagStrategyfor overridable) - Bump config
version
Clean up a flag
When a feature is fully rolled out and the flag is no longer needed.
- Remove from
features-config.json - Remove from
KnownFeaturesenum - Remove from
knownFeaturesrecord - Remove strategy registration from
feature-flag.provider.ts - Remove from FE
FeatureFlagsenum - Remove default state from
features.ts - Remove all gating code (conditionals,
FeatureFlagComponentwrappers) in consuming components
FE Usage Patterns
Check flag in a component
import { FeatureFlags } from 'uiSrc/constants';
import { appFeatureFlagsFeaturesSelector } from 'uiSrc/slices/app/features';
const features = useSelector(appFeatureFlagsFeaturesSelector);
const isEnabled = features[FeatureFlags.myFeature]?.flag;
Custom selector for complex logic
export const isMyFeatureEnabledSelector = (state: RootState): boolean => {
const features = state.app.features.featureFlags.features;
return features[FeatureFlags.myFeature]?.flag ?? false;
};