mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-06 00:07:44 +01:00
157 lines
6.2 KiB
TypeScript
157 lines
6.2 KiB
TypeScript
|
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 thefeature'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',
|
||
|
enum: ['json', 'csv', '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
|
||
|
>;
|