From f2c732b227db32f1aaacc4036a67cb7bb7e49ee0 Mon Sep 17 00:00:00 2001 From: Lucie Milan <32450552+lmilan@users.noreply.github.com> Date: Tue, 10 Dec 2024 16:49:47 +0100 Subject: [PATCH] Feat: 3.9 API specs (#8234) * fix typo * fix typo * add config endpoint * add list_consumers parameter * fix copy paste error * add endpoint to update admins's belong workspace * added minlength for tag pagination * fixes after review * minlength to nullable * minlength to nullable * add yaml example --------- Co-authored-by: Angel --- api-specs/Gateway-EE/3.8/kong-ee.yaml | 2 + api-specs/Gateway-EE/3.9/kong-ee.yaml | 134 ++++++++++++++++++++ api-specs/Gateway-EE/latest/kong-ee.yaml | 2 + api-specs/Gateway-OSS/3.7/kong-oss-3.7.yaml | 2 +- api-specs/Gateway-OSS/3.8/kong-oss.yaml | 3 +- api-specs/Gateway-OSS/3.9/kong-oss.yaml | 64 +++++++++- api-specs/Gateway-OSS/latest/kong-oss.yaml | 3 +- 7 files changed, 206 insertions(+), 4 deletions(-) diff --git a/api-specs/Gateway-EE/3.8/kong-ee.yaml b/api-specs/Gateway-EE/3.8/kong-ee.yaml index cb3bf230d528..40fe5b58e7f1 100644 --- a/api-specs/Gateway-EE/3.8/kong-ee.yaml +++ b/api-specs/Gateway-EE/3.8/kong-ee.yaml @@ -22,6 +22,7 @@ components: name: tags schema: type: string + nullable: false certificate_name_or_id: name: certificate_name_or_id in: path @@ -225,6 +226,7 @@ components: name: tags schema: type: string + nullable: false filter_chain_id: name: filter_chain_id in: path diff --git a/api-specs/Gateway-EE/3.9/kong-ee.yaml b/api-specs/Gateway-EE/3.9/kong-ee.yaml index cb3bf230d528..94b98157da66 100644 --- a/api-specs/Gateway-EE/3.9/kong-ee.yaml +++ b/api-specs/Gateway-EE/3.9/kong-ee.yaml @@ -22,6 +22,7 @@ components: name: tags schema: type: string + nullable: false certificate_name_or_id: name: certificate_name_or_id in: path @@ -225,6 +226,7 @@ components: name: tags schema: type: string + nullable: false filter_chain_id: name: filter_chain_id in: path @@ -250,6 +252,13 @@ components: description: | After filter could be used to request audit log data that was recorded after certain time (inclusive). It can either be a timestamp as Unix Epoch or a string following RFC3339 Schema (without fractions of a second) - ex: '2024-04-25T15:03:24Z' + list_consumers: + description: Indicates whether the list of consumers should be included in the consumer group details. + in: query + name: list_consumers + schema: + default: true + type: boolean schemas: UnauthorizedError: type: object @@ -10476,6 +10485,7 @@ paths: '/consumer_groups/{group_name_or_id}': parameters: - $ref: '#/components/parameters/group_name_or_id' + - $ref: '#/components/parameters/list_consumers' get: summary: List a specific consumer group responses: @@ -13111,6 +13121,69 @@ paths: $ref: '#/components/responses/HTTP401Error' operationId: get-admins-name_or_id-workspaces description: Return workspaces associated with an admin. + '/admins/{name_or_id}/workspaces/{workspace_name_or_id}': + parameters: + - schema: + type: string + name: name_or_id + in: path + required: true + description: The admin’s username or ID + - schema: + type: string + name: workspace_name_or_id + in: path + required: true + description: The name or ID of the admin's new workspace. + patch: + summary: Update an Admin's Workspace + tags: + - admins + responses: + '200': + description: OK + content: + application/json: + schema: + type: object + properties: + created_at: + type: integer + id: + type: string + updated_at: + type: integer + status: + type: integer + username: + type: string + email: + type: string + rbac_token_enabled: + type: boolean + x-examples: + Example 1: + created_at: 1556638385 + id: 665b4070-541f-48bf-82c1-53030babaa81 + updated_at: 1556638385 + status: 4 + username: test-admin + email: test@test.com + rbac_token_enabled: true + examples: + Example response body: + value: + created_at: 1556638385 + id: 665b4070-541f-48bf-82c1-53030babaa81 + updated_at: 1556638385 + status: 4 + username: test-admin + email: test@test.com + rbac_token_enabled: true + '401': + $ref: '#/components/responses/HTTP401Error' + operationId: patch-admins-name_or_id-workspaces-workspace_name_or_id + description: Change the `belong_workspace` property for the specified admin. /groups: get: summary: List Groups @@ -16158,6 +16231,64 @@ paths: tags: - cache + '/config': + post: + summary: Apply Declarative Config + tags: + - config + responses: + '201': + description: Created + content: + application/json: + schema: + type: object + requestBody: + content: + application/json: + schema: + type: object + application/yaml: + schema: + type: object + example: | + services: + - name: example-service + url: http://example.com + routes: + - name: example-route + paths: + - /example + multipart/form-data: + schema: + type: object + properties: + config: + type: string + format: binary + example: /path/to/ + description: Configuration file in JSON or YAML. + operationId: post-config + description: | + Apply a configuration from a declarative JSON or YAML file. Any existing configuration will be overwritten. Note: This API is only available in DB-less mode. + get: + summary: Get Declarative Config + operationId: get-config + responses: + '200': + description: OK + content: + application/json: + schema: + type: object + properties: + config: + type: string + tags: + - config + description: | + Get the current configuration. Note: This API is only available in DB-less mode. + servers: - description: Default Admin API URL url: '{protocol}://{hostname}:{port}{path}' @@ -16344,3 +16475,6 @@ tags: - description: | Querying and managing cache entries. name: cache + - description: | + Apply and retrieve declarative configuration when using DB-less mode. + name: config diff --git a/api-specs/Gateway-EE/latest/kong-ee.yaml b/api-specs/Gateway-EE/latest/kong-ee.yaml index cb3bf230d528..40fe5b58e7f1 100644 --- a/api-specs/Gateway-EE/latest/kong-ee.yaml +++ b/api-specs/Gateway-EE/latest/kong-ee.yaml @@ -22,6 +22,7 @@ components: name: tags schema: type: string + nullable: false certificate_name_or_id: name: certificate_name_or_id in: path @@ -225,6 +226,7 @@ components: name: tags schema: type: string + nullable: false filter_chain_id: name: filter_chain_id in: path diff --git a/api-specs/Gateway-OSS/3.7/kong-oss-3.7.yaml b/api-specs/Gateway-OSS/3.7/kong-oss-3.7.yaml index 122e7e78ac82..d4ed88443bff 100644 --- a/api-specs/Gateway-OSS/3.7/kong-oss-3.7.yaml +++ b/api-specs/Gateway-OSS/3.7/kong-oss-3.7.yaml @@ -8025,7 +8025,7 @@ tags: Most core entities can be tagged via the tags attribute upon creation or modification. name: Tags - description: | - Retreieve information about the status of data planes when Kong Gateway is configured in hybrid mode. + Retrieve information about the status of data planes when Kong Gateway is configured in hybrid mode. name: clustering - description: | Querying and managing cache entries. diff --git a/api-specs/Gateway-OSS/3.8/kong-oss.yaml b/api-specs/Gateway-OSS/3.8/kong-oss.yaml index 874abf7d52d8..889b8ac67472 100644 --- a/api-specs/Gateway-OSS/3.8/kong-oss.yaml +++ b/api-specs/Gateway-OSS/3.8/kong-oss.yaml @@ -22,6 +22,7 @@ components: name: tags schema: type: string + nullable: false service_id_or_name: name: service_id_or_name description: ID **or** name of the service to lookup @@ -8076,7 +8077,7 @@ tags: Most core entities can be tagged via the tags attribute upon creation or modification. name: Tags - description: | - Retreieve information about the status of data planes when Kong Gateway is configured in hybrid mode. + Retrieve information about the status of data planes when Kong Gateway is configured in hybrid mode. name: clustering - description: | Querying and managing cache entries. diff --git a/api-specs/Gateway-OSS/3.9/kong-oss.yaml b/api-specs/Gateway-OSS/3.9/kong-oss.yaml index 874abf7d52d8..de2567efbedc 100644 --- a/api-specs/Gateway-OSS/3.9/kong-oss.yaml +++ b/api-specs/Gateway-OSS/3.9/kong-oss.yaml @@ -22,6 +22,7 @@ components: name: tags schema: type: string + nullable: false service_id_or_name: name: service_id_or_name description: ID **or** name of the service to lookup @@ -7960,6 +7961,64 @@ paths: description: All cache entries purged successfully. tags: - cache + + '/config': + post: + summary: Apply Declarative Config + tags: + - config + responses: + '201': + description: Created + content: + application/json: + schema: + type: object + requestBody: + content: + application/json: + schema: + type: object + application/yaml: + schema: + type: object + example: | + services: + - name: example-service + url: http://example.com + routes: + - name: example-route + paths: + - /example + multipart/form-data: + schema: + type: object + properties: + config: + type: string + format: binary + example: /path/to/ + description: Configuration file in JSON or YAML. + operationId: post-config + description: | + Apply a configuration from a declarative JSON or YAML file. Any existing configuration will be overwritten. Note: This API is only available in DB-less mode. + get: + summary: Get Declarative Config + operationId: get-config + responses: + '200': + description: OK + content: + application/json: + schema: + type: object + properties: + config: + type: string + tags: + - config + description: | + Get the current configuration. Note: This API is only available in DB-less mode. servers: - description: Default Admin API URL url: '{protocol}://{hostname}:{port}{path}' @@ -8076,8 +8135,11 @@ tags: Most core entities can be tagged via the tags attribute upon creation or modification. name: Tags - description: | - Retreieve information about the status of data planes when Kong Gateway is configured in hybrid mode. + Retrieve information about the status of data planes when Kong Gateway is configured in hybrid mode. name: clustering - description: | Querying and managing cache entries. name: cache + - description: | + Apply and retrieve declarative configuration when using DB-less mode. + name: config diff --git a/api-specs/Gateway-OSS/latest/kong-oss.yaml b/api-specs/Gateway-OSS/latest/kong-oss.yaml index 874abf7d52d8..889b8ac67472 100644 --- a/api-specs/Gateway-OSS/latest/kong-oss.yaml +++ b/api-specs/Gateway-OSS/latest/kong-oss.yaml @@ -22,6 +22,7 @@ components: name: tags schema: type: string + nullable: false service_id_or_name: name: service_id_or_name description: ID **or** name of the service to lookup @@ -8076,7 +8077,7 @@ tags: Most core entities can be tagged via the tags attribute upon creation or modification. name: Tags - description: | - Retreieve information about the status of data planes when Kong Gateway is configured in hybrid mode. + Retrieve information about the status of data planes when Kong Gateway is configured in hybrid mode. name: clustering - description: | Querying and managing cache entries.