import { FromSchema } from 'json-schema-to-ts'; import { parametersSchema } from './parameters-schema'; import { variantSchema } from './variant-schema'; import { overrideSchema } from './override-schema'; import { playgroundStrategyEvaluation, playgroundStrategySchema, } from './playground-strategy-schema'; import { playgroundConstraintSchema } from './playground-constraint-schema'; import { playgroundSegmentSchema } from './playground-segment-schema'; import { sdkContextSchema } from './sdk-context-schema'; export const advancedPlaygroundEnvironmentFeatureSchema = { $id: '#/components/schemas/advancedPlaygroundEnvironmentFeatureSchema', description: 'A simplified feature toggle model intended for the Unleash playground.', type: 'object', additionalProperties: false, required: [ 'name', 'environment', 'context', 'projectId', 'isEnabled', 'isEnabledInCurrentEnvironment', 'variant', 'variants', 'strategies', ], properties: { name: { type: 'string', example: 'my-feature', description: "The feature's name.", }, environment: { type: 'string', example: 'development', description: "The feature's environment.", }, context: { description: 'The context to use when evaluating toggles', $ref: sdkContextSchema.$id, }, projectId: { type: 'string', example: 'my-project', description: 'The ID of the project that contains this feature.', }, strategies: { type: 'object', additionalProperties: false, required: ['result', 'data'], description: "Feature's applicable strategies and cumulative results of the strategies", properties: { result: { description: `The cumulative results of all the feature's strategies. Can be \`true\`, \`false\`, or \`${playgroundStrategyEvaluation.unknownResult}\`. This property will only be \`${playgroundStrategyEvaluation.unknownResult}\` if one or more of the strategies can't be fully evaluated and the rest of the strategies all resolve to \`false\`.`, anyOf: [ { type: 'boolean' }, { type: 'string', enum: [playgroundStrategyEvaluation.unknownResult], }, ], }, data: { description: 'The strategies that apply to this feature.', type: 'array', items: { $ref: playgroundStrategySchema.$id, }, }, }, }, isEnabledInCurrentEnvironment: { type: 'boolean', description: 'Whether the feature is active and would be evaluated in the provided environment in a normal SDK context.', }, isEnabled: { description: `Whether this feature is enabled or not in the current environment. If a feature can't be fully evaluated (that is, \`strategies.result\` is \`${playgroundStrategyEvaluation.unknownResult}\`), this will be \`false\` to align with how client SDKs treat unresolved feature states.`, type: 'boolean', example: true, }, variant: { description: `The feature variant you receive based on the provided context or the _disabled variant_. If a feature is disabled or doesn't have any variants, you would get the _disabled variant_. Otherwise, you'll get one of the feature's defined variants.`, type: 'object', additionalProperties: false, required: ['name', 'enabled'], properties: { name: { type: 'string', description: "The variant's name. If there is no variant or if the toggle is disabled, this will be `disabled`", example: 'red-variant', }, enabled: { type: 'boolean', description: "Whether the variant is enabled or not. If the feature is disabled or if it doesn't have variants, this property will be `false`", }, payload: { type: 'object', additionalProperties: false, required: ['type', 'value'], description: 'An optional payload attached to the variant.', properties: { type: { description: 'The format of the payload.', type: 'string', }, value: { type: 'string', description: 'The payload value stringified.', example: '{"property": "value"}', }, }, }, }, nullable: true, example: { name: 'green', enabled: true }, }, variants: { type: 'array', description: 'The feature variants.', items: { $ref: variantSchema.$id }, }, }, components: { schemas: { playgroundStrategySchema, playgroundConstraintSchema, playgroundSegmentSchema, parametersSchema, variantSchema, overrideSchema, sdkContextSchema, }, variants: { type: 'array', items: { $ref: variantSchema.$id } }, }, } as const; export type AdvancedPlaygroundEnvironmentFeatureSchema = FromSchema< typeof advancedPlaygroundEnvironmentFeatureSchema >;