mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
e11fae56e9
This PR updates the OpenAPI schemas for all the operations tagged with "addons". In doing so, I also uncovered a few bugs and inconsistencies. These have also been fixed. ## Changes I've added inline comments to the changed files to call out anything that I think is worth clarifying specifically. As an overall description, this PR does the following: Splits `addon-schema` into `addon-schema` and `addon-create-update-schema`. The former is used when describing addons that exist within Unleash and contain IDs and `created_at` timestamps. The latter is used when creating or updating addons. Adds examples and descriptions to all relevant schemas (and their dependencies). Updates addons operations descriptions and response codes (including the recently introduced 413 and 415). Fixes a bug where the server would crash if it didn't recognize the addon provider (test added). Fixes a bug where updating an addon wouldn't return anything, even if the API said that it would. (test added) Resolves some inconsistencies in handling of addon description. (tests added) ### Addon descriptions when creating addons, descriptions are optional. The original `addonSchema` said they could be `null | string | undefined`. This caused some inconsistencies in return values. Sometimes they were returned, other times not. I've made it so that `descriptions` are now always returned from the API. If it's not defined or if it's set to `null`, the API will return `description: null`. ### `IAddonDto` `IAddonDto`, the type we used internally to model the incoming addons (for create and update) says that `description` is required. This hasn't been true at least since we introduced OpenAPI schemas. As such, the update and insert methods that the service uses were incompatible with the **actual** data that we require. I've changed the type to reflect reality for now. Assuming the tests pass, this **should** all be good, but I'd like the reviewer(s) to give this a think too. --------- Co-authored-by: Christopher Kolstad <chriswk@getunleash.ai>
80 lines
3.4 KiB
TypeScript
80 lines
3.4 KiB
TypeScript
import { FromSchema } from 'json-schema-to-ts';
|
|
|
|
export const addonCreateUpdateSchema = {
|
|
$id: '#/components/schemas/addonCreateUpdateSchema',
|
|
type: 'object',
|
|
required: ['provider', 'enabled', 'parameters', 'events'],
|
|
description:
|
|
'Data required to create or update an [Unleash addon](https://docs.getunleash.io/reference/addons) instance.',
|
|
properties: {
|
|
provider: {
|
|
type: 'string',
|
|
|
|
description: `The addon provider, such as "webhook" or "slack". This string is **case sensitive** and maps to the provider's \`name\` property.
|
|
|
|
The list of all supported providers and their parameters for a specific Unleash instance can be found by making a GET request to the \`api/admin/addons\` endpoint: the \`providers\` property of that response will contain all available providers.
|
|
|
|
The default set of providers can be found in the [addons reference documentation](https://docs.getunleash.io/reference/addons). The default supported options are:
|
|
- \`datadog\` for [Datadog](https://docs.getunleash.io/reference/addons/datadog)
|
|
- \`slack\` for [Slack](https://docs.getunleash.io/reference/addons/slack)
|
|
- \`teams\` for [Microsoft Teams](https://docs.getunleash.io/reference/addons/teams)
|
|
- \`webhook\` for [webhooks](https://docs.getunleash.io/reference/addons/webhook)
|
|
|
|
The provider you choose for your addon dictates what properties the \`parameters\` object needs. Refer to the documentation for each provider for more information.
|
|
`,
|
|
example: 'webhook',
|
|
},
|
|
description: {
|
|
type: 'string',
|
|
description: 'A description of the addon.',
|
|
example:
|
|
'This addon posts updates to our internal feature tracking system whenever a feature is created or updated.',
|
|
},
|
|
enabled: {
|
|
type: 'boolean',
|
|
description: 'Whether the addon should be enabled or not.',
|
|
},
|
|
parameters: {
|
|
type: 'object',
|
|
additionalProperties: {},
|
|
example: {
|
|
url: 'http://localhost:4242/webhook',
|
|
},
|
|
description:
|
|
'Parameters for the addon provider. This object has different required and optional properties depending on the provider you choose. Consult the documentation for details.',
|
|
},
|
|
events: {
|
|
type: 'array',
|
|
description:
|
|
'The event types that will trigger this specific addon.',
|
|
items: {
|
|
type: 'string',
|
|
},
|
|
example: ['feature-created', 'feature-updated'],
|
|
},
|
|
projects: {
|
|
type: 'array',
|
|
description:
|
|
'The projects that this addon will listen to events from. An empty list means it will listen to events from **all** projects.',
|
|
example: ['new-landing-project', 'signups-v2'],
|
|
items: {
|
|
type: 'string',
|
|
},
|
|
},
|
|
environments: {
|
|
type: 'array',
|
|
description:
|
|
'The list of environments that this addon will listen to events from. An empty list means it will listen to events from **all** environments.',
|
|
example: ['development', 'production'],
|
|
items: {
|
|
type: 'string',
|
|
},
|
|
},
|
|
},
|
|
components: {},
|
|
} as const;
|
|
|
|
export type AddonCreateUpdateSchema = FromSchema<
|
|
typeof addonCreateUpdateSchema
|
|
>;
|