Importing
DevCycle Feature Importer
DevCycle's Feature Importer is designed to import resources from other feature flag providers. The importer is intended to be run on a single project and will create or update a project with the same key containing Environments, Features, and Variables.
The feature importer script is fully open-source. Check it out here: https://github.com/devcyclehq/feature-importer
Table of Contents
Setup
- Clone repo from here
- Run
npm install
to install dependencies - Setup configuration file
- Run
npm start
to start an import
Configuration
The feature importer can be configured using environment variables or a JSON config file.
By default the config is read from config.json
in the project root, this can be overwritten using CONFIG_FILE_PATH
.
Required
- ldAccessToken: string
- LaunchDarkly access token. Used for pulling feature flags.
- Equivalent env var:
LD_ACCESS_TOKEN
- dvcClientId: string
- DevCycle client ID. Used for fetching API credentials.
- Equivalent env var:
DVC_CLIENT_ID
- dvcClientSecret: string
- DevCycle client secret. Used for fetching API credentials.
- Equivalent env var:
DVC_CLIENT_SECRET
- sourceProjectKey: string
- LaunchDarkly's project key. Resources will be pulled from this project.
- Equivalent env var:
SOURCE_PROJECT_KEY
Optional
- targetProjectKey: string
- A DevCycle project key. Resources will be created within this project. A project will be created with this key if it does not already exist.
- If not specified, the target project key will be used
- Equivalent env var: TARGET_PROJECT_KEY
- includeFeatures:
string[]
- An array of LD feature flag keys to be imported. By default, the importer will attempt to migrate all features.
- Equivalent env var:
INCLUDE_FEATURES
- excludeFeatures: string[]
- An array of LD feature flag keys to be skipped when importing.
- Equivalent env var:
EXCLUDE_FEATURES
- overwriteDuplicates: boolean
- If true, when the importer encounters a duplicate resource it will be overwritten. By default, duplicates will be skipped.
- Equivalent env var:
OVERWRITE_DUPLICATES
- operationMap: Map<string, string>
- A map of LD operations to map to DevCycle operations
- DevCycle operations:
=
,!=
,>
,<
,>=
,<=
,contain
,!contain
,exist
,!exist
- Equivalent env var: OPERATION_MAP
Sample config.json
{
"ldAccessToken": "api-key",
"dvcClientId": "clientId",
"dvcClientSecret": "clientSecret",
"sourceProjectKey": "project-key",
"includeFeatures": ["feat-1", "feat-2"],
"excludeFeatures": [],
"overwriteDuplicates": false,
"operationMap": {
"startsWith": "contain",
"endsWith": "contain"
}
}
Sample .env file
LD_ACCESS_TOKEN="api-key"
DVC_CLIENT_ID="clientId"
DVC_CLIENT_SECRET="clientSecret"
SOURCE_PROJECT_KEY="project-key"
INCLUDE_FEATURES=[feat-1,feat-2]
EXCLUDE_FEATURES=[]
OVERWRITE_DUPLICATES=false
OPERATION_MAP='{"endsWith":"contain","startsWith":"contain"}'
Code Migration
Migrating Code from LaunchDarkly
- In LaunchDarkly, the primary identifier is
key
, in DVC the equivalent value should be passed asuser_id
- DVC supports the following top-level properties on the user object: see DVC User Object.
Any other properties used for targeting should be passed within the
customData
map. - If you are passing a date to be used with LD's before/after operators, the value should be converted to a Long when passed to DVC. The importer will convert
before
&after
operators to<
&>
in DVC. - DVC doesn't support targeting by the top-level
isAnonymous
property. If you are using LD's targeting with theanonymous
attribute, make sure to include ananonymous
property in the user'scustomData
Contributing to DevCycle or creating a new Integration:
If you would like to contribute to an existing integration or tool, all of DevCycle's tools and integrations are open source on the DevCycle github repository.
Further, if you'd like to create a new tool or integration, a great starting point is DevCycle's Management API which allows you to modify and interact with features and more within a devcycle project, as well as the DevCycle Bucketing API which is used to give users features and variables (as used within the DevCycle SDKs!)