POST
/
console
/
v1
/
dynamic_configs
curl --request POST \
  --url https://statsigapi.net/console/v1/dynamic_configs \
  --header 'Content-Type: application/json' \
  --header 'STATSIG-API-KEY: <api-key>' \
  --data '{
  "isEnabled": true,
  "description": "<string>",
  "rules": [
    {
      "name": "<string>",
      "passPercentage": 50,
      "conditions": [
        {
          "targetValue": [
            "<string>"
          ],
          "operator": "<string>",
          "field": "<string>",
          "customID": "<string>",
          "type": "app_version"
        }
      ],
      "environments": [
        "<string>"
      ],
      "id": "<string>",
      "baseID": "<string>",
      "returnValue": {},
      "returnValueJson5": "<string>"
    }
  ],
  "defaultValue": {},
  "defaultValueJson5": "<string>",
  "idType": "userID",
  "tags": [
    "<string>"
  ],
  "creatorID": "<string>",
  "owner": {
    "ownerID": "user123",
    "ownerType": "USER",
    "ownerName": "John Doe",
    "ownerEmail": "owner123@test.com"
  },
  "creatorEmail": "<string>",
  "schema": "<string>",
  "schemaJson5": "<string>",
  "targetApps": "<string>",
  "team": "<string>",
  "teamID": "<string>",
  "precommitWebhook": {
    "url": "<string>",
    "internalStatusUrl": "<string>"
  },
  "name": "<string>",
  "id": "<string>"
}'
{
  "message": "Dynamic Config created successfully.",
  "data": {
    "id": "a_dynamic_config",
    "name": "a dynamic config",
    "description": "helpful summary of what this dynamic config does",
    "idType": "userID",
    "lastModifierID": "1vaQaBoLlkauH9iiuOSBP2",
    "lastModifiedTime": 1707344887865,
    "lastModifierName": "CONSOLE API",
    "lastModifierEmail": null,
    "creatorID": "1vaQaBoLlkauH9iiuOSBP2",
    "createdTime": 1707344887764,
    "creatorName": "CONSOLE API",
    "creatorEmail": null,
    "targetApps": [],
    "holdoutIDs": [],
    "tags": [],
    "isEnabled": true,
    "rules": [],
    "defaultValue": {}
  }
}

Authorizations

STATSIG-API-KEY
string
header
required

Headers

x-respect-review-settings
string

Optional header to respect review settings for mutation endpoints.

Body

application/json
name
string
required
Required string length: 3 - 100
isEnabled
boolean
default:true

Is the dynamic config enabled

description
string
Maximum length: 1000
rules
object[]

An array of Rule objects

defaultValue
object

The fallback JSON object when no rules are triggered

defaultValueJson5
string

Can include comments. If provided with defaultValue, must parse to the same JSON

idType
string

The type of ID which the dynamic config is based on.

Example:

"userID"

tags
string[]

The list of tag names attached to the dynamic config

creatorID
string | null
owner
object | null

Schema for owner data including ID, type, name. Note that if Entity is created by CONSOLE API, owner will be undefined.

Example:
{
  "ownerID": "user123",
  "ownerType": "USER",
  "ownerName": "John Doe",
  "ownerEmail": "owner123@test.com"
}
creatorEmail
string | null
schema
string | null

A schema using JSON Schema Draft 2020-12 to enforce return values of this dynamic config's rules.

schemaJson5
string | null

schema except with Json5 comments. Optional and should parse to same json as schema.

targetApps
team
string | null

The team name associated with the dynamic config, Enterprise only.

teamID
string | null

The team ID associated with the dynamic config, Enterprise only.

precommitWebhook
object | null
id
string
Required string length: 3 - 100

Response

200
application/json
Create gate response
message
string
required

A simple string explaining the result of the operation.

data
object
required

A single result.