Get a health report for a project.
GET /api/admin/projects/:projectId/health-report
This endpoint returns a health report for the specified project. This data is used for the technical debt dashboard
Request
Path Parameters
- projectId string required
- 200
- 401
- 403
- 404
healthReportSchema
- application/json
- Schema
- Example (from schema)
Schema
- version integer required
The project overview version.
- name string required
The project's name
- description string nullable
The project's description
- defaultStickiness string required
A default stickiness for the project affecting the default stickiness value for variants and Gradual Rollout strategy
- mode string required
Possible values: [
open
,protected
,private
]The project's collaboration mode. Determines whether non-project members can submit change requests or not.
- featureLimit number nullable
A limit on the number of features allowed in the project. Null if no limit.
- members integer required
The number of users/members in the project.
- health integer required
The overall health rating of the project.
environments object[]required
An array containing the names of all the environments configured for the project.
Array [environment string requiredThe environment to add to the project
changeRequestsEnabled booleanWhether change requests should be enabled or for this environment on the project or not
defaultStrategy object
A default strategy to create for this environment on the project.
name string requiredThe name of the strategy type
title string nullableA descriptive title for the strategy
disabled boolean nullableA toggle to disable the strategy. defaults to false. Disabled strategies are not evaluated or returned to the SDKs
sortOrder numberThe order of the strategy in the list
constraints object[]
A list of the constraints attached to the strategy. See https://docs.getunleash.io/reference/strategy-constraints
Array [contextName string requiredThe name of the context field that this constraint should apply to.
operator string requiredPossible values: [
NOT_IN
,IN
,STR_ENDS_WITH
,STR_STARTS_WITH
,STR_CONTAINS
,NUM_EQ
,NUM_GT
,NUM_GTE
,NUM_LT
,NUM_LTE
,DATE_AFTER
,DATE_BEFORE
,SEMVER_EQ
,SEMVER_GT
,SEMVER_LT
]The operator to use when evaluating this constraint. For more information about the various operators, refer to the strategy constraint operator documentation.
caseInsensitive booleanDefault value:
false
Whether the operator should be case sensitive or not. Defaults to
false
(being case sensitive).inverted booleanDefault value:
false
Whether the result should be negated or not. If
true
, will turn atrue
result into afalse
result and vice versa.values string[]The context values that should be used for constraint evaluation. Use this property instead of
value
for properties that accept multiple values.value stringThe context value that should be used for constraint evaluation. Use this property instead of
values
for properties that only accept single values.]variants object[]
Strategy level variants
Array [name string requiredThe variant name. Must be unique for this feature toggle
weight integer requiredPossible values:
<= 1000
The weight is the likelihood of any one user getting this variant. It is an integer between 0 and 1000. See the section on variant weights for more information
weightType string requiredPossible values: [
variable
,fix
]Set to
fix
if this variant must have exactly the weight allocated to it. If the type isvariable
, the weight will adjust so that the total weight of all variants adds up to 1000. Refer to the variant weight documentation.stickiness string requiredThe stickiness to use for distribution of this variant. Stickiness is how Unleash guarantees that the same user gets the same variant every time
payload object
Extra data configured for this variant
type string requiredPossible values: [
json
,csv
,string
,number
]The type of the value. Commonly used types are string, number, json and csv.
value string requiredThe actual value of payload
]parameters object
A list of parameters for a strategy
property name* stringsegments number[]Ids of segments to use for this strategy
]features object[]required
An array containing an overview of all the features of the project and their individual status
Array [name string requiredUnique feature name
type stringType of the toggle e.g. experiment, kill-switch, release, operational, permission
description string nullableDetailed description of the feature
archived booleantrue
if the feature is archivedproject stringName of the project the feature belongs to
enabled booleantrue
if the feature is enabled, otherwisefalse
.stale booleantrue
if the feature is stale based on the age and feature type, otherwisefalse
.favorite booleantrue
if the feature was favorited, otherwisefalse
.impressionData booleantrue
if the impression data collection is enabled for the feature, otherwisefalse
.createdAt date-time nullableThe date the feature was created
archivedAt date-time nullableThe date the feature was archived
lastSeenAt date-time nullable deprecatedThe date when metrics where last collected for the feature. This field is deprecated, use the one in featureEnvironmentSchema
environments object[]
The list of environments where the feature can be used
Array [name string requiredThe name of the environment
featureName stringThe name of the feature
environment stringThe name of the environment
type stringThe type of the environment
enabled boolean requiredtrue
if the feature is enabled for the environment, otherwisefalse
.sortOrder numberThe sort order of the feature environment in the feature environments list
variantCount numberThe number of defined variants
strategies object[]
A list of activation strategies for the feature environment
Array [id stringA uuid for the feature strategy
name string requiredThe name or type of strategy
title string nullableA descriptive title for the strategy
disabled boolean nullableA toggle to disable the strategy. defaults to false. Disabled strategies are not evaluated or returned to the SDKs
featureName stringThe name or feature the strategy is attached to
sortOrder numberThe order of the strategy in the list
segments number[]A list of segment ids attached to the strategy
constraints object[]
A list of the constraints attached to the strategy. See https://docs.getunleash.io/reference/strategy-constraints
Array [contextName string requiredThe name of the context field that this constraint should apply to.
operator string requiredPossible values: [
NOT_IN
,IN
,STR_ENDS_WITH
,STR_STARTS_WITH
,STR_CONTAINS
,NUM_EQ
,NUM_GT
,NUM_GTE
,NUM_LT
,NUM_LTE
,DATE_AFTER
,DATE_BEFORE
,SEMVER_EQ
,SEMVER_GT
,SEMVER_LT
]The operator to use when evaluating this constraint. For more information about the various operators, refer to the strategy constraint operator documentation.
caseInsensitive booleanDefault value:
false
Whether the operator should be case sensitive or not. Defaults to
false
(being case sensitive).inverted booleanDefault value:
false
Whether the result should be negated or not. If
true
, will turn atrue
result into afalse
result and vice versa.values string[]The context values that should be used for constraint evaluation. Use this property instead of
value
for properties that accept multiple values.value stringThe context value that should be used for constraint evaluation. Use this property instead of
values
for properties that only accept single values.]variants object[]
Strategy level variants
Array [name string requiredThe variant name. Must be unique for this feature toggle
weight integer requiredPossible values:
<= 1000
The weight is the likelihood of any one user getting this variant. It is an integer between 0 and 1000. See the section on variant weights for more information
weightType string requiredPossible values: [
variable
,fix
]Set to
fix
if this variant must have exactly the weight allocated to it. If the type isvariable
, the weight will adjust so that the total weight of all variants adds up to 1000. Refer to the variant weight documentation.stickiness string requiredThe stickiness to use for distribution of this variant. Stickiness is how Unleash guarantees that the same user gets the same variant every time
payload object
Extra data configured for this variant
type string requiredPossible values: [
json
,csv
,string
,number
]The type of the value. Commonly used types are string, number, json and csv.
value string requiredThe actual value of payload
]parameters object
A list of parameters for a strategy
property name* string]variants object[]
A list of variants for the feature environment
Array [name string requiredThe variants name. Is unique for this feature toggle
weight number requiredPossible values:
<= 1000
The weight is the likelihood of any one user getting this variant. It is a number between 0 and 1000. See the section on variant weights for more information
weightType stringPossible values: [
variable
,fix
]Set to fix if this variant must have exactly the weight allocated to it. If the type is variable, the weight will adjust so that the total weight of all variants adds up to 1000
stickiness stringStickiness is how Unleash guarantees that the same user gets the same variant every time
payload object
Extra data configured for this variant
type string requiredPossible values: [
json
,csv
,string
,number
]The type of the value. Commonly used types are string, number, json and csv.
value string requiredThe actual value of payload
overrides object[]
Overrides assigning specific variants to specific users. The weighting system automatically assigns users to specific groups for you, but any overrides in this list will take precedence.
Array [contextName string requiredThe name of the context field used to determine overrides
values string[] requiredWhich values that should be overriden
]]lastSeenAt date-time nullableThe date when metrics where last collected for the feature environment
hasStrategies booleanWhether the feature has any strategies defined.
hasEnabledStrategies booleanWhether the feature has any enabled strategies defined.
]variants object[]deprecated
The list of feature variants
Array [name string requiredThe variants name. Is unique for this feature toggle
weight number requiredPossible values:
<= 1000
The weight is the likelihood of any one user getting this variant. It is a number between 0 and 1000. See the section on variant weights for more information
weightType stringPossible values: [
variable
,fix
]Set to fix if this variant must have exactly the weight allocated to it. If the type is variable, the weight will adjust so that the total weight of all variants adds up to 1000
stickiness stringStickiness is how Unleash guarantees that the same user gets the same variant every time
payload object
Extra data configured for this variant
type string requiredPossible values: [
json
,csv
,string
,number
]The type of the value. Commonly used types are string, number, json and csv.
value string requiredThe actual value of payload
overrides object[]
Overrides assigning specific variants to specific users. The weighting system automatically assigns users to specific groups for you, but any overrides in this list will take precedence.
Array [contextName string requiredThe name of the context field used to determine overrides
values string[] requiredWhich values that should be overriden
]]strategies object[] deprecatedThis is a legacy field that will be deprecated
tags object[]nullable
The list of feature tags
Array [value string requiredPossible values:
>= 2 characters
and<= 50 characters
The value of the tag
type string requiredPossible values:
>= 2 characters
and<= 50 characters
Default value:
simple
The type of the tag
]children string[]The list of child feature names. This is an experimental field and may change.
dependencies object[]
The list of parent dependencies. This is an experimental field and may change.
Array [feature string requiredThe name of the parent feature
enabled booleanWhether the parent feature is enabled or not
variants string[]The list of variants the parent feature should resolve to. Only valid when feature is enabled.
]]- updatedAt date-time nullable
When the project was last updated.
- createdAt date-time nullable
When the project was last updated.
- favorite boolean
Indicates if the project has been marked as a favorite by the current user requesting the project health overview.
stats object
Project statistics
avgTimeToProdCurrentWindow number requiredThe average time from when a feature was created to when it was enabled in the "production" environment during the current window
createdCurrentWindow number requiredThe number of feature toggles created during the current window
createdPastWindow number requiredThe number of feature toggles created during the previous window
archivedCurrentWindow number requiredThe number of feature toggles that were archived during the current window
archivedPastWindow number requiredThe number of feature toggles that were archived during the previous window
projectActivityCurrentWindow number requiredThe number of project events that occurred during the current window
projectActivityPastWindow number requiredThe number of project events that occurred during the previous window
projectMembersAddedCurrentWindow number requiredThe number of members that were added to the project during the current window
featureNaming object
Create a feature naming pattern
pattern string nullable requiredA JavaScript regular expression pattern, without the start and end delimiters. Optional flags are not allowed.
example string nullableAn example of a feature name that matches the pattern. Must itself match the pattern supplied.
description string nullableA description of the pattern in a human-readable format. Will be shown to users when they create a new feature flag.
- potentiallyStaleCount number required
The number of potentially stale feature toggles.
- activeCount number required
The number of active feature toggles.
- staleCount number required
The number of stale feature toggles.
{
"version": 1,
"name": "enterprisegrowth",
"description": "The project for all things enterprisegrowth",
"defaultStickiness": "userId",
"mode": "open",
"featureLimit": 100,
"members": 5,
"health": 95,
"environments": [
{
"environment": "development",
"changeRequestsEnabled": true,
"defaultStrategy": {
"name": "flexibleRollout",
"title": "Gradual Rollout 25-Prod",
"disabled": false,
"sortOrder": 9999,
"constraints": [
{
"values": [
"1",
"2"
],
"inverted": false,
"operator": "IN",
"contextName": "appName",
"caseInsensitive": false
}
],
"variants": [
{
"name": "blue_group",
"weight": 0,
"weightType": "fix",
"stickiness": "custom.context.field",
"payload": {
"type": "json",
"value": "{\"color\": \"red\"}"
}
}
],
"parameters": {
"groupId": "some_new",
"rollout": "25",
"stickiness": "sessionId"
},
"segments": [
1,
2
]
}
}
],
"features": [
{
"name": "disable-comments",
"type": "kill-switch",
"description": "Controls disabling of the comments section in case of an incident",
"archived": true,
"project": "dx-squad",
"enabled": true,
"stale": false,
"favorite": true,
"impressionData": false,
"createdAt": "2023-01-28T15:21:39.975Z",
"archivedAt": "2023-01-29T15:21:39.975Z",
"environments": [
{
"name": "my-dev-env",
"featureName": "disable-comments",
"environment": "development",
"type": "development",
"enabled": true,
"sortOrder": 3,
"variantCount": 0,
"strategies": [
{
"id": "6b5157cb-343a-41e7-bfa3-7b4ec3044840",
"name": "flexibleRollout",
"title": "Gradual Rollout 25-Prod",
"disabled": false,
"featureName": "myAwesomeFeature",
"sortOrder": 9999,
"segments": [
1,
2
],
"constraints": [
{
"contextName": "appName",
"operator": "IN",
"caseInsensitive": false,
"inverted": false,
"values": [
"my-app",
"my-other-app"
],
"value": "my-app"
}
],
"variants": [
{
"name": "blue_group",
"weight": 0,
"weightType": "fix",
"stickiness": "custom.context.field",
"payload": {
"type": "json",
"value": "{\"color\": \"red\"}"
}
}
],
"parameters": {}
}
],
"variants": [
{
"name": "blue_group",
"weight": 0,
"weightType": "variable",
"stickiness": "custom.context.field",
"payload": {
"type": "json",
"value": "{\"color\": \"red\"}"
},
"overrides": [
{
"contextName": "userId",
"values": [
"red",
"blue"
]
}
]
}
],
"lastSeenAt": "2023-01-28T16:21:39.975Z",
"hasStrategies": true,
"hasEnabledStrategies": true
}
],
"tags": [
{
"value": "a-tag-value",
"type": "simple"
}
],
"children": [
"some-feature"
],
"dependencies": [
{
"feature": "some-feature",
"enabled": true,
"variants": [
"some-feature-blue-variant"
]
}
]
}
],
"updatedAt": "2023-04-19T08:15:14.000Z",
"createdAt": "2023-04-19T08:15:14.000Z",
"favorite": true,
"stats": {
"avgTimeToProdCurrentWindow": 10,
"createdCurrentWindow": 15,
"createdPastWindow": 15,
"archivedCurrentWindow": 5,
"archivedPastWindow": 5,
"projectActivityCurrentWindow": 100,
"projectActivityPastWindow": 100,
"projectMembersAddedCurrentWindow": 1
},
"featureNaming": {
"pattern": "^[A-Za-z]+\\.[A-Za-z]+\\.[A-Za-z0-9-]+$",
"example": "dx.feature1.1-135",
"description": "<project>.<featureName>.<ticket>\n\nThe flag name should contain the project name, the feature name, and the ticket number, each separated by a dot."
},
"potentiallyStaleCount": 5,
"activeCount": 2,
"staleCount": 10
}
Authorization information is missing or invalid. Provide a valid API token as the authorization
header, e.g. authorization:*.*.my-admin-token
.
- application/json
- Schema
- Example (from schema)
Schema
- id string
The ID of the error instance
- name string
The name of the error kind
- message string
A description of what went wrong.
{
"id": "9c40958a-daac-400e-98fb-3bb438567008",
"name": "AuthenticationRequired",
"message": "You must log in to use Unleash. Your request had no authorization header, so we could not authorize you. Try logging in at /auth/simple/login."
}
The provided user credentials are valid, but the user does not have the necessary permissions to perform this operation
- application/json
- Schema
- Example (from schema)
Schema
- id string
The ID of the error instance
- name string
The name of the error kind
- message string
A description of what went wrong.
{
"id": "9c40958a-daac-400e-98fb-3bb438567008",
"name": "NoAccessError",
"message": "You need the \"UPDATE_ADDON\" permission to perform this action in the \"development\" environment."
}
The requested resource was not found.
- application/json
- Schema
- Example (from schema)
Schema
- id string
The ID of the error instance
- name string
The name of the error kind
- message string
A description of what went wrong.
{
"id": "9c40958a-daac-400e-98fb-3bb438567008",
"name": "NotFoundError",
"message": "Could not find the addon with ID \"12345\"."
}