HTTP API
Console API
Alerts
Audit Logs
Autotunes
Company
Dynamic Configs
- GETList Dynamic Configs
- POSTCreate Dynamic Config
- GETGet Dynamic Config
- POSTFully Update Dynamic Config
- DELDelete Dynamic Config
- PATCHPartially Update Dynamic Config
- PUTDisable Dynamic Config
- PUTEnable Dynamic Config
- POSTAdd Dynamic Config Rule
- GETGet Specific Dynamic Config Rule
- DELDelete Dynamic Config Rule
- PATCHUpdate Dynamic Config Rule By Id
- DELDelete Dynamic Config Rule By Name
- PATCHUpdate Dynamic Config Rule By Name
- GETGet Dynamic Config Rules
- POSTAdd Dynamic Config Rules
- PATCHUpdate List of Dynamic Config Rules
- GETList Dynamic Config Versions
Experiments
- GETList Experiments
- POSTCreate Experiment
- GETGet Experiment
- POSTFully Update Experiment
- DELDeleted Experiment
- PATCHPartially Update Experiment
- PUTAbandon Experiment
- PUTArchive Experiment
- GETRetrieve cumulative exposures
- POSTDisable Experiment Groups
- POSTEnable Experiment Groups
- PUTFinish Experiment Early
- GETGet Experiment Overrides
- POSTUpdate Experiment Overrides
- DELDelete Experiment Overrides
- PATCHPartially Update Experiment Overrides
- GETRetrieve Pulse Results (Beta)
- PUTReset Experiment
- PUTStart Experiment
- PUTUnarchive Experiment
Experiments (Warehouse Native)
- POSTLoad Pulse (Warehouse Native)
- GETPulse Load History (Warehouse Native)
- POSTPost Assignment Source
- DELDelete Assignment Source
- PATCHPatch Assignment Source
- GETList Assignment Sources
- POSTCreate Assignment Source
- GETList Entity Property Sources
- POSTCreate Entity Property Source
- GETGet Entity Property Source
- POSTPost Entity Property Source
- DELDelete Entity Property Source
- PATCHPatch Entity Property Source
Configs
Gates
- GETList Gates
- POSTCreate Gate
- GETRead Gate
- POSTFully Update Gates
- DELDelete Gates
- PATCHPartially Update Gates
- PUTArchive Gate
- PUTDisable Gate
- PUTEnable Gate
- PUTLaunch Gate
- POSTLoad Pulse Gate
- GETGet Gate Override
- POSTUpdate Gate Overrides
- DELDelete Gate Overrides
- PATCHAdd Gate Overrides
- POSTAdd Gate Rule
- GETRead Gate Rules
- POSTAdd Multiple Gate Rule
- PATCHUpdate list of current Gate Rules settings
- DELDelete Gate Rule
- PATCHUpdate Gate Rules
- GETPulse Load History (Warehouse Native)
- GETRetrieve Pulse Results (Beta)
- GETList Gate Versions
Holdouts
Ingestions
- GETRead Ingestion
- POSTCreate Ingestion Source
- DELDelete Ingestion Source
- PATCHUpdate Ingestion Source
- POSTBackfill Ingestion
- POSTCreate Ingestion Databricks
- GETGet Ingestion Event Count
- GETGet Ingestion Event Delta Ledger
- GETList Ingestion Runs
- GETRead Ingestion Run
- GETRead Ingestion Schedule
- POSTUpdate Ingestion Schedule
- GETList Ingestions Status
Keys
Layers
Metrics
Metrics (Warehouse Native)
Project
Reports
Segments
Target App
Users
- GETList Users
- GETGet user by email
- POSTUpdate user
- POSTInvite user. To avoid spamming, invitation emails are not sent. Invitee will see invitation notification in-app after logging in.
- GETList Teams
- POSTCreate Team
- GETGet Team
- DELDelete Team
- PATCHUpdate Team. Ops: Replace. Use GET for current data if you intent to Add.
List Experiments
curl --request GET \
--url https://statsigapi.net/console/v1/experiments \
--header 'STATSIG-API-KEY: <api-key>'
{
"message": "Experiments listed successfully.",
"data": [
{
"id": "a_experiment",
"name": "a_experiment",
"description": "description",
"idType": "userID",
"lastModifierID": "1vaQaBoLlkauH9iiuOSBP2",
"lastModifiedTime": 1707427635442,
"lastModifierName": "CONSOLE API",
"lastModifierEmail": null,
"creatorID": "1vaQaBoLlkauH9iiuOSBP2",
"createdTime": 1707427634717,
"creatorName": "CONSOLE API",
"creatorEmail": null,
"targetApps": [],
"holdoutIDs": [],
"tags": [],
"status": "setup",
"launchedGroupID": null,
"startTime": null,
"endTime": null,
"layerID": null,
"hypothesis": "This will be a good feature :)",
"primaryMetrics": [
{
"name": "d1_retention_rate",
"type": "user"
}
],
"primaryMetricTags": [],
"secondaryMetrics": [],
"secondaryMetricTags": [],
"groups": [
{
"name": "Control",
"id": "6sEQvUd4c6E55V6ljBYMeJ",
"size": 50,
"parameterValues": {
"assigned_group": "control"
},
"description": ""
},
{
"name": "Test",
"id": "6sEQvVS6EoNzpkEgUJUpxL",
"size": 50,
"parameterValues": {
"assigned_group": "test"
},
"description": ""
}
],
"allocation": 100,
"duration": 14,
"targetingGateID": "",
"defaultConfidenceInterval": "95",
"bonferroniCorrection": false,
"decisionReason": null,
"decisionTime": null,
"healthChecks": [],
"owner": {
"ownerType": "USER",
"ownerName": "Test User"
},
"inlineTargetingRulesJSON": "{}",
"healthCheckStatus": "PASSED"
},
{
"id": "b_experiment",
"name": "b experiment",
"description": "",
"idType": "userID",
"inlineTargetingRulesJSON": "{}",
"lastModifierID": "68ztZp2v2nFc81RAsvuvj4",
"lastModifiedTime": 1706744900374,
"lastModifierName": "jacob O'Quinn",
"lastModifierEmail": "jacob@statsig.com",
"creatorID": "68ztZp2v2nFc81RAsvuvj4",
"createdTime": 1678394676162,
"creatorName": "jacob O'Quinn",
"creatorEmail": "jacob@statsig.com",
"targetApps": [],
"holdoutIDs": [],
"tags": [
"customTag",
"asdf"
],
"status": "archived",
"launchedGroupID": null,
"startTime": null,
"endTime": null,
"layerID": null,
"hypothesis": "",
"primaryMetrics": [],
"primaryMetricTags": [],
"secondaryMetrics": [],
"secondaryMetricTags": [
"★ Core"
],
"groups": [
{
"name": "Control",
"id": "7dCnwm0by2laSOcBNKIL8r",
"size": 50,
"parameterValues": {
"control": "control value"
},
"description": ""
},
{
"name": "Test",
"id": "7dCnwnFe0kuFcdKxoSEort",
"size": 50,
"parameterValues": {
"control": "test value"
},
"description": ""
}
],
"allocation": 100,
"duration": 14,
"targetingGateID": "targeting_gate_to_select_users",
"defaultConfidenceInterval": "95",
"bonferroniCorrection": false,
"decisionReason": null,
"decisionTime": null,
"healthCheckStatus": "WAITING",
"healthChecks": [
{
"name": "Checks not yet detected",
"status": "WAITING",
"description": "This experiment has not recorded any exposure checks in production yet."
},
{
"name": "Valid unit type not yet verified",
"status": "WAITING",
"description": "Exposure checks for this experiment are pending evaluation. This experiment requires exposure checks with unit IDs of type userID"
},
{
"name": "Event metric data not yet verified",
"status": "WAITING",
"description": "This experiment has recorded no event metric with a valid unit ID yet, or these event metrics are pending evaluation. If you are importing events, this may take up to a day to reflect. This experiment requires metrics with unit IDs of type userID"
},
{
"name": "Pulse metrics not yet available",
"status": "WAITING",
"description": "Expect to see your Pulse Results within 24 hours. Statsig computes Pulse results on a daily basis."
},
{
"name": "Exposure balance not yet verified",
"status": "WAITING",
"description": "Exposure balance for this experiment is pending evaluation. As the experiment records more exposures, Statsig will continue to evaluate experiment exposure balance."
}
]
}
]
}
Authorizations
Headers
Optional header to respect review settings for mutation endpoints.
Query Parameters
Which layer to place the experiment into.
The idType the experiment will be performed on
The current status of the experiment
Name of the creator.
ID of the user who created the entity.
Filter by tags
Results per page
10
Page number
1
Response
A simple string explaining the result of the operation.
Array of results returned by pagination limit.
ID
A helpful summary of what this experiment does
1000
ID of the last modifier.
Time of the last modification.
Email of the last modifier.
Name of the last modifier.
Timestamp when the entity was created.
Name of the creator.
A statement that will be tested by this experiment
The test groups for your experiment
Percent of layer allocated to this experiment
0 <= x <= 100
Restrict your experiment to users passing the selected feature gate
Is Bonferroni correction applied per variant?
Default error margin used for results
80
, 90
, 95
, 98
, 99
The current status of the experiment
active
, setup
, decision_made
, abandoned
, archived
, experiment_stopped
, assignment_stopped
Overall health check status
PASSED
, FAILED
, WAITING
, WARNING
Optional name for the configuration.
The Statsig ID of the creator of this experiment
The email of the creator of this experiment
Target apps assigned to this experiment
Holdouts applied to this configuration.
The team name associated with the experiment, Enterprise only.
The team ID associated with the experiment, Enterprise only.
Version number
The secondary ID type for the experiment used in WHN for ID resolution
Optional control group ID
Primary metric tags for the experiment
Secondary metric tags for the experiment
How long the experiment is expected to last in days
x > 1
Target exposures for the experiment
x > 1
Apply sequential testing?
Is Bonferroni correction applied per metric?
Is Benjamini-Hochberg procedure applied per variant?
Is Benjamini-Hochberg procedure applied per metric?
Is Benjamini-Hochberg procedure applied for primary metrics only?
ID of the launched group, null otherwise
Name of the source experiment for assignment
Warehouse Native Only - Allocation duration in days
x > 1
Warehouse Native Only - Cohorted analysis duration in days
x > 1
Warehouse Native Only - Allow cohort metrics to mature after experiment end
Warehouse Native Only - Whether to filter to units whose experiment cohort analysis duration is complete, if cohortedAnalysisDuration exists
Fixed analysis duration in days
x > 1
Warehouse Native only - UTC hour at which to run scheduled pulse loads
0 <= x <= 23
Warehouse Native only - reload type for scheduled reloads
full
, incremental
Array of criteria for filtering assignment sources.
in
, not_in
, =
, >
, <
, >=
, <=
, is_null
, non_null
, contains
, not_contains
, sql_filter
, starts_with
, ends_with
, after_exposure
Column to filter on.
Optional array of values for the criterion to match against.
conversion
, reactivation
, retention
PASSED
, FAILED
, WAITING
, WARNING
has_checks
, has_valid_unit_type
, has_balanced_exposures
, has_event_metrics
, has_pulse_metrics
, assignment_health
, has_crossover
, has_exposures
, has_recent_exposures_for_analyze_whn
, user_metrics_exist
, deduplication_rate
, deduplication_rate_group_level
, windowed_metrics_have_outliers
, exposures_data_is_behind
, pre_experimental_bias_check
, segments_of_interest_analysis
, has_changed_parameter
, metric_history_for_topline_impact
, default_value_mismatch
Schema for owner data including ID, type, name. Note that if Entity is created by CONSOLE API, owner will be undefined.
ID of the owner
"abc123"
Type of the owner (e.g., SDK_KEY or USER)
"USER"
The name of the owner. This field is optional.
"John Doe"
The email of the owner. This field is optional.
{
"ownerID": "user123",
"ownerType": "USER",
"ownerName": "John Doe",
"ownerEmail": "owner123@test.com"
}
curl --request GET \
--url https://statsigapi.net/console/v1/experiments \
--header 'STATSIG-API-KEY: <api-key>'
{
"message": "Experiments listed successfully.",
"data": [
{
"id": "a_experiment",
"name": "a_experiment",
"description": "description",
"idType": "userID",
"lastModifierID": "1vaQaBoLlkauH9iiuOSBP2",
"lastModifiedTime": 1707427635442,
"lastModifierName": "CONSOLE API",
"lastModifierEmail": null,
"creatorID": "1vaQaBoLlkauH9iiuOSBP2",
"createdTime": 1707427634717,
"creatorName": "CONSOLE API",
"creatorEmail": null,
"targetApps": [],
"holdoutIDs": [],
"tags": [],
"status": "setup",
"launchedGroupID": null,
"startTime": null,
"endTime": null,
"layerID": null,
"hypothesis": "This will be a good feature :)",
"primaryMetrics": [
{
"name": "d1_retention_rate",
"type": "user"
}
],
"primaryMetricTags": [],
"secondaryMetrics": [],
"secondaryMetricTags": [],
"groups": [
{
"name": "Control",
"id": "6sEQvUd4c6E55V6ljBYMeJ",
"size": 50,
"parameterValues": {
"assigned_group": "control"
},
"description": ""
},
{
"name": "Test",
"id": "6sEQvVS6EoNzpkEgUJUpxL",
"size": 50,
"parameterValues": {
"assigned_group": "test"
},
"description": ""
}
],
"allocation": 100,
"duration": 14,
"targetingGateID": "",
"defaultConfidenceInterval": "95",
"bonferroniCorrection": false,
"decisionReason": null,
"decisionTime": null,
"healthChecks": [],
"owner": {
"ownerType": "USER",
"ownerName": "Test User"
},
"inlineTargetingRulesJSON": "{}",
"healthCheckStatus": "PASSED"
},
{
"id": "b_experiment",
"name": "b experiment",
"description": "",
"idType": "userID",
"inlineTargetingRulesJSON": "{}",
"lastModifierID": "68ztZp2v2nFc81RAsvuvj4",
"lastModifiedTime": 1706744900374,
"lastModifierName": "jacob O'Quinn",
"lastModifierEmail": "jacob@statsig.com",
"creatorID": "68ztZp2v2nFc81RAsvuvj4",
"createdTime": 1678394676162,
"creatorName": "jacob O'Quinn",
"creatorEmail": "jacob@statsig.com",
"targetApps": [],
"holdoutIDs": [],
"tags": [
"customTag",
"asdf"
],
"status": "archived",
"launchedGroupID": null,
"startTime": null,
"endTime": null,
"layerID": null,
"hypothesis": "",
"primaryMetrics": [],
"primaryMetricTags": [],
"secondaryMetrics": [],
"secondaryMetricTags": [
"★ Core"
],
"groups": [
{
"name": "Control",
"id": "7dCnwm0by2laSOcBNKIL8r",
"size": 50,
"parameterValues": {
"control": "control value"
},
"description": ""
},
{
"name": "Test",
"id": "7dCnwnFe0kuFcdKxoSEort",
"size": 50,
"parameterValues": {
"control": "test value"
},
"description": ""
}
],
"allocation": 100,
"duration": 14,
"targetingGateID": "targeting_gate_to_select_users",
"defaultConfidenceInterval": "95",
"bonferroniCorrection": false,
"decisionReason": null,
"decisionTime": null,
"healthCheckStatus": "WAITING",
"healthChecks": [
{
"name": "Checks not yet detected",
"status": "WAITING",
"description": "This experiment has not recorded any exposure checks in production yet."
},
{
"name": "Valid unit type not yet verified",
"status": "WAITING",
"description": "Exposure checks for this experiment are pending evaluation. This experiment requires exposure checks with unit IDs of type userID"
},
{
"name": "Event metric data not yet verified",
"status": "WAITING",
"description": "This experiment has recorded no event metric with a valid unit ID yet, or these event metrics are pending evaluation. If you are importing events, this may take up to a day to reflect. This experiment requires metrics with unit IDs of type userID"
},
{
"name": "Pulse metrics not yet available",
"status": "WAITING",
"description": "Expect to see your Pulse Results within 24 hours. Statsig computes Pulse results on a daily basis."
},
{
"name": "Exposure balance not yet verified",
"status": "WAITING",
"description": "Exposure balance for this experiment is pending evaluation. As the experiment records more exposures, Statsig will continue to evaluate experiment exposure balance."
}
]
}
]
}