2022-06-27 10:17:44 +02:00
|
|
|
import { FromSchema } from 'json-schema-to-ts';
|
2023-04-26 12:10:57 +02:00
|
|
|
import { dateSchema } from './date-schema';
|
2022-06-27 10:17:44 +02:00
|
|
|
|
|
|
|
export const featureEnvironmentMetricsSchema = {
|
|
|
|
$id: '#/components/schemas/featureEnvironmentMetricsSchema',
|
|
|
|
type: 'object',
|
|
|
|
additionalProperties: false,
|
|
|
|
required: ['environment', 'timestamp', 'yes', 'no'],
|
2023-04-26 12:10:57 +02:00
|
|
|
description:
|
|
|
|
'How many times `feautreName` was evaluated to `true` (yes) and `false` (no) for `appName` in `environmnet`',
|
2022-06-27 10:17:44 +02:00
|
|
|
properties: {
|
|
|
|
featureName: {
|
2023-04-26 12:10:57 +02:00
|
|
|
description: 'The name of the feature',
|
2022-06-27 10:17:44 +02:00
|
|
|
type: 'string',
|
2023-04-26 12:10:57 +02:00
|
|
|
example: 'my.special.feature',
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
|
|
|
appName: {
|
2023-04-26 12:10:57 +02:00
|
|
|
description: 'The name of the application the SDK is being used in',
|
2022-06-27 10:17:44 +02:00
|
|
|
type: 'string',
|
2023-04-26 12:10:57 +02:00
|
|
|
example: 'accounting',
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
|
|
|
environment: {
|
2023-04-26 12:10:57 +02:00
|
|
|
description: 'Which environment the SDK is being used in',
|
2022-06-27 10:17:44 +02:00
|
|
|
type: 'string',
|
2023-04-26 12:10:57 +02:00
|
|
|
example: 'development',
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
|
|
|
timestamp: {
|
2023-04-26 12:10:57 +02:00
|
|
|
description:
|
|
|
|
'The start of the time window these metrics are valid for. The window is usually 1 hour wide',
|
|
|
|
example: '1926-05-08T12:00:00.000Z',
|
|
|
|
$ref: '#/components/schemas/dateSchema',
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
|
|
|
yes: {
|
2023-04-26 12:10:57 +02:00
|
|
|
description: 'How many times the toggle evaluated to true',
|
|
|
|
type: 'integer',
|
|
|
|
example: 974,
|
|
|
|
minimum: 0,
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
|
|
|
no: {
|
2023-04-26 12:10:57 +02:00
|
|
|
description: 'How many times the toggle evaluated to false',
|
|
|
|
type: 'integer',
|
|
|
|
example: 50,
|
|
|
|
minimum: 0,
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
2023-05-05 10:10:54 +02:00
|
|
|
variants: {
|
|
|
|
description: 'How many times each variant was returned',
|
|
|
|
type: 'object',
|
|
|
|
additionalProperties: {
|
|
|
|
type: 'integer',
|
|
|
|
minimum: 0,
|
|
|
|
},
|
|
|
|
example: {
|
|
|
|
variantA: 15,
|
|
|
|
variantB: 25,
|
|
|
|
variantC: 5,
|
|
|
|
},
|
|
|
|
},
|
2022-06-27 10:17:44 +02:00
|
|
|
},
|
2023-04-26 12:10:57 +02:00
|
|
|
components: {
|
|
|
|
dateSchema,
|
|
|
|
},
|
2022-06-27 10:17:44 +02:00
|
|
|
} as const;
|
|
|
|
|
|
|
|
export type FeatureEnvironmentMetricsSchema = FromSchema<
|
|
|
|
typeof featureEnvironmentMetricsSchema
|
|
|
|
>;
|