openapi: 3.0.3
info:
title: Gravitee.io APIM - Management API
description: |-
This is the OpenAPI specification for our new version of APIM Management API.
contact:
email: team-apim@graviteesource.com
license:
name: Apache 2.0
url: http://www.apache.org/licenses/LICENSE-2.0.html
version: 2.0.0
security:
- BasicAuth: []
- CookieAuth: []
servers:
- url: /management/v2
description: Gravitee.io APIM - Management API -v2
tags:
- name: APIs
description: Everything about APIs
- name: API Members
description: Everything about API members
- name: API Plans
description: Everything about API plans
- name: API Subscriptions
description: Everything about API subscriptions
- name: Group
description: Everything about groups
- name: Installation
description: Base resources about the installation
- name: Plugins - Endpoints
description: Everything about endpoint plugins
- name: Plugins - Entrypoints
description: Everything about entrypoint plugins
- name: Plugins - Policies
description: Everything about policies plugins
paths:
# APIs
/environments/{envId}/apis:
parameters:
- $ref: "#/components/parameters/envIdParam"
get:
parameters:
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
- $ref: "#/components/parameters/apiExpandsParam"
tags:
- APIs
summary: List APIs
description: |-
Get the list of APIs for a specific environment.
The results are paginated.
User must have the ENVIRONMENT_API[READ] permission.
operationId: listApis
responses:
"200":
$ref: "#/components/responses/ApisResponse"
default:
$ref: "#/components/responses/Error"
post:
tags:
- APIs
summary: Create an API
description: |-
⚠️ Support only v4 API for the moment. ⚠️
Create a new API.
User must have the ENVIRONMENT_API[CREATE] permission.
operationId: createApi
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/CreateApiV4"
required: true
responses:
"201":
description: API successfully created
content:
application/json:
schema:
$ref: "#/components/schemas/ApiV4"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/_import/definition:
parameters:
- $ref: "#/components/parameters/envIdParam"
post:
tags:
- APIs
summary: Import API definition
description: |-
⚠️ Support only v4 API for the moment. ⚠️
Create an API by importing an API definition.
This definition can be retrieved from `GET /environments/{envId}/apis/{apiId}/_export/definition`
User must have the ENVIRONMENT_API[CREATE] permission.
operationId: createApiWithImportDefinition
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/ExportApiV4"
required: true
responses:
"201":
description: API successfully created
content:
application/json:
schema:
$ref: "#/components/schemas/ApiV4"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/_search:
parameters:
- $ref: "#/components/parameters/envIdParam"
post:
parameters:
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
- $ref: "#/components/parameters/apiSortByParam"
- $ref: "#/components/parameters/apiExpandsParam"
tags:
- APIs
summary: Search APIs
description: |-
Search APIs for a specific environment.
The results are paginated and can be sorted.
User must have the ENVIRONMENT_API[READ] permission.
operationId: searchApis
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/ApiSearchQuery"
required: true
responses:
"200":
$ref: "#/components/responses/ApisResponse"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
tags:
- APIs
summary: Get a specific API
description: |-
Get a specific API.
User must have at least one management (create, update, or delete) permission on the API to access it.
operationId: getApi
responses:
"200":
description: API found
content:
application/json:
schema:
$ref: "#/components/schemas/Api"
default:
$ref: "#/components/responses/Error"
put:
tags:
- APIs
summary: Update an API
description: |-
Update a V2 or a V4 API.
User must have API_DEFINITION[UPDATE] or API_GATEWAY_DEFINITION[UPDATE] permissions.
operationId: updateApi
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/UpdateApi"
required: true
responses:
"200":
description: API successfully updated
content:
application/json:
schema:
$ref: "#/components/schemas/Api"
default:
$ref: "#/components/responses/Error"
delete:
parameters:
- name: closePlans
in: query
required: false
description: |-
Set to true to force deletion by closing API plans.
⚠️ Closed plans can't be reopened and every active subscriptions will also be closed. ⚠️
schema:
type: boolean
tags:
- APIs
summary: Delete an API
description: |-
Delete a V2 or a V4 API.
User must have API_DEFINITION[DELETE] permission.
operationId: deleteApi
responses:
"204":
description: API successfully deleted
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/background:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
tags:
- APIs
summary: Get an API's background picture
description: |-
Get the API's background picture.
User must have the API_DEFINITION[READ] permission.
operationId: getApiBackground
responses:
"200":
$ref: "#/components/responses/ImageResponse"
default:
$ref: "#/components/responses/Error"
put:
tags:
- APIs
summary: Update an API's background
description: |-
Update the API's background.
User must have the API_DEFINITION[UPDATE] permission.
operationId: updateApiBackground
requestBody:
content:
image/*:
schema:
type: string
format: binary
responses:
"204":
description: API background successfully updated
default:
$ref: "#/components/responses/Error"
delete:
tags:
- APIs
summary: Delete an API's background
description: |-
Delete the API's background.
User must have the API_DEFINITION[UPDATE] permission.
operationId: deleteApiBackground
responses:
"204":
description: API background successfully deleted.
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/deployments:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- APIs
summary: Request a deployment to gateway instances
description: |-
Request a deployment for a given API.
An optional deployment label can be given to the requested deployment.
User must have the API_DEFINITION[UPDATE] permission.
operationId: createApiDeployment
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/ApiDeployment"
responses:
"202":
description: API deployment request received
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/picture:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
tags:
- APIs
summary: Get an API's picture
description: |-
Get the API's picture.
User must have the API_DEFINITION[READ] permission.
operationId: getApiPicture
responses:
"200":
$ref: "#/components/responses/ImageResponse"
default:
$ref: "#/components/responses/Error"
put:
tags:
- APIs
summary: Update an API's picture
description: |-
Update the API's picture.
User must have the API_DEFINITION[UPDATE] permission.
operationId: updateApiPicture
requestBody:
content:
image/*:
schema:
type: string
format: binary
responses:
"204":
description: API picture successfully updated
default:
$ref: "#/components/responses/Error"
delete:
tags:
- APIs
summary: Delete an API's picture
description: |-
Delete the API's picture.
User must have the API_DEFINITION[UPDATE] permission.
operationId: deleteApiPicture
responses:
"204":
description: API picture successfully deleted.
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/_export/definition:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
tags:
- APIs
summary: Export an API
description: |-
⚠️ Support only v4 API for the moment. ⚠️
Export an API to a JSON file.
User must have at least the API_DEFINITION[READ] permission.
User should also have these permissions for specific data:
- API_DEFINITION[READ] for the API
- API_MEMBER[READ] for the API's members
- API_PLAN[READ] for the API's plans
- API_METADATA[READ] for the API's metadata
- API_DOCUMENTATION[READ] for the API's documentation pages
operationId: exportApiDefinition
responses:
"200":
description: API deployment successfully deployed
headers:
Content-Disposition:
schema:
type: string
example: attachment; filename="api-definition.json"
content:
application/json:
schema:
$ref: "#/components/schemas/ExportApiV4"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/_start:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- APIs
summary: Start an API
description: |-
Change the API's status to STARTED.
Return a 400 HTTP Error:
- when user tries to start an ARCHIVED API
- when the API is already STARTED
- when the API needs to be reviewed (only if Review feature is activated).
User must have the API_DEFINITION[UPDATE] permission.
operationId: startApi
responses:
"204":
description: API successfully started
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/_stop:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- APIs
summary: Stop an API
description: |-
Change the API's status to STOPPED.
Return a 400 HTTP Error:
- when user tries to stop an ARCHIVED API
- when the API is already STOPPED.
User must have the API_DEFINITION[UPDATE] permission.
operationId: stopApi
responses:
"204":
description: API successfully stopped
default:
$ref: "#/components/responses/Error"
# API Reviews
/environments/{envId}/apis/{apiId}/reviews/_ask:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- APIs
summary: Ask for a review
description: |-
Ask for a review
Return a 400 HTTP Error:
- when user tries to change reviews state of an ARCHIVED API
- when user tries to change reviews state of an API already in review
User must have the API_DEFINITION[UPDATE] permission.
operationId: reviewsAsk
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/ApiReview"
required: true
responses:
"204":
description: API successfully change review state
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/reviews/_accept:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- APIs
summary: Accept a review
description: |-
Accept a review
Return a 400 HTTP Error:
- when user tries to change reviews state of an ARCHIVED API
- when user tries to change reviews state of an API that is not in review
User must have the API_REVIEWS[UPDATE] permission.
operationId: reviewsAccept
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/ApiReview"
required: true
responses:
"204":
description: API successfully change review state
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/reviews/_reject:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- APIs
summary: Reject a review
description: |-
Reject a review
Return a 400 HTTP Error:
- when user tries to change reviews state of an ARCHIVED API
- when user tries to change reviews state of an API that is not in review
User must have the API_REVIEWS[UPDATE] permission.
operationId: reviewsReject
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/ApiReview"
required: true
responses:
"204":
description: API successfully change review state
default:
$ref: "#/components/responses/Error"
# API Members
/environments/{envId}/apis/{apiId}/members:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
parameters:
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- API Members
summary: Get the API's members
description: |
List the members for a given API.
User must have the API_MEMBER[READ] permission.
operationId: listApiMembers
responses:
"200":
$ref: "#/components/responses/MembersResponse"
default:
$ref: "#/components/responses/Error"
post:
tags:
- API Members
summary: Add a member to an API.
description: |
Add a new member to an API.
Returns a 400 HTTP Error:
- when the user tries to set a member as PrimaryOwner.
User must have the API_MEMBER[CREATE] permission.
operationId: addApiMember
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/AddApiMember"
required: true
responses:
"201":
description: Member successfully added
content:
application/json:
schema:
$ref: "#/components/schemas/Member"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/members/{memberId}:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/memberIdParam"
put:
tags:
- API Members
summary: Updates a member for an API.
description: |
Edit a member for an API.
Returns a 400 HTTP Error:
- when the user tries to set a member as PrimaryOwner.
User must have the API_MEMBER[UPDATE] permission.
operationId: updateApiMember
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/UpdateApiMember"
required: true
responses:
"200":
description: Membership successfully edited.
content:
application/json:
schema:
$ref: "#/components/schemas/Member"
default:
$ref: "#/components/responses/Error"
delete:
tags:
- API Members
summary: Remove one API member
description: |
Remove an API member.
Returns a 400 HTTP Error:
- when the user tries to remove a PrimaryOwner.
User must have the API_MEMBER[DELETE] permission.
operationId: removeApiMember
responses:
"204":
description: API member successfully removed
default:
$ref: "#/components/responses/Error"
# API Plans
/environments/{envId}/apis/{apiId}/plans:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
parameters:
- name: statuses
in: query
required: false
description: List of status filters
schema:
type: array
items:
$ref: "#/components/schemas/PlanStatus"
default: ["published"]
explode: false
- name: securities
in: query
required: false
description: List of security plan type filters
schema:
type: array
items:
$ref: "#/components/schemas/PlanSecurityType"
explode: false
- name: mode
in: query
required: false
description: Mode of plan
schema:
$ref: "#/components/schemas/PlanMode"
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- API Plans
summary: List the API's plans
description: |
List plans for a given API, always filtered by a `status` and the possibility to filter by `security`.
The results are paginated.
User must have API_PLAN[READ] permissions to access endpoint.
operationId: listApiPlans
responses:
"200":
$ref: "#/components/responses/PlansResponse"
default:
$ref: "#/components/responses/Error"
post:
tags:
- API Plans
summary: Create an API's plan
description: |-
Create a new plan on a given API.
User must have the API_PLAN[CREATE] permission.
operationId: createApiPlan
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/CreatePlan"
required: true
responses:
"201":
description: Plan successfully created
content:
application/json:
schema:
$ref: "#/components/schemas/Plan"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/plans/{planId}:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/planIdParam"
get:
tags:
- API Plans
summary: Get one API's plan
description: |-
Get the API's plan by its identifier.
User must have the API_PLAN[READ] permission.
operationId: getApiPlan
responses:
"200":
description: An API's plan
content:
application/json:
schema:
$ref: "#/components/schemas/Plan"
default:
$ref: "#/components/responses/Error"
put:
tags:
- API Plans
summary: Update one API's plan
description: |-
Update the API's plan.
User must have the API_PLAN[UPDATE] permission.
operationId: updateApiPlan
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/UpdatePlan"
required: true
responses:
"200":
description: API's plan successfully updated
content:
application/json:
schema:
$ref: "#/components/schemas/Plan"
default:
$ref: "#/components/responses/Error"
delete:
tags:
- API Plans
summary: Delete one API's plan
description: |-
Delete the API's plan.
User must have the API_PLAN[DELETE] permission.
operationId: deleteApiPlan
responses:
"204":
description: API's plan successfully deleted
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/plans/{planId}/_close:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/planIdParam"
post:
tags:
- API Plans
summary: Close an API's plan
description: |-
Close the API's plan.
User must have the API_PLAN[UPDATE] permission.
operationId: closeApiPlan
responses:
"200":
description: API's plan successfully closed
content:
application/json:
schema:
$ref: "#/components/schemas/Plan"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/plans/{planId}/_deprecate:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/planIdParam"
post:
tags:
- API Plans
summary: Deprecate an API's plan
description: |-
Deprecate the API's plan.
User must have the API_PLAN[UPDATE] permission.
operationId: deprecateApiPlan
responses:
"200":
description: API's plan successfully deprecated
content:
application/json:
schema:
$ref: "#/components/schemas/Plan"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/plans/{planId}/_publish:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/planIdParam"
post:
tags:
- API Plans
summary: Publish an API's plan
description: |-
Publish the API's plan.
User must have the API_PLAN[UPDATE] permission.
operationId: publishApiPlan
responses:
"200":
description: API's plan successfully published
content:
application/json:
schema:
$ref: "#/components/schemas/Plan"
default:
$ref: "#/components/responses/Error"
# Group
/environments/{envId}/groups/{groupId}/members:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/groupIdParam"
get:
parameters:
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- Group
summary: List a group's members
description: |
List the members of a given group.
User must have the GROUP_MEMBER[READ] permission.
operationId: listGroupMembers
responses:
"200":
$ref: "#/components/responses/MembersResponse"
default:
$ref: "#/components/responses/Error"
# Installation
/environments:
get:
parameters:
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- Installation
summary: List all environments.
description: |-
List all environments accessible by the current user.
User must be authenticated.
operationId: getEnvironments
responses:
"200":
$ref: "#/components/responses/EnvironmentsResponse"
default:
$ref: "#/components/responses/Error"
/environments/{envId}:
parameters:
- $ref: "#/components/parameters/envIdParam"
get:
tags:
- Installation
summary: Get a specific environment
description: |-
Get a specific environment.
User must be authenticated.
operationId: getEnvironmentById
responses:
"200":
description: An environment
content:
application/json:
schema:
$ref: "#/components/schemas/Environment"
default:
$ref: "#/components/responses/Error"
/license:
get:
tags:
- Installation
summary: Get the license gravitee is running on.
description: |-
Returns the license information of the gravitee instance.
User must be authenticated.
operationId: getGraviteeLicense
responses:
"200":
description: |-
The license and its features. If there is no license, then the features will be empty.
content:
application/json:
schema:
$ref: "#/components/schemas/GraviteeLicense"
default:
$ref: "#/components/responses/Error"
/organizations/{orgId}:
parameters:
- $ref: "#/components/parameters/orgIdParam"
get:
tags:
- Installation
summary: Get a specific organization
description: |-
Get a specific organization
User must be authenticated.
operationId: getOrganizationById
responses:
"200":
description: An organization
content:
application/json:
schema:
$ref: "#/components/schemas/Organization"
default:
$ref: "#/components/responses/Error"
# API Subscriptions
/environments/{envId}/apis/{apiId}/subscribers:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
parameters:
- name: name
description: |-
Name to use to filter subscribers.
Can be a part of a name.
For example, `foo` will match `foo`, `foobar` and `barfoo`.
in: query
schema:
type: string
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- API Subscriptions
summary: Get the API's subscribers
description: |
List applications that have subscribed to a given API.
The results are paginated.
User must have API_SUBSCRIPTION[READ] permissions to access endpoint.
operationId: getApiSubscribers
responses:
"200":
$ref: "#/components/responses/SubscribersResponse"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
parameters:
- name: applicationIds
description: List of application ids to filter on.
in: query
explode: false
schema:
type: array
items:
type: string
- name: planIds
description: List of plan ids to filter on.
in: query
explode: false
schema:
type: array
items:
type: string
- name: statuses
in: query
required: false
description: List of status filters.
explode: false
schema:
type: array
items:
$ref: "#/components/schemas/SubscriptionStatus"
- name: apiKey
in: query
description: API Key associated to the subscription to filter on.
schema:
type: string
- name: expands
in: query
description: Expansion of data to return in subscriptions.
schema:
type: array
items:
type: string
enum:
- application
- plan
- subscribedBy
explode: false
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- API Subscriptions
summary: Get the API's subscriptions
description: |
List subscriptions for a given API, always filtered by a `status` and the possibility to filter by `security`.
User must have API_SUBSCRIPTION[READ] permissions to access endpoint.
operationId: getApiSubscriptions
responses:
"200":
$ref: "#/components/responses/SubscriptionsResponse"
default:
$ref: "#/components/responses/Error"
post:
tags:
- API Subscriptions
summary: Subscribe to an API's plan
description: |-
Create a new subscription on a given API.
User must have the API_SUBSCRIPTION[CREATE] permission.
operationId: createApiSubscription
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/CreateSubscription"
required: true
responses:
"201":
description: Subscription successfully created
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/_export:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
get:
parameters:
- name: applicationIds
description: List of application ids to filter on.
in: query
explode: false
schema:
type: array
items:
type: string
- name: planIds
description: List of plan ids to filter on.
in: query
explode: false
schema:
type: array
items:
type: string
- name: statuses
in: query
required: false
description: List of status filters.
explode: false
schema:
type: array
items:
$ref: "#/components/schemas/SubscriptionStatus"
- name: apiKey
in: query
description: API Key associated to the subscription to filter on.
schema:
type: string
- $ref: "#/components/parameters/pageParam"
- $ref: "#/components/parameters/perPageParam"
tags:
- API Subscriptions
summary: Export API subscriptions as CSV
description: |-
Export API subscriptions to a CSV file.
User must have the API_SUBSCRIPTION[READ] permission.
operationId: exportApiSubscriptions
responses:
"200":
description: API subscriptions successfully exported.
headers:
Content-Disposition:
schema:
type: string
example: attachment;filename="filename=subscriptions-51fdbabf-ab0c-3dc6-b3c1-77c99d96b535-1686772361126.csv"
content:
text/csv: {}
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/_verify:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
post:
tags:
- API Subscriptions
summary: Check a subscription can be created
description: |-
Check a subscription can be created with given API Key, and application.
User must have the API_SUBSCRIPTION[CREATE] permission.
operationId: verifyCreateApiSubscription
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/VerifySubscription"
required: true
responses:
"200":
description: Verification successfully performed.
content:
application/json:
schema:
$ref: "#/components/schemas/VerifySubscriptionResponse"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
get:
tags:
- API Subscriptions
parameters:
- name: expands
in: query
description: Expansion of data to return in subscriptions.
schema:
type: array
items:
type: string
enum:
- application
- plan
- subscribedBy
summary: Get one API's subscription
description: |-
Get the API's subscription by its identifier.
User must have the API_SUBSCRIPTION[READ] permission.
operationId: getApiSubscription
responses:
"200":
description: An API's subscription
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
put:
tags:
- API Subscriptions
summary: Update one API's subscription
description: |-
Update the API's subscription.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: updateApiSubscription
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/UpdateSubscription"
required: true
responses:
"200":
description: API's subscription successfully updated
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/_close:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Close one API's subscription
description: |-
Close the API's subscription.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: closeApiSubscription
responses:
"200":
description: API's subscription successfully closed
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/_pause:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Pause one API's subscription
description: |-
Pause the API's subscription.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: pauseApiSubscription
responses:
"200":
description: API's subscription successfully paused
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/_resume:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Resume a paused API's subscription
description: |-
Resume a previously paused subscription.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: resumeApiSubscription
responses:
"200":
description: API's subscription successfully resumed
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/_accept:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Accept an API subscription
description: |-
Accept an API subscription with an optional starting / ending dates and reason.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: acceptApiSubscription
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/AcceptSubscription"
required: true
responses:
"200":
description: API's subscription successfully accepted
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/_reject:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Reject an API subscription
description: |-
Reject an API subscription with an optional reason.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: rejectApiSubscription
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/RejectSubscription"
required: true
responses:
"200":
description: API's subscription successfully rejected
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/_transfer:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Transfer an API subscription
description: |-
Transfer an API subscription to another plan.
The targeted plan must be published and must have the same security type. Transfer cannot be performed if general conditions apply to the targeted plan.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: transferApiSubscription
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/TransferSubscription"
required: true
responses:
"200":
description: API's subscription successfully transferred
content:
application/json:
schema:
$ref: "#/components/schemas/Subscription"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/api-keys:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
get:
tags:
- API Subscriptions
summary: Get subscription's API Keys
description: |-
Get the subscription API Keys.
User must have the API_SUBSCRIPTION[READ] permission.
operationId: getApiSubscriptionApiKeys
responses:
"200":
$ref: "#/components/responses/SubscriptionApiKeysResponse"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/api-keys/_renew:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
post:
tags:
- API Subscriptions
summary: Renew the subscription API Keys.
description: |-
Renew the subscription API Key by setting an expiration date on the existing active API Keys and creating a new API Key.
The newly created API Key is returned in response.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: renewApiSubscriptionApiKeys
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/RenewApiKey"
required: true
responses:
"200":
description: API's subscription API Key successfully renewed
content:
application/json:
schema:
$ref: "#/components/schemas/ApiKey"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/api-keys/{apiKeyId}:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
- $ref: "#/components/parameters/apiKeyIdParam"
put:
tags:
- API Subscriptions
summary: Update a subscription API Key
description: |-
Update the subscription API Key.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: updateApiSubscriptionApiKey
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/UpdateApiKey"
required: true
responses:
"200":
description: The subscription API Key.
content:
application/json:
schema:
$ref: "#/components/schemas/ApiKey"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/api-keys/{apiKeyId}/_revoke:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
- $ref: "#/components/parameters/apiKeyIdParam"
post:
tags:
- API Subscriptions
summary: Revoke a subscription API Key
description: |-
Revoke the subscription API Key by setting the revocation date to the current date and flagging it as revoked.
A notification will be sent to the subscriber according to his portal notification options.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: revokeApiSubscriptionApiKey
responses:
"200":
description: The revoked subscription API Key.
content:
application/json:
schema:
$ref: "#/components/schemas/ApiKey"
default:
$ref: "#/components/responses/Error"
/environments/{envId}/apis/{apiId}/subscriptions/{subscriptionId}/api-keys/{apiKeyId}/_reactivate:
parameters:
- $ref: "#/components/parameters/envIdParam"
- $ref: "#/components/parameters/apiIdParam"
- $ref: "#/components/parameters/subscriptionIdParam"
- $ref: "#/components/parameters/apiKeyIdParam"
post:
tags:
- API Subscriptions
summary: Reactivate subscription API Key
description: |-
Reactivate the revoked or expired subscription API Key.
User must have the API_SUBSCRIPTION[UPDATE] permission.
operationId: reactivateApiSubscriptionApiKey
responses:
"200":
description: The reactivated subscription API Key.
content:
application/json:
schema:
$ref: "#/components/schemas/ApiKey"
default:
$ref: "#/components/responses/Error"
# Plugins - Endpoints
/plugins/endpoints:
get:
tags:
- Plugins - Endpoints
summary: Get available endpoints on the platform
description: |
Get available endpoint types on the platform.
User must be authenticated.
operationId: getEndpoints
responses:
"200":
description: List of Endpoints.
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/ConnectorPlugin"
default:
$ref: "#/components/responses/Error"
/plugins/endpoints/{endpointId}:
parameters:
- $ref: "#/components/parameters/endpointIdParam"
get:
tags:
- Plugins - Endpoints
summary: Get an endpoint
description: |
Get an endpoint type.
User must be authenticated.
operationId: getEndpoint
responses:
"200":
description: Endpoint
content:
application/json:
schema:
$ref: "#/components/schemas/ConnectorPlugin"
default:
$ref: "#/components/responses/Error"
/plugins/endpoints/{endpointId}/documentation:
parameters:
- $ref: "#/components/parameters/endpointIdParam"
get:
tags:
- Plugins - Endpoints
summary: Get an endpoint documentation
description: |
Get the documentation of an endpoint.
User must be authenticated.
operationId: getEndpointDocumentation
responses:
"200":
description: Documentation of the endpoint
content:
text/plain:
schema:
type: string
default:
$ref: "#/components/responses/Error"
/plugins/endpoints/{endpointId}/more-information:
parameters:
- $ref: "#/components/parameters/endpointIdParam"
get:
tags:
- Plugins - Endpoints
summary: Get more information about how to use a given endpoint
description: |
More information about the endpoint.
User must be authenticated.
operationId: getEndpointMoreInformation
responses:
"200":
description: More information of the endpoint
content:
application/json:
schema:
$ref: "#/components/schemas/MoreInformation"
default:
$ref: "#/components/responses/Error"
/plugins/endpoints/{endpointId}/schema:
parameters:
- $ref: "#/components/parameters/endpointIdParam"
get:
tags:
- Plugins - Endpoints
summary: Get an endpoint schema
description: |
Get the JSON schema that describes the configuration of an endpoint.
User must be authenticated.
operationId: getEndpointSchema
responses:
"200":
$ref: "#/components/responses/SchemaFormResponse"
default:
$ref: "#/components/responses/Error"
/plugins/endpoints/{endpointId}/shared-configuration-schema:
parameters:
- $ref: "#/components/parameters/endpointIdParam"
get:
tags:
- Plugins - Endpoints
summary: Get an endpoint shared configuration schema
description: |
Get an endpoint shared configuration schema.
User must be authenticated.
operationId: getEndpointSharedConfigurationSchema
responses:
"200":
$ref: "#/components/responses/SchemaFormResponse"
default:
$ref: "#/components/responses/Error"
# Plugins - Entrypoints
/plugins/entrypoints:
get:
tags:
- Plugins - Entrypoints
summary: Get available entrypoints on the platform
description: |
Get available entrypoint types on the platform.
User must be authenticated.
operationId: getEntrypoints
responses:
"200":
description: List of Entrypoints.
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/ConnectorPlugin"
default:
$ref: "#/components/responses/Error"
/plugins/entrypoints/{entrypointId}:
parameters:
- $ref: "#/components/parameters/entrypointIdParam"
get:
tags:
- Plugins - Entrypoints
summary: Get an entrypoint
description: |
Get an entrypoint type.
User must be authenticated.
operationId: getEntrypoint
responses:
"200":
description: Entrypoint
content:
application/json:
schema:
$ref: "#/components/schemas/ConnectorPlugin"
default:
$ref: "#/components/responses/Error"
/plugins/entrypoints/{entrypointId}/documentation:
parameters:
- $ref: "#/components/parameters/entrypointIdParam"
get:
tags:
- Plugins - Entrypoints
summary: Get an entrypoint documentation
description: |
Get the documentation of an entrypoint.
User must be authenticated.
operationId: getEntrypointDocumentation
responses:
"200":
description: Documentation of the entrypoint
content:
text/plain:
schema:
type: string
default:
$ref: "#/components/responses/Error"
/plugins/entrypoints/{entrypointId}/more-information:
parameters:
- $ref: "#/components/parameters/entrypointIdParam"
get:
tags:
- Plugins - Entrypoints
summary: Get more information about how to use a given entrypoint
description: |
More information about the entrypoint.
User must be authenticated.
operationId: getEntrypointMoreInformation
responses:
"200":
description: More information of the entrypoint
content:
application/json:
schema:
$ref: "#/components/schemas/MoreInformation"
default:
$ref: "#/components/responses/Error"
/plugins/entrypoints/{entrypointId}/schema:
parameters:
- $ref: "#/components/parameters/entrypointIdParam"
get:
tags:
- Plugins - Entrypoints
summary: Get an entrypoint schema
description: |
Get the JSON schema that describes the configuration of an entrypoint.
User must be authenticated.
operationId: getEntrypointSchema
responses:
"200":
$ref: "#/components/responses/SchemaFormResponse"
default:
$ref: "#/components/responses/Error"
/plugins/entrypoints/{entrypointId}/subscription-schema:
parameters:
- $ref: "#/components/parameters/entrypointIdParam"
get:
parameters:
- name: display
in: query
description: Display the schema in a specific format..
required: false
schema:
type: string
default: gio-form-json-schema
enum:
- gv-schema-form
- gio-form-json-schema
tags:
- Plugins - Entrypoints
summary: Get an entrypoint subscription schema
description: |
Get the JSON schema that describes the subscription to a given entrypoint.
User must be authenticated.
operationId: getEntrypointSubscriptionSchema
responses:
"200":
$ref: "#/components/responses/SchemaFormResponse"
default:
$ref: "#/components/responses/Error"
# Plugins - Policies
/plugins/policies:
get:
tags:
- Plugins - Policies
summary: Get available policies on the platform
description: |
Get available policies on the platform.
User must be authenticated.
operationId: getPolicies
responses:
"200":
description: List of Policies.
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/PolicyPlugin"
default:
$ref: "#/components/responses/Error"
/plugins/policies/{policyId}:
parameters:
- $ref: "#/components/parameters/policyIdParam"
get:
tags:
- Plugins - Policies
summary: Get a policy
description: |
Get a policy.
User must be authenticated.
operationId: getPolicy
responses:
"200":
description: Policy
content:
application/json:
schema:
$ref: "#/components/schemas/PolicyPlugin"
default:
$ref: "#/components/responses/Error"
/plugins/policies/{policyId}/documentation:
parameters:
- $ref: "#/components/parameters/policyIdParam"
get:
tags:
- Plugins - Policies
summary: Get a policy documentation
description: |
Get the documentation of a policy.
User must be authenticated.
operationId: getPolicyDocumentation
responses:
"200":
description: Documentation of the entrypoint
content:
text/plain:
schema:
type: string
default:
$ref: "#/components/responses/Error"
/plugins/policies/{policyId}/schema:
parameters:
- $ref: "#/components/parameters/policyIdParam"
get:
parameters:
- name: display
in: query
description: Display the schema in a specific format..
required: false
schema:
type: string
default: gio-form-json-schema
enum:
- gv-schema-form
- gio-form-json-schema
tags:
- Plugins - Policies
summary: Get a policy schema
description: |
Get the JSON schema that describes the configuration of a policy.
User must be authenticated.
operationId: getPolicySchema
responses:
"200":
$ref: "#/components/responses/SchemaFormResponse"
default:
$ref: "#/components/responses/Error"
components:
schemas:
GraviteeLicense:
type: object
properties:
tier:
type: string
description: The tier gravitee is running on.
example: "tier-planet"
packs:
type: array
items:
type: string
description: The packs included in the tier gravitee is running on.
example:
- "pack-observability"
- "pack-event-native"
features:
type: array
items:
type: string
description: The features included in the tier gravitee is running on.
example:
- feature-debug-mode
- feature-datadog-reporter
Analytics:
type: object
properties:
enabled:
type: boolean
description: Whether or not analytics is enabled.
default: true
sampling:
$ref: "#/components/schemas/Sampling"
logging:
$ref: "#/components/schemas/LoggingV4"
Api:
oneOf:
- $ref: "#/components/schemas/ApiV1"
- $ref: "#/components/schemas/ApiV2"
- $ref: "#/components/schemas/ApiV4"
discriminator:
propertyName: definitionVersion
mapping:
V1: ApiV1
V2: ApiV2
V4: ApiV4
BaseApi:
type: object
properties:
id:
type: string
description: API's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: API's name. Duplicate names can exists.
example: My Api
description:
type: string
description: API's description. A short description of your API.
example: I can use many characters to describe this API.
GenericApi:
type: object
allOf:
- $ref: "#/components/schemas/BaseApi"
- properties:
crossId:
type: string
description: API's crossId. Identifies API across environments.
example: df83b2a4-cc3e-3f80-9f0d-c138c106c076
apiVersion:
type: string
description: API's version. It's a simple string only used in the portal.
example: v1.0
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
deployedAt:
type: string
format: date-time
description: The last date (as timestamp) when the API was deployed.
example: 1581256457163
createdAt:
type: string
format: date-time
description: The date (as timestamp) when the API was created.
example: 1581256457163
updatedAt:
type: string
format: date-time
description: The last date (as timestamp) when the API was updated.
example: 1581256457163
disableMembershipNotifications:
type: boolean
description: Disable membership notifications.
default: false
# metadata ==> dedicated resource
groups:
type: array
description: API's groups. Used to add team in your API.
example:
- MY_GROUP1
- MY_GROUP2
items:
type: string
state:
type: string
description: The state of the API regarding the gateway(s).
example: STARTED
enum:
- CLOSED
- INITIALIZED
- STARTED
- STOPPED
- STOPPING
deploymentState:
type: string
description: The deployment state of the API regarding the gateway(s).
example: DEPLOYED
enum:
- NEED_REDEPLOY
- DEPLOYED
visibility:
$ref: "#/components/schemas/Visibility"
labels:
type: array
description: The free list of labels associated with this API.
example:
- json
- read_only
- awesome
items:
type: string
lifecycleState:
$ref: "#/components/schemas/ApiLifecycleState"
tags:
type: array
description: The list of sharding tags associated with this API.
example:
- public
- private
items:
type: string
primaryOwner:
$ref: "#/components/schemas/PrimaryOwner"
categories:
type: array
description: The list of category ids associated with this API.
example:
- 6c530064-0b2c-4004-9300-640b2ce0047b
- 12559b64-0b2c-4004-9300-640b2ce0047b
items:
type: string
definitionContext:
$ref: "#/components/schemas/DefinitionContext"
workflowState:
$ref: "#/components/schemas/ApiWorkflowState"
responseTemplates:
type: object
additionalProperties:
type: object
additionalProperties:
$ref: "#/components/schemas/ResponseTemplate"
# plans ==> dedicated resource
resources:
type: array
items:
$ref: "#/components/schemas/Resource"
properties:
type: array
items:
$ref: "#/components/schemas/Property"
_links:
$ref: "#/components/schemas/ApiLinks"
discriminator:
propertyName: definitionVersion
mapping:
V1: ApiV1
V2: ApiV2
V4: ApiV4
required:
- definitionVersion
ApiV1:
type: object
allOf:
- $ref: "#/components/schemas/GenericApi"
- properties:
environmentId:
type: string
description: The environment's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
executionMode:
$ref: "#/components/schemas/ExecutionMode"
contextPath:
type: string
description: The context path of the API.
example: /my-api
proxy:
$ref: "#/components/schemas/Proxy"
paths:
type: object
additionalProperties:
type: array
description: a map where you can associate a path to a configuration (the
policies configuration)
items:
$ref: "#/components/schemas/Rule"
services:
$ref: "#/components/schemas/ApiServicesV2"
pathMappings:
type: array
description: The list of path mappings associated with this API.
items:
type: string
entrypoints:
type: array
description: The list of entrypoints associated with this API.
items:
$ref: "#/components/schemas/ApiEntrypoint"
ApiV2:
type: object
allOf:
- $ref: "#/components/schemas/GenericApi"
- properties:
environmentId:
type: string
description: The environment's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
executionMode:
$ref: "#/components/schemas/ExecutionMode"
contextPath:
type: string
description: The context path of the API.
example: /my-api
proxy:
$ref: "#/components/schemas/Proxy"
flowMode:
$ref: "#/components/schemas/FlowMode"
flows:
type: array
description: The list of flows associated with this API.
items:
$ref: "#/components/schemas/FlowV2"
services:
$ref: "#/components/schemas/ApiServicesV2"
pathMappings:
type: array
description: The list of path mappings associated with this API.
items:
type: string
entrypoints:
type: array
description: The list of entrypoints associated with this API.
items:
$ref: "#/components/schemas/ApiEntrypoint"
ApiV4:
type: object
allOf:
- $ref: "#/components/schemas/GenericApi"
- properties:
type:
$ref: "#/components/schemas/ApiType"
listeners:
type: array
description: The list of listeners associated with this API.
items:
$ref: "#/components/schemas/Listener"
endpointGroups:
type: array
items:
$ref: "#/components/schemas/EndpointGroupV4"
analytics:
$ref: "#/components/schemas/Analytics"
flowExecution:
$ref: "#/components/schemas/FlowExecution"
flows:
type: array
items:
$ref: "#/components/schemas/FlowV4"
services:
$ref: "#/components/schemas/ApiServices"
ApiLinks:
type: object
properties:
pictureUrl:
type: string
description: The URL to the API's picture.
example: https://gravitee.example.com/management/v2/environments/00f8c9e7-78fc-4907-b8c9-e778fc790750/apis/6c530064-0b2c-4004-9300-640b2ce0047b/picture
backgroundUrl:
type: string
description: The URL to the API's background.
example: https://gravitee.example.com/management/v2/environments/00f8c9e7-78fc-4907-b8c9-e778fc790750/apis/6c530064-0b2c-4004-9300-640b2ce0047b/background
CreateApi:
oneOf:
- $ref: "#/components/schemas/CreateApiV2"
- $ref: "#/components/schemas/CreateApiV4"
discriminator:
propertyName: definitionVersion
mapping:
V2: CreateApiV2
V4: CreateApiV4
CreateGenericApi:
type: object
properties:
name:
type: string
description: API's name. Duplicate names can exists.
example: My Api
minLength: 1
apiVersion:
type: string
description: API's version. It's a simple string only used in the portal.
example: v1.0
minLength: 1
description:
type: string
description: API's description. A short description of your API.
example: I can use many characters to describe this API.
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
groups:
type: array
description: API's groups. Used to add team in your API.
example:
- MY_GROUP1
- MY_GROUP2
items:
type: string
required: [name, apiVersion, definitionVersion]
discriminator:
propertyName: definitionVersion
mapping:
V2: CreateApiV2
V4: CreateApiV4
CreateApiV2:
type: object
allOf:
- $ref: "#/components/schemas/CreateGenericApi"
- properties:
contextPath:
type: string
description: API's context path. It's the base path of your API.
example: /my-api
minLength: 3
endpoint:
type: string
description: API's endpoint. It's the base URL of your API.
example: https://my-api.mycompany.com
minLength: 1
flows:
type: array
items:
$ref: "#/components/schemas/FlowV2"
flowMode:
$ref: "#/components/schemas/FlowMode"
required: [contextPath, endpoint]
CreateApiV4:
type: object
allOf:
- $ref: "#/components/schemas/CreateGenericApi"
- properties:
type:
$ref: "#/components/schemas/ApiType"
tags:
type: array
description: The list of sharding tags associated with this API.
example:
- public
- private
items:
type: string
uniqueItems: true
listeners:
type: array
description: The list of listeners associated with this API.
items:
$ref: "#/components/schemas/Listener"
minItems: 1
endpointGroups:
type: array
items:
$ref: "#/components/schemas/EndpointGroupV4"
minItems: 1
analytics:
$ref: "#/components/schemas/Analytics"
flowExecution:
$ref: "#/components/schemas/FlowExecution"
flows:
type: array
items:
$ref: "#/components/schemas/FlowV4"
required: [listeners, endpointGroups, type]
ExportApiV4:
type: object
properties:
api:
$ref: "#/components/schemas/ApiV4"
members:
type: array
description: The list of members associated with this API.
items:
$ref: "#/components/schemas/Member"
uniqueItems: true
metadata:
type: array
description: The list of API's metadata.
items:
$ref: "#/components/schemas/Metadata"
uniqueItems: true
pages:
type: array
description: The list of pages associated with this API.
items:
$ref: "#/components/schemas/Page"
uniqueItems: true
plans:
type: array
description: The list of plans associated with this API.
items:
$ref: "#/components/schemas/PlanV4"
uniqueItems: true
apiPicture:
type: string
format: base64
description: The API's picture.
apiBackground:
type: string
format: base64
description: The API's background.
apiMedia:
type: array
description: The list of API's media used in pages.
items:
$ref: "#/components/schemas/Media"
UpdateApi:
oneOf:
- $ref: "#/components/schemas/UpdateApiV2"
- $ref: "#/components/schemas/UpdateApiV4"
discriminator:
propertyName: definitionVersion
mapping:
V2: UpdateApiV2
V4: UpdateApiV4
UpdateGenericApi:
type: object
properties:
name:
type: string
description: API's name. Duplicate names can exists.
example: My Api
minLength: 1
apiVersion:
type: string
description: API's version. It's a simple string only used in the portal.
example: v1.0
minLength: 1
description:
type: string
description: API's description. A short description of your API.
example: I can use many characters to describe this API.
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
groups:
type: array
description: API's groups. Used to add team in your API.
example:
- MY_GROUP1
- MY_GROUP2
items:
type: string
tags:
type: array
description: The list of sharding tags associated with this API.
example:
- public
- private
items:
type: string
resources:
type: array
items:
$ref: "#/components/schemas/Resource"
responseTemplates:
type: object
additionalProperties:
type: object
additionalProperties:
$ref: "#/components/schemas/ResponseTemplate"
visibility:
$ref: "#/components/schemas/Visibility"
categories:
type: array
description: The list of category ids associated with this API.
example:
- 6c530064-0b2c-4004-9300-640b2ce0047b
- 12559b64-0b2c-4004-9300-640b2ce0047b
items:
type: string
labels:
type: array
description: The free list of labels associated with this API.
example:
- json
- read_only
- awesome
items:
type: string
lifecycleState:
$ref: "#/components/schemas/ApiLifecycleState"
disableMembershipNotifications:
type: boolean
description: Disable membership notifications.
default: false
properties:
type: array
items:
$ref: "#/components/schemas/Property"
required: [name, apiVersion, definitionVersion]
discriminator:
propertyName: definitionVersion
mapping:
V2: UpdateApiV2
V4: UpdateApiV4
UpdateApiV2:
type: object
allOf:
- $ref: "#/components/schemas/UpdateGenericApi"
- properties:
proxy:
$ref: "#/components/schemas/Proxy"
flowMode:
$ref: "#/components/schemas/FlowMode"
flows:
type: array
description: The list of flows associated with this API.
items:
$ref: "#/components/schemas/FlowV2"
services:
$ref: "#/components/schemas/ApiServicesV2"
pathMappings:
type: array
description: The list of path mappings associated with this API.
items:
type: string
executionMode:
$ref: "#/components/schemas/ExecutionMode"
required: [contextPath, endpoint]
UpdateApiV4:
type: object
allOf:
- $ref: "#/components/schemas/UpdateGenericApi"
- properties:
type:
$ref: "#/components/schemas/ApiType"
listeners:
type: array
description: The list of listeners associated with this API.
items:
$ref: "#/components/schemas/Listener"
minItems: 1
endpointGroups:
type: array
items:
$ref: "#/components/schemas/EndpointGroupV4"
minItems: 1
analytics:
$ref: "#/components/schemas/Analytics"
flowExecution:
$ref: "#/components/schemas/FlowExecution"
flows:
type: array
items:
$ref: "#/components/schemas/FlowV4"
services:
$ref: "#/components/schemas/ApiServices"
required: [listeners, endpointGroups, type]
ApiDeployment:
type: object
properties:
deploymentLabel:
type: string
description: Label for an Api deployment. Duplicate names can exists.
example: My deployment
maxLength: 32
ApiLifecycleState:
type: string
description: The status of the API regarding the console.
example: CREATED
enum:
- ARCHIVED
- CREATED
- DEPRECATED
- PUBLISHED
- UNPUBLISHED
ApiServices:
type: object
properties:
dynamicProperty:
$ref: "#/components/schemas/ServiceV4"
ApiSearchQuery:
type: object
properties:
query:
type: string
description: The query to search for.
example: my api
ids:
type: array
items:
type: string
description: List of ids to find
example:
- apiId-1
- apiId-2
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
ApiType:
type: string
description: API's type.
example: MESSAGE
enum:
- MESSAGE
- PROXY
Visibility:
type: string
description: The visibility of the resource regarding the portal.
example: PUBLIC
enum:
- PUBLIC
- PRIVATE
ApiWorkflowState:
type: string
description: The status of the API regarding the review feature.
example: DRAFT
enum:
- DRAFT
- IN_REVIEW
- REQUEST_FOR_CHANGES
- REVIEW_OK
readOnly: true
ChannelSelector:
type: object
required:
- type
- channel
- channelOperator
allOf:
- $ref: "#/components/schemas/BaseSelector"
- type: object
properties:
operations:
type: array
description: The list of operations associated with this channel selector.
items:
type: string
description: The operation associated with this channel selector.
enum:
- PUBLISH
- SUBSCRIBE
uniqueItems: true
channel:
type: string
description: The channel of the selector
example: /my/channel
default: /
channelOperator:
$ref: "#/components/schemas/Operator"
entrypoints:
type: array
items:
type: string
uniqueItems: true
ConditionSelector:
type: object
required:
- type
- condition
allOf:
- $ref: "#/components/schemas/BaseSelector"
- type: object
properties:
condition:
type: string
description: The condition of the selector
example: ${#jsonPath(payload, '$.myField') == 'myValue'}
ConnectorFeature:
type: string
description: A feature used by a connector
example: LIMIT
enum:
- LIMIT
- RESUME
- DLQ
ConnectorMode:
type: string
description: A mode used by a connector
example: SUBSCRIBE
enum:
- SUBSCRIBE
- PUBLISH
- REQUEST_RESPONSE
ConnectorPlugin:
type: object
allOf:
- $ref: "#/components/schemas/PlatformPlugin"
- type: object
properties:
supportedApiType:
$ref: "#/components/schemas/ApiType"
supportedModes:
type: array
items:
$ref: "#/components/schemas/ConnectorMode"
uniqueItems: true
supportedQos:
type: array
items:
$ref: "#/components/schemas/Qos"
uniqueItems: true
supportedListenerType:
$ref: "#/components/schemas/ListenerType"
availableFeatures:
type: array
items:
$ref: "#/components/schemas/ConnectorFeature"
uniqueItems: true
schema:
type: string
description: The schema of the plugin.
subscriptionSchema:
type: string
description: The subscription schema of the plugin.
Cors:
type: object
properties:
allowCredentials:
type: boolean
allowHeaders:
uniqueItems: true
type: array
items:
type: string
allowMethods:
uniqueItems: true
type: array
items:
type: string
allowOrigin:
uniqueItems: true
type: array
items:
type: string
enabled:
type: boolean
exposeHeaders:
uniqueItems: true
type: array
items:
type: string
maxAge:
type: integer
format: int32
default: -1
runPolicies:
type: boolean
Dlq:
type: object
properties:
endpoint:
type: string
description: The endpoint of the DLQ.
DefinitionContext:
type: object
description: the context where the api definition was created
properties:
origin:
type: string
description: The origin of the API.
example: MANAGEMENT
enum:
- MANAGEMENT
- KUBERNETES
mode:
type: string
description: |-
The mode of the API.
fully_managed: Mode indicating the api is fully managed by the origin and so, only the origin should be able to manage the api.
api_definition_only: Mode indicating the api is partially managed by the origin and so, only the origin should be able to manage the api definition part of the api. This includes everything regarding the definition of the apis (plans, flows, metadata, ...)
example: FULLY_MANAGED
enum:
- FULLY_MANAGED
- API_DEFINITION_ONLY
readOnly: true
DefinitionVersion:
type: string
description: API's gravitee definition version.
example: V4
enum:
- V1
- V2
- V4
EndpointV4:
type: object
properties:
name:
type: string
description: The name of the endpoint
example: default-endpoint
nullable: false
type:
type: string
description: The type of the endpoint
example: mock
nullable: false
weight:
type: integer
format: int32
description: The weight of the endpoint
default: 1
inheritConfiguration:
type: boolean
description: Is the configuration of the endpoint inherited from the endpoint group it belongs to.
default: false
configuration:
type: object
sharedConfigurationOverride:
type: object
services:
$ref: "#/components/schemas/EndpointServices"
secondary:
type: boolean
description: Is the endpoint a secondary endpoint.
default: false
tenants:
type: array
description: The list of tenants associated to the endpoint.
items:
type: string
required:
- type
EndpointGroupV4:
type: object
properties:
name:
type: string
description: The name of the endpoint group
example: default-endpoint-group
nullable: false
type:
type: string
description: The type of the endpoint group
example: default
nullable: false
loadBalancer:
$ref: "#/components/schemas/LoadBalancer"
sharedConfiguration:
type: object
endpoints:
type: array
items:
$ref: "#/components/schemas/EndpointV4"
services:
$ref: "#/components/schemas/EndpointGroupServices"
required:
- type
EndpointGroupServices:
type: object
properties:
discovery:
$ref: "#/components/schemas/ServiceV4"
healthcheck:
$ref: "#/components/schemas/ServiceV4"
EndpointServices:
type: object
properties:
healthcheck:
$ref: "#/components/schemas/ServiceV4"
Entrypoint:
type: object
required:
- type
properties:
type:
type: string
description: The type of the entrypoint
example: http-get
nullable: false
qos:
$ref: "#/components/schemas/Qos"
dlq:
$ref: "#/components/schemas/Dlq"
configuration:
type: object
Environment:
type: object
properties:
id:
type: string
description: Environment's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Environment's name. Duplicate names can exists.
example: My Environment
minLength: 1
description:
type: string
description: Environment's description. A short description of your Environment.
example: I can use many characters to describe this Environment.
minLength: 1
Error:
type: object
properties:
httpStatus:
type: integer
format: int32
description: The error code
example: 400
message:
type: string
description: The error message
example: Bad request
technicalCode:
type: string
description: A technical code to identify the error
example: invalid.import.definition
parameters:
type: object
description: A map of parameters to be used in the error message
additionalProperties:
type: string
details:
type: array
description: A list of details about the error
items:
type: object
properties:
message:
type: string
description: The error message
example: Bad request
location:
type: string
description: The json path of the field in error.
example: updateApi.properties[0].key
invalidValue:
type: object
description: The invalid value.
FlowV4:
type: object
properties:
name:
type: string
description: Flow's name.
example: My Flow
enabled:
type: boolean
description: Is the flow enabled.
default: true
selectors:
type: array
items:
$ref: "#/components/schemas/Selector"
request:
type: array
items:
$ref: "#/components/schemas/StepV4"
response:
type: array
items:
$ref: "#/components/schemas/StepV4"
subscribe:
type: array
items:
$ref: "#/components/schemas/StepV4"
publish:
type: array
items:
$ref: "#/components/schemas/StepV4"
tags:
type: array
items:
type: string
description: Flow's tags.
example:
- tag1
- tag2
uniqueItems: true
FlowExecution:
type: object
properties:
mode:
$ref: "#/components/schemas/FlowMode"
matchRequired:
type: boolean
description: Is the flow execution match required.
default: false
FlowMode:
type: string
description: API's flow mode.
example: BEST_MATCH
default: DEFAULT
enum:
- BEST_MATCH
- DEFAULT
HttpListener:
type: object
required:
- type
allOf:
- $ref: "#/components/schemas/BaseListener"
- type: object
properties:
paths:
type: array
minItems: 1
items:
$ref: "#/components/schemas/PathV4"
pathMappings:
type: array
items:
type: string
cors:
$ref: "#/components/schemas/Cors"
HttpMethod:
type: string
description: The method of the selector
example: GET
enum:
- CONNECT
- DELETE
- GET
- HEAD
- OPTIONS
- PATCH
- POST
- PUT
- TRACE
- OTHER
HttpSelector:
type: object
required:
- type
- path
- pathOperator
allOf:
- $ref: "#/components/schemas/BaseSelector"
- type: object
properties:
path:
type: string
description: The path of the selector
example: /my/path
default: /
pathOperator:
$ref: "#/components/schemas/Operator"
methods:
type: array
items:
$ref: "#/components/schemas/HttpMethod"
uniqueItems: true
Links:
description: List of links for pagination
properties:
self:
type: string
description: Link to current resource
first:
type: string
description: In a paginated response, link to the first page
last:
type: string
description: In a paginated response, link to the last page
previous:
type: string
description: In a paginated response, link to the previous page. Maybe null if current is the first page
next:
type: string
description: In a paginated response, link to the next page. Maybe null if current is the last page
Listener:
oneOf:
- $ref: "#/components/schemas/HttpListener"
- $ref: "#/components/schemas/SubscriptionListener"
- $ref: "#/components/schemas/TcpListener"
discriminator:
propertyName: type
mapping:
HTTP: HttpListener
TCP: TcpListener
SUBSCRIPTION: SubscriptionListener
BaseListener:
type: object
required:
- type
properties:
type:
$ref: "#/components/schemas/ListenerType"
entrypoints:
type: array
minItems: 1
items:
$ref: "#/components/schemas/Entrypoint"
servers:
type: array
items:
type: string
discriminator:
propertyName: type
mapping:
HTTP: HttpListener
TCP: TcpListener
SUBSCRIPTION: SubscriptionListener
ListenerType:
type: string
description: Listener type.
example: HTTP
enum:
- HTTP
- SUBSCRIPTION
- TCP
LoadBalancer:
type: object
properties:
type:
type: string
description: Load balancer type.
example: ROUND_ROBIN
default: ROUND_ROBIN
enum:
- RANDOM
- ROUND_ROBIN
- WEIGHTED_RANDOM
- WEIGHTED_ROUND_ROBIN
LoggingV4:
type: object
properties:
condition:
type: string
messageCondition:
type: string
content:
$ref: "#/components/schemas/LoggingContentV4"
phase:
$ref: "#/components/schemas/LoggingPhase"
mode:
$ref: "#/components/schemas/LoggingModeV4"
LoggingContentV4:
type: object
properties:
headers:
type: boolean
messageHeaders:
type: boolean
payload:
type: boolean
messagePayload:
type: boolean
messageMetadata:
type: boolean
LoggingModeV4:
type: object
properties:
endpoint:
type: boolean
entrypoint:
type: boolean
LoggingPhase:
type: object
properties:
request:
type: boolean
response:
type: boolean
MetadataResponse:
description: Generic object to handle additional information about an entity. Can also be used for pagination data.
type: object
MoreInformation:
type: object
properties:
description:
type: string
description: Plugin's description.
example: Let your consumers send synchronous, on-demand requests for events via a standard HTTP GET requests. Use a standard HTTP proxy to mediate between client applications as data consumers and event brokers such as Kafka.
documentationUrl:
type: string
description: Plugin's documentation URL.
example: https://docs.gravitee.io
schemaImg:
type: string
description: Plugin's schema image as base64.
format: base64
example: 
Operator:
type: string
description: The path operator of the selector
example: EQUALS
default: STARTS_WITH
enum:
- EQUALS
- STARTS_WITH
Organization:
type: object
properties:
id:
type: string
description: Organization's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Organization's name. Duplicate names can exists.
example: My Organization
minLength: 1
description:
type: string
description: Organization's description. A short description of your Organization.
example: I can use many characters to describe this Organization.
minLength: 1
Pagination:
description: Generic object to handle pagination data.
type: object
properties:
page:
type: integer
description: The current page.
perPage:
type: integer
description: The number of items requested per page.
pageCount:
type: integer
description: The total number of pages.
pageItemsCount:
type: integer
description: The number of items for the current page.
totalCount:
type: integer
description: The total number of items.
PathV4:
type: object
properties:
host:
type: string
path:
type: string
default: "/"
overrideAccess:
type: boolean
default: false
ApiReview:
type: object
properties:
message:
type: string
description: Optional message from the API reviewer.
BasePlan:
type: object
properties:
id:
type: string
description: Plan's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Plan's name. Duplicate names can exists.
example: My Api plan
description:
type: string
description: Plan's description. A short description of your plan.
example: I can use a hundred characters to describe this plan.
apiId:
type: string
description: Id of the API owning the plan.
example: 6c530064-0b2c-4004-9300-640b2ce0047b
security:
$ref: "#/components/schemas/PlanSecurity"
GenericPlan:
type: object
allOf:
- $ref: "#/components/schemas/BasePlan"
- properties:
characteristics:
type: array
items:
type: string
closedAt:
type: string
format: date-time
description: The datetime when the plan was closed.
example: 2023-05-25T12:40:46.184Z
commentMessage:
type: string
description: A message from the API Publisher that is displayed to the consumer at subscription time.
example: Explain why you want to subscribe.
commentRequired:
type: boolean
description: A flag indicating if the consumer has to write a "consumer message" or if he/she can leave the field blank.
createdAt:
type: string
format: date-time
description: The last datetime when the plan was created.
example: 2023-05-25T12:40:46.184Z
crossId:
type: string
description: Plan's crossId. Identifies plan across environments.
example: df83b2a4-cc3e-3f80-9f0d-c138c106c076
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
description:
type: string
description: Plan's description. A short description of your plan.
example: I can use a hundred characters to describe this plan.
excludedGroups:
type: array
description: Groups of users which are not allowed to subscribe to this plan.
example:
- MY_GROUP1
- MY_GROUP2
items:
type: string
generalConditions:
type: string
order:
type: integer
publishedAt:
type: string
format: date-time
description: The last datetime when the plan was published.
example: 2023-05-25T12:40:46.184Z
selectionRule:
type: string
status:
$ref: "#/components/schemas/PlanStatus"
tags:
type: array
description: The list of sharding tags associated with this plan.
example:
- public
- private
items:
type: string
type:
$ref: "#/components/schemas/PlanType"
updatedAt:
type: string
format: date-time
description: The last datetime when the plan was updated.
example: 2023-05-25T12:40:46.184Z
validation:
$ref: "#/components/schemas/PlanValidation"
required:
- definitionVersion
discriminator:
propertyName: definitionVersion
mapping:
V2: PlanV2
V4: PlanV4
PlanV4:
type: object
allOf:
- $ref: "#/components/schemas/GenericPlan"
- properties:
flows:
type: array
items:
$ref: "#/components/schemas/FlowV4"
mode:
$ref: "#/components/schemas/PlanMode"
Plan:
oneOf:
- $ref: "#/components/schemas/PlanV2"
- $ref: "#/components/schemas/PlanV4"
discriminator:
propertyName: definitionVersion
mapping:
V2: PlanV2
V4: PlanV4
PlanSecurity:
type: object
properties:
type:
$ref: "#/components/schemas/PlanSecurityType"
configuration:
type: object
required:
- type
PlanSecurityType:
type: string
description: Plan security type.
example: KEY_LESS
enum:
- KEY_LESS
- API_KEY
- OAUTH2
- JWT
PlanStatus:
type: string
description: Plan status.
example: STAGING
enum:
- STAGING
- PUBLISHED
- DEPRECATED
- CLOSED
PlanType:
type: string
description: Plan type.
example: API
enum:
- API
- CATALOG
PlanValidation:
type: string
description: Plan validation type.
example: AUTO
enum:
- AUTO
- MANUAL
CreatePlan:
oneOf:
- $ref: "#/components/schemas/CreatePlanV2"
- $ref: "#/components/schemas/CreatePlanV4"
discriminator:
propertyName: definitionVersion
mapping:
V2: CreatePlanV2
V4: CreatePlanV4
CreateGenericPlan:
type: object
properties:
crossId:
type: string
description: Plan's crossId. Identifies plan across environments.
example: df83b2a4-cc3e-3f80-9f0d-c138c106c076
characteristics:
type: array
items:
type: string
commentMessage:
type: string
description: A message from the API Publisher that is displayed to the consumer at subscription time.
example: Explain why you want to subscribe.
commentRequired:
type: boolean
description: A flag indicating if the consumer has to write a "consumer message" or if he/she can leave the field blank.
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
description:
type: string
description: Plan's description. A short description of your Plan.
example: I can use a hundred characters to describe this plan.
excludedGroups:
type: array
description: Groups of users which are not allowed to subscribe to this plan.
example:
- MY_GROUP1
- MY_GROUP2
items:
type: string
generalConditions:
type: string
description: This field contains the UUID of the documentation page that is used as General Conditions.
example: 4e3de652-2301-48ba-bde6-522301e8ba3a
name:
type: string
description: Plan's name. Duplicate names can exists.
example: My Api plan
order:
type: integer
description: Simple order that could be used by a front end to display plans in a certain order. To highlight a plan on the portal for instance.
example: 0
security:
$ref: "#/components/schemas/PlanSecurity"
selectionRule:
type: string
description: An optional EL expression that will be evaluated at request time to select this plan.
tags:
type: array
description: The list of sharding tags associated with this plan.
example:
- public
- private
items:
type: string
validation:
$ref: "#/components/schemas/PlanValidation"
discriminator:
propertyName: definitionVersion
mapping:
V2: CreatePlanV2
V4: CreatePlanV4
required:
- definitionVersion
CreatePlanV2:
type: object
allOf:
- $ref: "#/components/schemas/CreateGenericPlan"
- properties:
flows:
type: array
items:
$ref: "#/components/schemas/FlowV2"
CreatePlanV4:
type: object
allOf:
- $ref: "#/components/schemas/CreateGenericPlan"
- properties:
flows:
type: array
items:
$ref: "#/components/schemas/FlowV4"
mode:
$ref: "#/components/schemas/PlanMode"
PlanMode:
type: string
description: The behavioural mode of the Plan (Standard for classical plan, Push for subscription plan).
example: STANDARD
enum:
- STANDARD
- PUSH
UpdatePlan:
oneOf:
- $ref: "#/components/schemas/UpdatePlanV2"
- $ref: "#/components/schemas/UpdatePlanV4"
discriminator:
propertyName: definitionVersion
mapping:
V2: UpdatePlanV2
V4: UpdatePlanV4
UpdateGenericPlan:
type: object
properties:
crossId:
type: string
description: Plan's crossId. Identifies plan across environments.
example: df83b2a4-cc3e-3f80-9f0d-c138c106c076
characteristics:
type: array
items:
type: string
commentMessage:
type: string
description: A message from the API Publisher that is displayed to the consumer at subscription time.
example: Explain why you want to subscribe.
commentRequired:
type: boolean
description: A flag indicating if the consumer has to write a "consumer message" or if he/she can leave the field blank.
definitionVersion:
$ref: "#/components/schemas/DefinitionVersion"
description:
type: string
description: Plan's description. A short description of your Plan.
example: I can use a hundred characters to describe this plan.
excludedGroups:
type: array
description: Groups of users which are not allowed to subscribe to this plan.
example:
- MY_GROUP1
- MY_GROUP2
items:
type: string
generalConditions:
type: string
description: This field contains the UUID of the documentation page that is used as General Conditions.
example: 4e3de652-2301-48ba-bde6-522301e8ba3a
name:
type: string
description: Plan's name. Duplicate names can exists.
example: My Api plan
order:
type: integer
description: Simple order that could be used by a front end to display plans in a certain order. To highlight a plan on the portal for instance.
example: 0
security:
type: object
properties:
configuration:
type: object
selectionRule:
type: string
description: An optional EL expression that will be evaluated at request time to select this plan.
tags:
type: array
description: The list of sharding tags associated with this plan.
example:
- public
- private
items:
type: string
validation:
$ref: "#/components/schemas/PlanValidation"
discriminator:
propertyName: definitionVersion
mapping:
V2: UpdatePlanV2
V4: UpdatePlanV4
required:
- definitionVersion
UpdatePlanV2:
type: object
allOf:
- $ref: "#/components/schemas/UpdateGenericPlan"
- properties:
flows:
type: array
items:
$ref: "#/components/schemas/FlowV2"
paths:
type: object
additionalProperties:
type: array
items:
$ref: "#/components/schemas/Rule"
UpdatePlanV4:
type: object
allOf:
- $ref: "#/components/schemas/UpdateGenericPlan"
- properties:
flows:
type: array
items:
$ref: "#/components/schemas/FlowV4"
BaseSubscription:
type: object
properties:
id:
type: string
description: Subscription's uuid.
example: 34f8c9e7-68fd-4922-b8c9-e778fc790777
Subscription:
allOf:
- $ref: "#/components/schemas/BaseSubscription"
- properties:
api:
$ref: "#/components/schemas/BaseApi"
plan:
$ref: "#/components/schemas/BasePlan"
application:
$ref: "#/components/schemas/BaseApplication"
consumerMessage:
type: string
description: Message given by the api consumer when subscribing to the api.
publisherMessage:
type: string
description: Message given by the api publisher when accepting or rejecting the subscription.
metadata:
type: object
description: A list of metadata associated to this subscription.
additionalProperties:
type: string
daysToExpirationOnLastNotification:
type: integer
format: int32
description: Number of days before the expiration of this subscription when the last pre-expiration notification was sent.
consumerConfiguration:
$ref: "#/components/schemas/SubscriptionConsumerConfiguration"
failureCause:
type: string
description: Details about the last failure encountered on this subscription.
status:
$ref: "#/components/schemas/SubscriptionStatus"
consumerStatus:
$ref: "#/components/schemas/SubscriptionConsumerStatus"
processedBy:
$ref: "#/components/schemas/BaseUser"
subscribedBy:
$ref: "#/components/schemas/BaseUser"
processedAt:
type: string
format: date-time
description: The datetime when the subscription was processed.
example: 2023-05-18T12:40:46.184Z
startingAt:
type: string
format: date-time
description: The datetime when the subscription starts. No starting date means the subscription starts immediately.
example: 2023-05-20T12:30:42.101Z
endingAt:
type: string
format: date-time
description: The datetime when the subscription ends. No ending date means the subscription never ends.
example: 2023-05-25T12:40:46.184Z
createdAt:
type: string
format: date-time
description: The datetime when the subscription was created.
example: 2023-05-18T12:40:46.184Z
updatedAt:
type: string
format: date-time
description: The last datetime when the subscription was updated.
example: 2023-05-25T12:40:46.184Z
closedAt:
type: string
format: date-time
description: The datetime when the subscription was closed.
example: 2023-05-31T13:40:46.184Z
pausedAt:
type: string
format: date-time
description: The datetime when the subscription was paused by the api publisher.
example: 2023-05-25T12:40:46.184Z
consumerPausedAt:
type: string
format: date-time
description: The datetime when the subscription was paused by the api consumer.
example: 2023-05-25T12:40:46.184Z
SubscriptionStatus:
type: string
description: The status of the subscription manageable by the api publisher.
example: ACCEPTED
enum:
- PENDING
- REJECTED
- ACCEPTED
- CLOSED
- PAUSED
- RESUMED
SubscriptionConsumerStatus:
type: string
description: The status of the subscription manageable by the api consumer.
example: STOPPED
enum:
- STARTED
- STOPPED
- FAILURE
SubscriptionConsumerConfiguration:
type: object
description: Consumer configuration associated to the subscription in case it is attached to a push plan.
properties:
entrypointId:
type: string
description: The id of the targeted entrypoint
example: webhook
channel:
type: string
description: The channel to consume
example: /channel1
entrypointConfiguration:
type: object
description: The configuration to use at subscription time to push to the target service.
example: |
{
"callbackUrl": "https://webhook.site/aaaaaaaa-ffff-ffff-ffff-aaaaaaaa",
"headers": [
{
"name": "demoHeader",
"value": "my-value"
},
{
"name": "anotherHeader",
"value": "my-value2"
}
]
}
required: [entrypointId]
CreateSubscription:
type: object
properties:
applicationId:
type: string
description: The id of the application subscribing.
planId:
type: string
description: The id plan the application is subscribing to.
customApiKey:
type: string
description: Optional custom API Key that can be given when the subscription is related to an api-key plan and custom API Key support is enabled.
consumerConfiguration:
$ref: "#/components/schemas/SubscriptionConsumerConfiguration"
metadata:
type: object
description: A list of metadata associated to this subscription.
additionalProperties:
type: string
required: [applicationId, planId]
UpdateSubscription:
type: object
properties:
consumerConfiguration:
$ref: "#/components/schemas/SubscriptionConsumerConfiguration"
metadata:
type: object
description: A list of metadata associated to this subscription.
additionalProperties:
type: string
startingAt:
type: string
format: date-time
description: The datetime when the subscription starts. No starting date means the subscription starts immediately.
example: 2023-05-20T12:30:42.101Z
endingAt:
type: string
format: date-time
description: The datetime when the subscription ends. No ending date means the subscription never ends.
example: 2023-05-25T12:40:46.184Z
VerifySubscription:
type: object
properties:
applicationId:
type: string
description: The id of the application subscribing.
apiKey:
type: string
description: 'The API Key that needs to be verified. Should not contain: ^ # % @ \\ / ; = ? | ~ , (space)'
pattern: '^[^#%@/;=?|^~, \\]*$'
required: [applicationId, apiKey]
VerifySubscriptionResponse:
type: object
properties:
ok:
type: boolean
description: Indicates whether the creation can be done or not.
reason:
type: string
description: An optional reason giving details about the result.
AcceptSubscription:
type: object
properties:
reason:
type: string
description: Optional reason explaining why the subscription has been accepted.
customApiKey:
type: string
description: Optional custom API Key that can be given when the subscription is related to an api-key plan and custom API Key support is enabled.
startingAt:
type: string
format: date-time
description: The datetime when the subscription starts. No starting date means the subscription starts immediately.
example: 2023-05-20T12:30:42.101Z
endingAt:
type: string
format: date-time
description: The datetime when the subscription ends. No ending date means the subscription never ends.
example: 2023-05-25T12:40:46.184Z
RejectSubscription:
type: object
properties:
reason:
type: string
description: Optional reason explaining why the subscription has been rejected.
TransferSubscription:
type: object
properties:
planId:
type: string
description: The plan identifier to transfer the subscription to.
ApiKey:
type: object
properties:
id:
type: string
description: The internal UUID of the API Key.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
key:
type: string
description: The API Key value to use to call the protected api.
example: my-api-key
application:
$ref: "#/components/schemas/BaseApplication"
subscriptions:
type: array
items:
$ref: "#/components/schemas/BaseSubscription"
description: The list of subscriptions using this API Key. Multiple subscription is possible with shared API Key.
revoked:
type: boolean
description: Flag indicating that the API Key has been revoked.
paused:
type: boolean
description: Flag indicating that the API Key has been paused.
expired:
type: boolean
description: Flag indicating that the API Key has expired.
daysToExpirationOnLastNotification:
type: integer
format: int32
description: Number of days before the expiration of this subscription when the last pre-expiration notification was sent.
expireAt:
type: string
format: date-time
description: The datetime when the API Key expires. No date means no expiration.
example: 2023-05-18T12:40:46.184Z
createdAt:
type: string
format: date-time
description: The datetime when the API Key has been created.
example: 2023-01-18T12:40:46.184Z
updatedAt:
type: string
format: date-time
description: The datetime when the API Key has been updated.
example: 2023-01-18T12:40:46.184Z
revokedAt:
type: string
format: date-time
description: The datetime when the API Key has been revoke. No date means not revoked.
example: 2023-01-18T12:40:46.184Z
UpdateApiKey:
type: object
properties:
expireAt:
type: string
format: date-time
description: The datetime when the API Key expires. No date means no expiration.
example: 2023-05-18T12:40:46.184Z
RenewApiKey:
type: object
properties:
customApiKey:
type: string
description: Optional custom API Key that can be given when custom API Key support is enabled.
BaseUser:
type: object
description: Base information about a user.
properties:
id:
type: string
description: User's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
displayName:
type: string
description: User's name.
example: John Doe
BaseApplication:
type: object
properties:
id:
type: string
description: Application's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Application's name. Duplicate names can exist.
example: My App
description:
type: string
description: Application's description. A short description of your App.
example: I can use a hundred characters to describe this App.
domain:
type: string
description: Application's domain. Domain used by application, if relevant.
example: https://my-app.com
type:
type: string
description: Application's type.
example: iOS
primaryOwner:
$ref: "#/components/schemas/PrimaryOwner"
Member:
type: object
properties:
id:
type: string
description: Member's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
displayName:
type: string
description: Member's name.
example: John Doe
minLength: 1
roles:
type: array
items:
$ref: "#/components/schemas/Role"
description: The list of roles for this Member.
Role:
type: object
properties:
name:
type: string
description: Role's name.
example: OWNER
scope:
$ref: "#/components/schemas/RoleScope"
RoleScope:
type: string
description: Scope of a role.
enum:
- API
- APPLICATION
- GROUP
- ENVIRONMENT
- ORGANIZATION
- PLATFORM
AddApiMember:
type: object
description: Membership can be created for existing users, or for users provided by external identity provider. Thus, either userId or externalReference are required.
properties:
userId:
type: string
description: Technical identifier for existing user.
externalReference:
type: string
description: User's reference for user provided from an identity provider.
roleName:
type: string
description: The name of the role
minLength: 1
required: [roleName]
UpdateApiMember:
type: object
properties:
roleName:
type: string
description: The name of the role
minLength: 1
required: [roleName]
PolicyPlugin:
type: object
allOf:
- $ref: "#/components/schemas/PlatformPlugin"
- type: object
properties:
proxy:
type: array
uniqueItems: true
items:
$ref: "#/components/schemas/ExecutionPhase"
message:
type: array
uniqueItems: true
items:
$ref: "#/components/schemas/ExecutionPhase"
PlatformPlugin:
type: object
properties:
id:
type: string
description: Plugin's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Plugin's name.
example: My Plugin
minLength: 1
description:
type: string
description: Plugin's description.
example: I can use many characters to describe this plugin.
minLength: 1
icon:
type: string
description: Plugin's icon.
minLength: 1
category:
type: string
description: Plugin's category.
example: policy
minLength: 1
version:
type: string
description: Plugin's version.
example: 1.0.0
minLength: 1
deployed:
type: boolean
description: The deployment status of the plugin.
PrimaryOwner:
type: object
properties:
id:
type: string
description: Owner's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
email:
type: string
description: Owner's email. Can be null if owner is a group.
displayName:
type: string
description: Owner's name.
example: John Doe
minLength: 1
type:
type: string
description: Owner's type.
example: USER
enum:
- USER
- GROUP
Property:
type: object
required:
- key
- value
properties:
key:
type: string
value:
type: string
encrypted:
type: boolean
dynamic:
type: boolean
encryptable:
type: boolean
writeOnly: true
Qos:
type: string
description: Type of the quality of service.
example: NONE
default: AUTO
enum:
- NONE
- AUTO
- AT_MOST_ONCE
- AT_LEAST_ONCE
Resource:
type: object
required:
- name
- type
- configuration
properties:
name:
type: string
type:
type: string
configuration:
type: object
enabled:
type: boolean
ResponseTemplate:
type: object
properties:
# TODO: How to specify that json output is "status"?
statusCode:
type: integer
headers:
type: object
additionalProperties:
type: string
body:
type: string
Sampling:
type: object
properties:
type:
type: string
description: The type of the sampling
enum:
- PROBABILITY
- TEMPORAL
- COUNT
- QUERY
value:
type: string
description: The value of the sampling
required:
- type
Selector:
oneOf:
- $ref: "#/components/schemas/HttpSelector"
- $ref: "#/components/schemas/ChannelSelector"
- $ref: "#/components/schemas/ConditionSelector"
discriminator:
propertyName: type
mapping:
HTTP: HttpSelector
CHANNEL: ChannelSelector
CONDITION: ConditionSelector
BaseSelector:
properties:
type:
type: string
description: Selector type.
example: HTTP
enum:
- HTTP
- CHANNEL
- CONDITION
discriminator:
propertyName: type
mapping:
HTTP: HttpSelector
CHANNEL: ChannelSelector
CONDITION: ConditionSelector
required:
- type
ServiceV4:
type: object
properties:
overrideConfiguration:
type: boolean
description: Override the configuration of the service
default: false
configuration:
type: object
description: The configuration of the service
enabled:
type: boolean
description: Is the service enabled or not.
default: true
type:
type: string
BaseStep:
type: object
properties:
name:
type: string
description: The name of the step
description:
type: string
description: The description of the step
enabled:
type: boolean
description: Is the step enabled or not.
default: true
policy:
type: string
description: The policy of the step
configuration:
type: object
description: The configuration of the step
condition:
type: string
description: The condition of the step
StepV4:
allOf:
- $ref: "#/components/schemas/BaseStep"
- properties:
messageCondition:
type: string
description: The message condition of the step
SubscriptionListener:
allOf:
- $ref: "#/components/schemas/BaseListener"
TcpListener:
allOf:
- $ref: "#/components/schemas/BaseListener"
## API V2 specific schemas
ApiEntrypoint:
type: object
properties:
target:
type: string
description: The target of the entrypoint.
example: /my-api
host:
type: string
description: The host of the entrypoint.
example: my-api.mycompany.com
tags:
type: array
description: The list of sharding tags associated with this entrypoint.
example:
- public
- private
items:
type: string
Consumer:
type: object
properties:
consumerType:
$ref: "#/components/schemas/ConsumerType"
consumerId:
type: string
description: The id of the consumer.
example: myTag
ConsumerType:
type: string
description: The type of the consumer.
default: TAG
enum:
- TAG
DynamicPropertyProvider:
type: string
description: The type of the dynamic property provider.
example: HTTP
enum:
- HTTP
DynamicPropertyService:
type: object
properties:
schedule:
type: string
description: The schedule of the service
provider:
$ref: "#/components/schemas/DynamicPropertyProvider"
configuration:
oneOf:
- $ref: "#/components/schemas/HttpDynamicPropertyProviderConfiguration"
discriminator:
propertyName: provider
mapping:
HTTP: HttpDynamicPropertyProviderConfiguration
enabled:
type: boolean
description: Is the service enabled or not.
default: true
EndpointV2:
oneOf:
- $ref: "#/components/schemas/HttpEndpointV2"
discriminator:
propertyName: type
mapping:
http: HttpEndpointV2
BaseEndpointV2:
type: object
properties:
name:
type: string
description: The name of the endpoint
example: default-endpoint
nullable: false
target:
type: string
description: The target of the endpoint
example: http://mycompany.com
weight:
type: integer
format: int32
description: The weight of the endpoint
default: 1
backup:
type: boolean
description: Is the endpoint a backup or not.
default: false
status:
$ref: "#/components/schemas/EndpointStatus"
tenants:
type: array
description: The list of tenants associated with this endpoint.
example:
- my-tenant
items:
type: string
type:
type: string
description: The type of the endpoint.
example: HTTP
inherit:
type: boolean
description: Inherit the configuration of the parent endpoint group.
default: true
healthCheck:
$ref: "#/components/schemas/EndpointHealthCheckService"
discriminator:
propertyName: type
mapping:
http: HttpEndpointV2
required:
- type
HttpEndpointV2:
allOf:
- $ref: "#/components/schemas/BaseEndpointV2"
- properties:
httpProxy:
$ref: "#/components/schemas/HttpProxy"
httpClientOptions:
$ref: "#/components/schemas/HttpClientOptions"
httpClientSslOptions:
$ref: "#/components/schemas/HttpClientSslOptions"
headers:
type: array
description: The list of headers associated with this endpoint.
example:
- name: X-My-Header
value: my-value
items:
$ref: "#/components/schemas/HttpHeader"
healthCheck:
$ref: "#/components/schemas/EndpointHealthCheckService"
EndpointDiscoveryService:
type: object
properties:
provider:
type: string
description: The provider of the service
configuration:
type: object
description: The configuration of the service
enabled:
type: boolean
description: Is the service enabled or not.
default: true
EndpointGroupV2:
type: object
properties:
name:
type: string
description: Endpoint group's name.
example: My Endpoint Group
minLength: 1
endpoints:
type: array
description: The list of endpoints associated with this endpoint group.
items:
$ref: "#/components/schemas/EndpointV2"
loadBalancer:
$ref: "#/components/schemas/LoadBalancer"
services:
$ref: "#/components/schemas/EndpointGroupServicesV2"
httpProxy:
$ref: "#/components/schemas/HttpProxy"
httpClientOptions:
$ref: "#/components/schemas/HttpClientOptions"
httpClientSslOptions:
$ref: "#/components/schemas/HttpClientSslOptions"
headers:
type: array
description: The list of headers associated with this endpoint group.
example:
- name: X-My-Header
value: my-value
items:
$ref: "#/components/schemas/HttpHeader"
EndpointHealthCheckService:
allOf:
- $ref: "#/components/schemas/HealthCheckService"
- properties:
inherit:
type: boolean
description: Inherit the configuration of the parent endpoint.
default: true
EndpointStatus:
type: string
description: The status of the endpoint.
example: UP
enum:
- UP
- DOWN
- TRANSITIONALLY_DOWN
- TRANSITIONALLY_UP
ExecutionMode:
type: string
description: The execution mode of the API.
example: V4_EMULATION_ENGINE
default: V4_EMULATION_ENGINE
enum:
- V3
- V4_EMULATION_ENGINE
ExecutionPhase:
type: string
description: The execution phase of a policy.
example: REQUEST
enum:
- REQUEST
- RESPONSE
- MESSAGE_REQUEST
- MESSAGE_RESPONSE
Failover:
type: object
properties:
maxAttempts:
type: integer
format: int32
description: The maximum number of attempts.
default: 1
retryTimeout:
type: integer
format: int64
description: The retry timeout in ms
default: 10000
cases:
type: array
description: The list of cases associated with this failover.
items:
$ref: "#/components/schemas/FailoverCase"
FailoverCase:
type: string
description: The case of the failover.
enum:
- TIMEOUT
FlowStage:
type: string
description: The stage of the flow.
enum:
- PLATFORM
- PLAN
- API
FlowV2:
type: object
properties:
id:
type: string
description: Flow's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Flow's name.
example: My Flow
pathOperator:
$ref: "#/components/schemas/PathOperator"
pre:
type: array
items:
$ref: "#/components/schemas/StepV2"
post:
type: array
items:
$ref: "#/components/schemas/StepV2"
enabled:
type: boolean
description: Is the flow enabled.
default: true
methods:
type: array
items:
$ref: "#/components/schemas/HttpMethod"
condition:
type: string
description: The condition to evaluate to determine if the flow should be executed.
example: "{#request.headers['x-foo'] == 'bar'}"
consumers:
type: array
items:
$ref: "#/components/schemas/Consumer"
stage:
$ref: "#/components/schemas/FlowStage"
HealthCheckRequest:
type: object
properties:
path:
type: string
description: The path of the request
example: /my/path
method:
$ref: "#/components/schemas/HttpMethod"
headers:
type: array
items:
$ref: "#/components/schemas/HttpHeader"
body:
type: string
description: The body of the request
example: my body
fromRoot:
type: boolean
description: Is the request from the root or not
default: false
HealthCheckResponse:
type: object
properties:
assertions:
type: array
items:
type: string
description: The assertion to check
example: "{#response.status == 200}"
HealthCheckService:
type: object
properties:
schedule:
type: string
description: The schedule of the service
steps:
type: array
items:
$ref: "#/components/schemas/HealthCheckStep"
enabled:
type: boolean
description: Is the service enabled or not.
default: true
HealthCheckStep:
type: object
properties:
name:
type: string
description: The name of the step
default: default-step
request:
$ref: "#/components/schemas/HealthCheckRequest"
response:
$ref: "#/components/schemas/HealthCheckResponse"
HttpClientOptions:
type: object
properties:
idleTimeout:
type: integer
format: int32
description: The idle timeout of the http client in ms
default: 60000
connectTimeout:
type: integer
format: int32
description: The connect timeout of the http client in ms
default: 5000
keepAlive:
type: boolean
description: The keep alive parameter of the http client
default: true
readTimeout:
type: integer
format: int32
description: The read timeout of the http client in ms
default: 10000
pipelining:
type: boolean
description: The pipelining parameter of the http client
default: false
maxConcurrentConnections:
type: integer
format: int32
description: The max connections of the http client
default: 100
useCompression:
type: boolean
description: Use compression or not
default: true
propagateClientAcceptEncoding:
type: boolean
description: Propagate the client accept encoding or not
default: false
followRedirects:
type: boolean
description: Follow redirects or not
default: false
clearTextUpgrade:
type: boolean
description: Clear text upgrade or not
default: true
version:
$ref: "#/components/schemas/ProtocolVersion"
HttpClientSslOptions:
type: object
properties:
trustAll:
type: boolean
description: Trust all certificates or not
default: false
hostnameVerifier:
type: boolean
description: Should the hostname be verified or not
default: false
trustStore:
$ref: "#/components/schemas/TrustStore"
keyStore:
$ref: "#/components/schemas/KeyStore"
headers:
type: array
items:
$ref: "#/components/schemas/HttpHeader"
HttpDynamicPropertyProviderConfiguration:
type: object
properties:
url:
type: string
description: The url of the dynamic property provider
example: http://my-provider.com
specification:
type: object
description: The specification of the dynamic property provider
example: my-specification
useSystemProxy:
type: boolean
description: Use the system proxy or not
default: false
method:
$ref: "#/components/schemas/HttpMethod"
headers:
type: array
items:
$ref: "#/components/schemas/HttpHeader"
body:
type: string
description: The body of the request
example: my body
HttpHeader:
type: object
properties:
name:
type: string
description: The name of the header
example: my-header
value:
type: string
description: The value of the header
example: my-value
HttpProxy:
type: object
properties:
enabled:
type: boolean
description: Is the proxy enabled or not
default: false
useSystemProxy:
type: boolean
description: Use the system proxy or not
default: false
host:
type: string
description: The host of the proxy
example: my-proxy.com
port:
type: integer
description: The port of the proxy
example: 8080
username:
type: string
description: The username used to connect to the proxy
example: my-username
password:
type: string
description: The password used to connect to the proxy
example: my-password
type:
$ref: "#/components/schemas/HttpProxyType"
HttpProxyType:
type: string
description: The type of the proxy.
example: HTTP
enum:
- HTTP
- SOCKS4
- SOCKS5
KeyStore:
oneOf:
- $ref: "#/components/schemas/JKSKeyStore"
- $ref: "#/components/schemas/PEMKeyStore"
- $ref: "#/components/schemas/PKCS12KeyStore"
- $ref: "#/components/schemas/NoneKeyStore"
discriminator:
propertyName: type
mapping:
JKS: "#/components/schemas/JKSKeyStore"
PEM: "#/components/schemas/PEMKeyStore"
PKCS12: "#/components/schemas/PKCS12KeyStore"
NONE: "#/components/schemas/NoneKeyStore"
KeyStoreType:
type: string
description: The type of the key store.
example: JKS
enum:
- JKS
- PEM
- PKCS12
- NONE
BaseKeyStore:
type: object
properties:
type:
$ref: "#/components/schemas/KeyStoreType"
discriminator:
propertyName: type
mapping:
JKS: "#/components/schemas/JKSKeyStore"
PEM: "#/components/schemas/PEMKeyStore"
PKCS12: "#/components/schemas/PKCS12KeyStore"
NONE: "#/components/schemas/NoneKeyStore"
required:
- type
JKSKeyStore:
allOf:
- $ref: "#/components/schemas/BaseKeyStore"
- properties:
alias:
type: string
description: The alias of the key store
path:
type: string
description: The path of the key store
example: /path/to/KeyStore.jks
content:
type: string
description: The content of the key store
password:
type: string
description: The password of the key store
keyPassword:
type: string
description: The key password of the key store
PEMKeyStore:
allOf:
- $ref: "#/components/schemas/BaseKeyStore"
- properties:
keyPath:
type: string
description: The path of the key store
example: /path/to/KeyStore.pem
keyContent:
type: string
description: The content of the key store
certPath:
type: string
description: The path of the key store
example: /path/to/KeyStore.pem
certContent:
type: string
description: The content of the key store
PKCS12KeyStore:
allOf:
- $ref: "#/components/schemas/BaseKeyStore"
- properties:
alias:
type: string
description: The alias of the key store
path:
type: string
description: The path of the key store
example: /path/to/KeyStore.jks
content:
type: string
description: The content of the key store
password:
type: string
description: The password of the key store
keyPassword:
type: string
description: The key password of the key store
NoneKeyStore:
allOf:
- $ref: "#/components/schemas/BaseKeyStore"
LoggingV2:
type: object
properties:
mode:
$ref: "#/components/schemas/LoggingModeV2"
scope:
$ref: "#/components/schemas/LoggingScope"
content:
$ref: "#/components/schemas/LoggingContentV2"
condition:
type: string
description: The condition of the logging
example: "{#context.attributes['my-attribute'] == 'my-value'}"
LoggingContentV2:
type: string
description: The content of the logging.
example: NONE
enum:
- NONE
- HEADERS
- PAYLOADS
- HEADERS_PAYLOADS
LoggingModeV2:
type: string
description: The mode of the logging.
example: NONE
enum:
- NONE
- CLIENT
- PROXY
- CLIENT_PROXY
LoggingScope:
type: string
description: The scope of the logging.
example: REQUEST
enum:
- NONE
- REQUEST
- RESPONSE
- REQUEST_RESPONSE
PathOperator:
type: object
properties:
path:
type: string
description: The path of the selector
example: /my/path
operator:
$ref: "#/components/schemas/Operator"
PlanV2:
type: object
allOf:
- $ref: "#/components/schemas/GenericPlan"
- properties:
flows:
type: array
items:
$ref: "#/components/schemas/FlowV2"
paths:
type: object
additionalProperties:
type: array
items:
$ref: "#/components/schemas/Rule"
ProtocolVersion:
type: string
description: The protocol version.
example: HTTP_1_1
default: HTTP_1_1
enum:
- HTTP_1_1
- HTTP_2
Proxy:
type: object
properties:
virtualHosts:
type: array
items:
$ref: "#/components/schemas/VirtualHost"
groups:
type: array
items:
$ref: "#/components/schemas/EndpointGroupV2"
failover:
$ref: "#/components/schemas/Failover"
cors:
$ref: "#/components/schemas/Cors"
logging:
$ref: "#/components/schemas/LoggingV2"
stripContextPath:
type: boolean
default: false
preserveHost:
type: boolean
default: false
servers:
type: array
items:
type: string
ApiServicesV2:
type: object
properties:
dynamicProperty:
$ref: "#/components/schemas/DynamicPropertyService"
healthCheck:
$ref: "#/components/schemas/HealthCheckService"
EndpointGroupServicesV2:
type: object
properties:
discovery:
$ref: "#/components/schemas/EndpointDiscoveryService"
StepV2:
allOf:
- $ref: "#/components/schemas/BaseStep"
TrustStore:
oneOf:
- $ref: "#/components/schemas/JKSTrustStore"
- $ref: "#/components/schemas/PEMTrustStore"
- $ref: "#/components/schemas/PKCS12TrustStore"
- $ref: "#/components/schemas/NoneTrustStore"
discriminator:
propertyName: type
mapping:
JKS: "#/components/schemas/JKSTrustStore"
PEM: "#/components/schemas/PEMTrustStore"
PKCS12: "#/components/schemas/PKCS12TrustStore"
NONE: "#/components/schemas/NoneTrustStore"
TrustStoreType:
type: string
description: The type of the trust store.
example: JKS
enum:
- JKS
- PEM
- PKCS12
- NONE
BaseTrustStore:
type: object
properties:
type:
$ref: "#/components/schemas/TrustStoreType"
discriminator:
propertyName: type
mapping:
JKS: "#/components/schemas/JKSTrustStore"
PEM: "#/components/schemas/PEMTrustStore"
PKCS12: "#/components/schemas/PKCS12TrustStore"
NONE: "#/components/schemas/NoneTrustStore"
JKSTrustStore:
allOf:
- $ref: "#/components/schemas/BaseTrustStore"
- properties:
alias:
type: string
description: The alias of the trust store
path:
type: string
description: The path of the trust store
example: /path/to/truststore.jks
content:
type: string
description: The content of the trust store
password:
type: string
description: The password of the trust store
PEMTrustStore:
allOf:
- $ref: "#/components/schemas/BaseTrustStore"
- properties:
path:
type: string
description: The path of the trust store
example: /path/to/truststore.pem
content:
type: string
description: The content of the trust store
PKCS12TrustStore:
allOf:
- $ref: "#/components/schemas/BaseTrustStore"
- properties:
alias:
type: string
description: The alias of the trust store
path:
type: string
description: The path of the trust store
example: /path/to/truststore.jks
content:
type: string
description: The content of the trust store
password:
type: string
description: The password of the trust store
NoneTrustStore:
allOf:
- $ref: "#/components/schemas/BaseTrustStore"
VirtualHost:
type: object
properties:
host:
type: string
description: The host of the virtual host
path:
type: string
description: The path of the virtual host
default: /
overrideEntrypoint:
type: boolean
description: Override the entrypoint or not
default: false
# Documentation pages
AccessControl:
type: object
properties:
referenceId:
type: string
description: The id of the resource used to check the access control
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
referenceType:
type: string
description: The type of the resource used to check the access control
example:
- GROUP
- ROLE
Media:
type: object
properties:
id:
type: string
description: Media's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
hash:
type: string
description: Media's hash.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
type:
type: string
description: Media's type.
example: image/png
subType:
type: string
description: Media's sub type.
example: png
fileName:
type: string
description: Media's file name.
example: my-image.png
size:
type: integer
format: int64
description: Media's size.
example: 1000
data:
type: string
format: byte
description: Media's data.
example: binary encoded data
createdAt:
type: string
format: date-time
description: Media's creation date.
example: 2018-11-23T22:00:00.000Z
Page:
description: Documentation page. Can be of multiple formats.
type: object
properties:
id:
type: string
description: Page's uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
crossId:
type: string
description: Page's cross uuid.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
name:
type: string
description: Page's name.
example: My Page
type:
$ref: "#/components/schemas/PageType"
content:
type: string
description: Page's content.
example: My Page content
order:
type: integer
description: Page's order.
example: 1
lastContributor:
type: string
description: Page's last contributor. Id of a user.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
published:
type: boolean
description: Page's published status.
example: true
visibility:
$ref: "#/components/schemas/Visibility"
updatedAt:
type: string
format: date-time
description: Page's last update date.
example: 2018-01-01T00:00:00.000Z
contentType:
type: string
description: Page's content type.
example: application/json
source:
$ref: "#/components/schemas/PageSource"
configuration:
type: object
description: Page's configuration.
additionalProperties:
type: string
homepage:
type: boolean
description: Page's homepage status.
example: true
parentId:
type: string
description: Page's parent id.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
parentPath:
type: string
description: Page's parent path.
example: /parent
excludedGroups:
type: array
description: List of group ids that are considered when looking for acces control.
items:
type: string
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
excludedAccessControls:
type: boolean
description: Flag to restrict access to user matching the restrictions.
accessControls:
type: array
description: List of access controls.
items:
$ref: "#/components/schemas/AccessControl"
attachedMedia:
type: array
description: List of attached media.
items:
$ref: "#/components/schemas/PageMedia"
metadata:
type: object
description: Page's metadata.
additionalProperties:
type: string
translations:
type: array
description: List of page translations.
items:
$ref: "#/components/schemas/Page"
generalConditions:
type: boolean
description: Is the page used as General Conditions for a plan.
contentRevision:
$ref: "#/components/schemas/Revision"
PageMedia:
type: object
properties:
name:
type: string
description: Media's name.
example: My Media
hash:
type: string
description: Media's hash.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
attachedAt:
type: string
format: date-time
description: Media's attachment date.
example: 2018-01-01T00:00:00.000Z
PageSource:
type: object
properties:
type:
type: string
description: The type of the page source (=fetcher type).
example:
- http-fetcher
- git-fetcher
- gitlab-fetcher
- github-fetcher
- bitbucket-fetcher
configuration:
type: object
description: Page source's configuration.
PageType:
type: string
description: The type of the page.
example: MARKDOWN
enum:
- ASCIIDOC
- ASYNCAPI
- MARKDOWN
- MARKDOWN_TEMPLATE
- SWAGGER
- FOLDER
- LINK
- ROOT
- SYSTEM_FOLDER
- TRANSLATION
Revision:
type: object
properties:
id:
type: string
description: Id of the page used to fill the content attributes.
example: 00f8c9e7-78fc-4907-b8c9-e778fc790750
revision:
type: integer
description: Revision number.
example: 1
# Metadata Page
Metadata:
type: object
properties:
key:
type: string
description: The key of the metadata.
minLength: 1
name:
type: string
description: The name of the metadata.
format:
$ref: "#/components/schemas/MetadataFormat"
value:
type: string
description: The value of the metadata.
minLength: 1
defaultValue:
type: string
description: The default value of the metadata.
MetadataFormat:
type: string
description: The format of the metadata.
example: DATE
enum:
- STRING
- NUMERIC
- BOOLEAN
- DATE
- MAIL
- URL
Rule:
type: object
properties:
methods:
type: array
items:
$ref: "#/components/schemas/HttpMethod"
description:
type: string
description: The description of the rule
enabled:
type: boolean
description: Is the rule enabled or not.
default: true
operation:
type: string
description: The operation of the rule
configuration:
type: object
description: The configuration of the rule
additionalProperties:
type: object
parameters:
#############
# PathParam #
#############
orgIdParam:
name: orgId
in: path
required: true
description: Id of an organization.
schema:
type: string
default: DEFAULT
envIdParam:
name: envId
in: path
required: true
description: Id or Hrid (Human readable Id) of an environment.
schema:
type: string
default: DEFAULT
apiIdParam:
name: apiId
in: path
required: true
description: Id of an API.
schema:
type: string
groupIdParam:
name: groupId
in: path
required: true
description: Id of a group.
schema:
type: string
memberIdParam:
name: memberId
in: path
required: true
description: Id of an API member.
schema:
type: string
planIdParam:
name: planId
in: path
required: true
description: Id of a plan.
schema:
type: string
subscriptionIdParam:
name: subscriptionId
in: path
required: true
description: Id of a subscription.
schema:
type: string
apiKeyIdParam:
name: apiKeyId
in: path
required: true
description: Id of an API Key.
schema:
type: string
endpointIdParam:
name: endpointId
in: path
required: true
description: Id of an endpoint.
schema:
type: string
entrypointIdParam:
name: entrypointId
in: path
required: true
description: Id of an entrypoint.
schema:
type: string
policyIdParam:
name: policyId
in: path
required: true
description: Id of a policy.
schema:
type: string
###############################
# Pagination Query Parameters #
###############################
apiSortByParam:
name: sortBy
in: query
required: false
description: |-
Possibility to sort APIs results by field.
Can be ascending or descending with minus '-' prefix.
By default, no sort is applied.
schema:
type: string
example: name
enum:
- name
- -name
- paths
- -paths
pageParam:
name: page
in: query
required: false
description: The page number for pagination.
schema:
type: integer
default: 1
perPageParam:
name: perPage
in: query
required: false
description: |
The number of items per page for pagination.
schema:
type: integer
default: 10
###############################
# Other Query Parameters #
###############################
apiExpandsParam:
name: expands
in: query
description: Expansion of data to return in APIs.
schema:
type: array
items:
type: string
enum:
- deploymentState
responses:
EnvironmentsResponse:
description: Page of environments
content:
application/json:
schema:
properties:
data:
description: List of Environments.
type: array
items:
$ref: "#/components/schemas/Environment"
metadata:
$ref: "#/components/schemas/MetadataResponse"
links:
$ref: "#/components/schemas/Links"
ApisResponse:
description: Page of apis
content:
application/json:
schema:
title: "ApisResponse"
properties:
data:
description: List of Apis.
type: array
items:
$ref: "#/components/schemas/Api"
pagination:
$ref: "#/components/schemas/Pagination"
links:
$ref: "#/components/schemas/Links"
ImageResponse:
description: An image
content:
"image/*":
schema:
type: string
format: binary
PlansResponse:
description: Page of API plans
content:
application/json:
schema:
title: "PlansResponse"
properties:
data:
description: List of API plans.
type: array
items:
$ref: "#/components/schemas/Plan"
pagination:
$ref: "#/components/schemas/Pagination"
links:
$ref: "#/components/schemas/Links"
SubscribersResponse:
description: Page of API subscribers
content:
application/json:
schema:
title: "SubscribersResponse"
properties:
data:
description: List of API subscribers.
type: array
items:
$ref: "#/components/schemas/BaseApplication"
pagination:
$ref: "#/components/schemas/Pagination"
links:
$ref: "#/components/schemas/Links"
SubscriptionsResponse:
description: Page of API subscriptions
content:
application/json:
schema:
title: "SubscriptionsResponse"
properties:
data:
description: List of API subscriptions.
type: array
items:
$ref: "#/components/schemas/Subscription"
pagination:
$ref: "#/components/schemas/Pagination"
links:
$ref: "#/components/schemas/Links"
SubscriptionApiKeysResponse:
description: Page of subscription API Keys
content:
application/json:
schema:
title: "SubscriptionApiKeysResponse"
properties:
data:
description: List of subscription API Keys.
type: array
items:
$ref: "#/components/schemas/ApiKey"
pagination:
$ref: "#/components/schemas/Pagination"
links:
$ref: "#/components/schemas/Links"
MembersResponse:
description: Page of API members
content:
application/json:
schema:
title: "MembersResponse"
properties:
data:
description: List of API members.
type: array
items:
$ref: "#/components/schemas/Member"
links:
$ref: "#/components/schemas/Links"
metadata:
$ref: "#/components/schemas/MetadataResponse"
pagination:
$ref: "#/components/schemas/Pagination"
SchemaFormResponse:
description: Schema form of a plugin
content:
application/json:
schema:
type: object
Error:
description: Generic error response
content:
application/json:
schema:
$ref: "#/components/schemas/Error"
securitySchemes:
BasicAuth:
type: http
scheme: basic
CookieAuth:
type: apiKey
in: cookie
name: Auth-Graviteeio-APIM