2022-06-30 10:12:34 +02:00
|
|
|
import { FromSchema } from 'json-schema-to-ts';
|
|
|
|
import { tagSchema } from './tag-schema';
|
2023-07-06 10:57:09 +02:00
|
|
|
import { IEventTypes } from '../../types';
|
|
|
|
import { variantSchema } from './variant-schema';
|
2022-06-30 10:12:34 +02:00
|
|
|
|
2023-07-06 10:57:09 +02:00
|
|
|
const eventDataSchema = {
|
|
|
|
type: 'object',
|
2023-07-19 17:20:17 +02:00
|
|
|
nullable: true,
|
|
|
|
'x-enforcer-exception-skip-codes': 'WSCH006', // allow additional properties in example (openapi enforcer)
|
2023-07-06 10:57:09 +02:00
|
|
|
description:
|
|
|
|
'Extra associated data related to the event, such as feature toggle state, segment configuration, etc., if applicable.',
|
|
|
|
example: {
|
|
|
|
name: 'new-feature',
|
|
|
|
description: 'Toggle description',
|
|
|
|
type: 'release',
|
|
|
|
project: 'my-project',
|
|
|
|
stale: false,
|
|
|
|
variants: [],
|
|
|
|
createdAt: '2022-05-31T13:32:20.547Z',
|
|
|
|
lastSeenAt: null,
|
|
|
|
impressionData: true,
|
|
|
|
},
|
|
|
|
} as const;
|
2022-06-30 10:12:34 +02:00
|
|
|
export const eventSchema = {
|
|
|
|
$id: '#/components/schemas/eventSchema',
|
|
|
|
type: 'object',
|
|
|
|
additionalProperties: false,
|
|
|
|
required: ['id', 'createdAt', 'type', 'createdBy'],
|
2023-07-06 10:57:09 +02:00
|
|
|
description: 'An event describing something happening in the system',
|
2022-06-30 10:12:34 +02:00
|
|
|
properties: {
|
|
|
|
id: {
|
|
|
|
type: 'integer',
|
|
|
|
minimum: 1,
|
2023-07-06 10:57:09 +02:00
|
|
|
description: 'The ID of the event. An increasing natural number.',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
createdAt: {
|
|
|
|
type: 'string',
|
|
|
|
format: 'date-time',
|
2023-07-06 10:57:09 +02:00
|
|
|
description:
|
|
|
|
'The time the event happened as a RFC 3339-conformant timestamp.',
|
|
|
|
example: '2023-07-05T12:56:00.000Z',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
type: {
|
|
|
|
type: 'string',
|
2023-07-06 10:57:09 +02:00
|
|
|
description:
|
|
|
|
'What [type](https://docs.getunleash.io/reference/api/legacy/unleash/admin/events#event-type-description) of event this is',
|
|
|
|
enum: IEventTypes,
|
|
|
|
example: 'feature-created',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
createdBy: {
|
|
|
|
type: 'string',
|
2023-07-06 10:57:09 +02:00
|
|
|
description: 'Which user created this event',
|
|
|
|
example: 'johndoe',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
environment: {
|
|
|
|
type: 'string',
|
2023-07-06 10:57:09 +02:00
|
|
|
description:
|
|
|
|
'The feature toggle environment the event relates to, if applicable.',
|
2022-06-30 10:12:34 +02:00
|
|
|
nullable: true,
|
2023-07-06 10:57:09 +02:00
|
|
|
example: 'development',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
project: {
|
|
|
|
type: 'string',
|
|
|
|
nullable: true,
|
2023-07-06 10:57:09 +02:00
|
|
|
description: 'The project the event relates to, if applicable.',
|
|
|
|
example: 'default',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
featureName: {
|
|
|
|
type: 'string',
|
|
|
|
nullable: true,
|
2023-07-06 10:57:09 +02:00
|
|
|
description:
|
|
|
|
'The name of the feature toggle the event relates to, if applicable.',
|
|
|
|
example: 'my.first.feature',
|
|
|
|
},
|
2023-07-14 11:11:32 +02:00
|
|
|
data: eventDataSchema,
|
2023-07-06 10:57:09 +02:00
|
|
|
preData: {
|
|
|
|
...eventDataSchema,
|
|
|
|
description:
|
|
|
|
"Data relating to the previous state of the event's subject.",
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
tags: {
|
|
|
|
type: 'array',
|
|
|
|
items: {
|
|
|
|
$ref: tagSchema.$id,
|
|
|
|
},
|
|
|
|
nullable: true,
|
2023-07-06 10:57:09 +02:00
|
|
|
description: 'Any tags related to the event, if applicable.',
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
components: {
|
|
|
|
schemas: {
|
|
|
|
tagSchema,
|
2023-07-06 10:57:09 +02:00
|
|
|
variantSchema,
|
2022-06-30 10:12:34 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
} as const;
|
|
|
|
|
|
|
|
export type EventSchema = FromSchema<typeof eventSchema>;
|