Aliases may be generated to find indirect references to feature flags, such as flag keys stored in variables or wrapped SDK code. Once aliases are generated, ld-find-code-refs
will automatically scan for aliases in addition to flag keys, and surface them in the LaunchDarkly dashboard.
To generate aliases for your flag keys, you may use any combination of the patterns described below. Configuration types may be used in conjunction and defined more than once for comprehensive alias coverage.
Alias patterns are defined using a YAML file stored in your repository at .launchdarkly/coderefs.yaml
.
Don't do this:
var featureFlag = 'first-flag-key';
...
var featureFlag = 'second-flag-key';
Do this instead:
var firstFeatureFlag = 'first-flag-key'
...
var secondFeatureFlag = 'second-flag-key'
Aliases can be hardcoded using the literal
type. This is intended to be used for testing aliasing functionality.
Note that literal aliases are limited to flag keys using lowercase letters only, due to a limitation of a dependency LaunchDarkly uses to parse the configuration file. You can track the issue here.
Example hardcoding aliases for a couple flags:
aliases:
- type: literal
flags:
my-flag:
- myFlag
- isMyFlagOn
my-other-flag:
- other.flag.alias
Aliases can be generated using any of the following common naming conventions. For more robust patterns, see the other available options below this section.
Example flag key: AnyKind.of_key
Type | After |
---|---|
camelcase |
anyKind.ofKey |
pascalcase |
AnyKind.OfKey |
snakecase |
any_kind.of_key |
uppersnakecase |
ANY_KIND.OF_KEY |
kebabcase |
any-kind.of-key |
dotcase |
any.kind.of.key |
Example generating aliases in camelCase and PascalCase:
aliases:
- type: camelcase
- type: pascalcase
You can specify a number of files (paths
) using glob patterns to search. To achieve the best performance, be as specific as possible with your path globs to minimize the number of files searched for aliases.
You must also specify at least one regular expression (pattern
) containing a capture group to match aliases. The pattern must contain the the text FLAG_KEY
, which will be interpolated with flag keys.
Example matching all variable names storing flag keys of the form var ENABLE_WIDGETS = "enable-widgets"
in .go files do not end with _test
:
aliases:
- type: filepattern
paths:
- '*[!_test].go'
patterns:
- '(\w+) = "FLAG_KEY"'
For more control over your aliases, you can write a script to generate aliases. The script will receive a flag key as standard input. ld-find-code-refs
expects a valid JSON array of flag keys output to standard output.
Here's an example of a bash script which returns the the flag key as it's own alias:
aliases:
- type: command
command: ./.launchdarkly/flagAlias.sh # must be a valid shell command.
timeout: 5 # seconds
Contents of ./.launchdarkly/flagAlias.sh
:
#! /bin/sh
read flagKey <&0; echo "[\"$flagKey\"]"
If you are using a shell script, make sure that the file is executable.
For a new file:
git add --chmod=+x -- .launchdarkly/flagAlias.sh
For a file that has already been committed:
git update-index --chmod=+x .launchdarkly/flagAlias.sh
If you are using launchdarkly/gha-flags, your flag keys will not be wrapped in delimiters, so it is important to either configure the proper aliases or disable delimiters.
Example alias configuration:
// given flag key "enable-new-feature"
aliases:
- type: kebabcase
// given flag key "enable_new_feature"
aliases:
- type: snakecase
Example delimiter disable:
delimiters:
disableDefaults: true # will find keys without surrounding delimiters like ' or "