2022-08-09 16:14:50 +02:00
|
|
|
import { FromSchema } from 'json-schema-to-ts';
|
2023-07-06 10:57:09 +02:00
|
|
|
import { IEventTypes } from '../../types';
|
2022-08-09 16:14:50 +02:00
|
|
|
|
|
|
|
export const searchEventsSchema = {
|
|
|
|
$id: '#/components/schemas/searchEventsSchema',
|
|
|
|
type: 'object',
|
|
|
|
description: `
|
|
|
|
Search for events by type, project, feature, free-text query,
|
|
|
|
or a combination thereof. Pass an empty object to fetch all events.
|
|
|
|
`,
|
|
|
|
properties: {
|
|
|
|
type: {
|
|
|
|
type: 'string',
|
|
|
|
description: 'Find events by event type (case-sensitive).',
|
2023-07-06 10:57:09 +02:00
|
|
|
enum: IEventTypes,
|
|
|
|
example: 'feature-created',
|
2022-08-09 16:14:50 +02:00
|
|
|
},
|
|
|
|
project: {
|
|
|
|
type: 'string',
|
|
|
|
description: 'Find events by project ID (case-sensitive).',
|
2023-07-06 10:57:09 +02:00
|
|
|
example: 'default',
|
2022-08-09 16:14:50 +02:00
|
|
|
},
|
|
|
|
feature: {
|
|
|
|
type: 'string',
|
|
|
|
description: 'Find events by feature toggle name (case-sensitive).',
|
2023-07-06 10:57:09 +02:00
|
|
|
example: 'my.first.toggle',
|
2022-08-09 16:14:50 +02:00
|
|
|
},
|
|
|
|
query: {
|
|
|
|
type: 'string',
|
|
|
|
description: `
|
|
|
|
Find events by a free-text search query.
|
|
|
|
The query will be matched against the event type,
|
|
|
|
the username or email that created the event (if any),
|
|
|
|
and the event data payload (if any).
|
|
|
|
`,
|
2023-07-06 10:57:09 +02:00
|
|
|
example: 'admin@example.com',
|
2022-08-09 16:14:50 +02:00
|
|
|
},
|
|
|
|
limit: {
|
|
|
|
type: 'integer',
|
2023-07-06 10:57:09 +02:00
|
|
|
description:
|
|
|
|
'The maximum amount of events to return in the search result',
|
2022-08-09 16:14:50 +02:00
|
|
|
minimum: 1,
|
|
|
|
maximum: 100,
|
|
|
|
default: 100,
|
2023-07-06 10:57:09 +02:00
|
|
|
example: 50,
|
2022-08-09 16:14:50 +02:00
|
|
|
},
|
|
|
|
offset: {
|
2023-07-06 10:57:09 +02:00
|
|
|
description: 'Which event id to start listing from',
|
2022-08-09 16:14:50 +02:00
|
|
|
type: 'integer',
|
|
|
|
minimum: 0,
|
|
|
|
default: 0,
|
2023-07-06 10:57:09 +02:00
|
|
|
example: 100,
|
2022-08-09 16:14:50 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
components: {},
|
|
|
|
} as const;
|
|
|
|
|
|
|
|
export type SearchEventsSchema = FromSchema<typeof searchEventsSchema>;
|