1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-31 00:16:47 +01:00
unleash.unleash/src/lib/openapi/spec/variant-schema.ts
andreas-unleash 1cd0edb11a
feat: variant with number payload (#4654)
Adds `number` as possible payload type for variant.
Adds a flag to enable the feature
Updates all relevant models and schemas
Adds the option to the UI

Closes: #
[1-1357](https://linear.app/unleash/issue/1-1357/support-number-in-variant-payload)

---------

Signed-off-by: andreas-unleash <andreas@getunleash.ai>
2023-09-11 16:57:42 +03:00

72 lines
3.0 KiB
TypeScript

import { FromSchema } from 'json-schema-to-ts';
import { overrideSchema } from './override-schema';
export const variantSchema = {
$id: '#/components/schemas/variantSchema',
type: 'object',
additionalProperties: false,
description:
'A variant allows for further separation of users into segments. See [our excellent documentation](https://docs.getunleash.io/reference/feature-toggle-variants#what-are-variants) for a more detailed description',
required: ['name', 'weight'],
properties: {
name: {
type: 'string',
description: 'The variants name. Is unique for this feature toggle',
example: 'blue_group',
},
weight: {
type: 'number',
description:
'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](https://docs.getunleash.io/reference/feature-toggle-variants#variant-weight) for more information',
minimum: 0,
maximum: 1000,
},
weightType: {
description:
'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',
type: 'string',
example: 'variable',
enum: ['variable', 'fix'],
},
stickiness: {
type: 'string',
description:
'[Stickiness](https://docs.getunleash.io/reference/feature-toggle-variants#variant-stickiness) is how Unleash guarantees that the same user gets the same variant every time',
example: 'custom.context.field',
},
payload: {
type: 'object',
required: ['type', 'value'],
description: 'Extra data configured for this variant',
additionalProperties: false,
properties: {
type: {
description:
'The type of the value. Commonly used types are string, number, json and csv.',
type: 'string',
enum: ['json', 'csv', 'string', 'number'],
},
value: {
description: 'The actual value of payload',
type: 'string',
},
},
example: { type: 'json', value: '{"color": "red"}' },
},
overrides: {
description: `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.`,
type: 'array',
items: {
$ref: '#/components/schemas/overrideSchema',
},
},
},
components: {
schemas: {
overrideSchema,
},
},
} as const;
export type VariantSchema = FromSchema<typeof variantSchema>;