NAV Navigation
cURL

Event Endpoint Management Admin API

Scroll down for code samples, example requests and responses. Select a language for code samples from the tabs above or the mobile navigation menu.

The Admin API provides programmatic access to your Event Endpoint Management deployment and features from other systems.

Authentication

Access control is provided through HTTP bearer authentication by using access tokens. To use the API, create an access token in the Event Endpoint Management UI.

Default

createCluster

Code samples

# You can also use wget
curl -X POST /{organization}/clusters \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

POST /{organization}/clusters

Create a new Cluster.

Body parameter

{
"type": "object",
"required": [
"name",
"bootstrapServers"
],
"properties": {
"bootstrapServers": {
"description": "Bootstrap servers for this cluster",
"type": "array",
"minItems": 1,
"uniqueItems": true,
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"name": {
"description": "Cluster name",
"type": "string"
},
"lastUpdated": {
"description": "Time in ms since the epoch which represents the last time the cluster information was updated.",
"type": "integer"
},
"credentials": {
"type": "object",
"required": [
"type",
"data"
],
"description": "Credentials be used by the gateway to connect to Kafka",
"properties": {
"type": {
"description": "The type of credentials. Used by parsers to determine how to handle the other fields",
"type": "string",
"enum": [
"NONE",
"SASL",
"MTLS",
"MTLS_SASL"
]
},
"data": {
"description": "Details of the SASL credential data to authenticate with Kafka",
"type": "object",
"properties": {
"username": {
"description": "SASL username to authenticate with Kafka",
"type": "string"
},
"password": {
"description": "SASL password to authenticate with Kafka",
"type": "string"
},
"mechanism": {
"description": "SASL mechanism to authenticate with Kafka",
"type": "string",
"enum": [
"PLAIN",
"SCRAM-SHA-256",
"SCRAM-SHA-512"
]
},
"clientCertificateAndKey": {
"type": "object",
"description": "Client certificate and key to use in mTLS",
"required": [
"pem",
"key"
],
"additionalProperties": false,
"properties": {
"pem": {
"description": "Client certificate in PEM format",
"type": "string"
},
"key": {
"description": "Client key in PEM format",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
disableValidation query boolean false disable immediate validation against the remote server
body body object true none
» bootstrapServers body [object] true Bootstrap servers for this cluster
»» host body string true Kafka server host name.
»» port body integer true Kafka server port.
»» ssl body boolean false Connect over SSL.
»» certificates body [object] false Certificates or CAs to trust when connecting to the server via SSL.
»»» pem body string true Certificate in PEM format
»»» subject body string false Subject name of the certificate
»»» sans body [string] false A list of subject alternative names of the certificate
»»» issuer body string false Issuer of the certificate
»»» expiry body integer false Expiration date of the certificate in epoch millis
» name body string true Cluster name
» lastUpdated body integer false Time in ms since the epoch which represents the last time the cluster information was updated.
» credentials body object false Credentials be used by the gateway to connect to Kafka
»» type body string true The type of credentials. Used by parsers to determine how to handle the other fields
»» data body object true Details of the SASL credential data to authenticate with Kafka
»»» username body string false SASL username to authenticate with Kafka
»»» password body string false SASL password to authenticate with Kafka
»»» mechanism body string false SASL mechanism to authenticate with Kafka
»»» clientCertificateAndKey body object false Client certificate and key to use in mTLS
»»»» pem body string true Client certificate in PEM format
»»»» key body string true Client key in PEM format
»»»» expiry body integer false Expiration date of the certificate in epoch millis

Enumerated Values

Parameter Value
»» type NONE
»» type SASL
»» type MTLS
»» type MTLS_SASL
»»» mechanism PLAIN
»»» mechanism SCRAM-SHA-256
»»» mechanism SCRAM-SHA-512

Example responses

200 Response

{
"type": "object",
"properties": {
"id": {
"description": "The ID of your newly created Cluster",
"type": "string"
}
}
}

Responses

Status Meaning Description Schema
200 OK Cluster successfully created Inline
400 Bad Request Bad input None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
409 Conflict A Cluster with the specified ID or name already exists None
422 Unprocessable Entity The specified Cluster could not be validated using Kafka discovery mechanisms e.g. connection fails, certs mis-matched, SASL mis-match None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string false none The ID of your newly created Cluster

readAllClusters

Code samples

# You can also use wget
curl -X GET /{organization}/clusters \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/clusters

List all Clusters within an Organization. If a page range is specified, then this will return the requested range

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
page query integer false The page number of results to retrieve. If this number exceeds the available data, then the last page is returned.
maxPageSize query integer false The maximum number of entries to return for a given page. If not specified, all data items will be returned.

Example responses

200 Response

{
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"name",
"validation"
],
"additionalProperties": false,
"properties": {
"bootstrapServers": {
"description": "Bootstrap servers for this cluster - only viewable with permissions",
"type": "array",
"minItems": 1,
"uniqueItems": true,
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"id": {
"description": "Unique cluster ID.",
"type": "string"
},
"name": {
"description": "Cluster name",
"type": "string"
},
"owner": {
"description": "Cluster owner.",
"type": "string"
},
"organization": {
"description": "Organization this cluster belongs to.",
"type": "string"
},
"lastUpdated": {
"description": "Time in ms since the epoch which represents the last time the cluster information was updated.",
"type": "integer"
},
"credentials": {
"type": "object",
"required": [
"type",
"data"
],
"description": "Credentials be used by the gateway to connect to Kafka",
"additionalProperties": false,
"properties": {
"type": {
"description": "The type of credentials. Used by parsers to determine how to handle the other fields",
"type": "string",
"enum": [
"NONE",
"SASL",
"MTLS",
"MTLS_SASL"
]
},
"data": {
"description": "Details of the SASL credential data to authenticate with Kafka",
"type": "object",
"additionalProperties": false,
"properties": {
"username": {
"description": "SASL username to authenticate with Kafka",
"type": "string"
},
"mechanism": {
"description": "SASL mechanism to authenticate with Kafka",
"type": "string",
"enum": [
"PLAIN",
"SCRAM-SHA-256",
"SCRAM-SHA-512"
]
},
"clientCertificateAndKey": {
"type": "object",
"description": "Client certificate and key to use in mTLS",
"required": [
"pem"
],
"additionalProperties": false,
"properties": {
"pem": {
"description": "Client certificate in PEM format",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"validation": {
"type": "object",
"required": [
"status",
"gatewayGroups"
],
"description": "Details of the visibility of this cluster amongst the gateways",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"description": "Overall status of all of the gateways. | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = No Gateways can see a Cluster/Topic - error state - either the configuration is incorrect, or there is a network issue | `success/partial` = success state - Some Gateways can see a Cluster/Topic | `success` = success state - All Gateways can see a Cluster/Topic",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gatewayGroups": {
"type": "array",
"description": "Gateway group names and if they can connect to this cluster",
"items": {
"type": "object",
"required": [
"name",
"gateways",
"status"
],
"additionalProperties": false,
"properties": {
"name": {
"type": "string"
},
"status": {
"type": "string",
"description": "Status on whether this gateway group can see the associated cluster. | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = error state - No Gateways can see the cluster | `success/partial` = success state - Some Gateways can see the cluster | `success` = success state - All Gateways can see the cluster",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gateways": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"validationErrors"
],
"additionalProperties": false,
"properties": {
"id": {
"type": "string"
},
"validationErrors": {
"type": "array",
"description": "List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the cluster.",
"items": {
"type": "string",
"description": "`network` = we cannot resolve this address | `certificates/tls` = we do not trust this address | `securityConfig` = this endpoint does not support the configured type of security (MTLS, SASL Plain etc) | `credentials` = provided username/password not accepted | `notKafka` server is resolvable but is not responding in the way a kafka server should",
"enum": [
"network",
"certificates/tls",
"securityConfig",
"credentials",
"notKafka"
]
}
}
}
}
}
}
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Clusters successfully listed. Inline
304 Not Modified Data not changed None
400 Bad Request Invalid request, only one of page and maxPageSize were supplied or max page size exceeded. None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» bootstrapServers [object] false none Bootstrap servers for this cluster - only viewable with permissions
»» host string true none Kafka server host name.
»» port integer true none Kafka server port.
»» ssl boolean false none Connect over SSL.
»» certificates [object] false none Certificates or CAs to trust when connecting to the server via SSL.
»»» pem string true none Certificate in PEM format
»»» subject string false none Subject name of the certificate
»»» sans [string] false none A list of subject alternative names of the certificate
»»» issuer string false none Issuer of the certificate
»»» expiry integer false none Expiration date of the certificate in epoch millis
» id string true none Unique cluster ID.
» name string true none Cluster name
» owner string true none Cluster owner.
» organization string true none Organization this cluster belongs to.
» lastUpdated integer false none Time in ms since the epoch which represents the last time the cluster information was updated.
» credentials object false none Credentials be used by the gateway to connect to Kafka
»» type string true none The type of credentials. Used by parsers to determine how to handle the other fields
»» data object true none Details of the SASL credential data to authenticate with Kafka
»»» username string false none SASL username to authenticate with Kafka
»»» mechanism string false none SASL mechanism to authenticate with Kafka
»»» clientCertificateAndKey object false none Client certificate and key to use in mTLS
»»»» pem string true none Client certificate in PEM format
»»»» expiry integer false none Expiration date of the certificate in epoch millis
» validation object true none Details of the visibility of this cluster amongst the gateways
»» status string true none Overall status of all of the gateways.
»» gatewayGroups [object] true none Gateway group names and if they can connect to this cluster
»»» name string true none none
»»» status string true none Status on whether this gateway group can see the associated cluster.
»»» gateways [object] true none none
»»»» id string true none none
»»»» validationErrors [string] true none List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the cluster.

Enumerated Values

Property Value
type NONE
type SASL
type MTLS
type MTLS_SASL
mechanism PLAIN
mechanism SCRAM-SHA-256
mechanism SCRAM-SHA-512
status pending
status error
status success/partial
status success
status pending
status error
status success/partial
status success

Response Headers

Status Header Type Format Description
200 ei-pagination-total integer Total number of items available for retrieval (including current page).
200 etag string An identifier which can be supplied with the If-None-Match header to indicate that unchanged results should return 304 with no data.

updateCluster

Code samples

# You can also use wget
curl -X PUT /{organization}/clusters/{clusterId} \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer {access-token}'

PUT /{organization}/clusters/{clusterId}

Update a Cluster using the ‘id’ as the identifier.

Note - You can view all of the Clusters (including their ‘id’) by using GET /{organization}/clusters

Body parameter

{
"type": "object",
"required": [
"name",
"bootstrapServers"
],
"properties": {
"bootstrapServers": {
"description": "Bootstrap servers for this cluster",
"type": "array",
"minItems": 1,
"uniqueItems": true,
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"name": {
"description": "Cluster name",
"type": "string"
},
"lastUpdated": {
"description": "Time in ms since the epoch which represents the last time the cluster information was updated.",
"type": "integer"
},
"credentials": {
"type": "object",
"required": [
"type",
"data"
],
"description": "Credentials be used by the gateway to connect to Kafka",
"properties": {
"type": {
"description": "The type of credentials. Used by parsers to determine how to handle the other fields",
"type": "string",
"enum": [
"NONE",
"SASL",
"MTLS",
"MTLS_SASL"
]
},
"data": {
"description": "Details of the SASL credential data to authenticate with Kafka",
"type": "object",
"properties": {
"username": {
"description": "SASL username to authenticate with Kafka",
"type": "string"
},
"password": {
"description": "SASL password to authenticate with Kafka",
"type": "string"
},
"mechanism": {
"description": "SASL mechanism to authenticate with Kafka",
"type": "string",
"enum": [
"PLAIN",
"SCRAM-SHA-256",
"SCRAM-SHA-512"
]
},
"clientCertificateAndKey": {
"type": "object",
"description": "Client certificate and key to use in mTLS",
"required": [
"pem",
"key"
],
"additionalProperties": false,
"properties": {
"pem": {
"description": "Client certificate in PEM format",
"type": "string"
},
"key": {
"description": "Client key in PEM format",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
clusterId path string true The ID of the Cluster.
disableValidation query boolean false disable immediate validation against the remote server
body body object true Update a cluster definition
» bootstrapServers body [object] true Bootstrap servers for this cluster
»» host body string true Kafka server host name.
»» port body integer true Kafka server port.
»» ssl body boolean false Connect over SSL.
»» certificates body [object] false Certificates or CAs to trust when connecting to the server via SSL.
»»» pem body string true Certificate in PEM format
»»» subject body string false Subject name of the certificate
»»» sans body [string] false A list of subject alternative names of the certificate
»»» issuer body string false Issuer of the certificate
»»» expiry body integer false Expiration date of the certificate in epoch millis
» name body string true Cluster name
» lastUpdated body integer false Time in ms since the epoch which represents the last time the cluster information was updated.
» credentials body object false Credentials be used by the gateway to connect to Kafka
»» type body string true The type of credentials. Used by parsers to determine how to handle the other fields
»» data body object true Details of the SASL credential data to authenticate with Kafka
»»» username body string false SASL username to authenticate with Kafka
»»» password body string false SASL password to authenticate with Kafka
»»» mechanism body string false SASL mechanism to authenticate with Kafka
»»» clientCertificateAndKey body object false Client certificate and key to use in mTLS
»»»» pem body string true Client certificate in PEM format
»»»» key body string true Client key in PEM format
»»»» expiry body integer false Expiration date of the certificate in epoch millis

Enumerated Values

Parameter Value
»» type NONE
»» type SASL
»» type MTLS
»» type MTLS_SASL
»»» mechanism PLAIN
»»» mechanism SCRAM-SHA-256
»»» mechanism SCRAM-SHA-512

Responses

Status Meaning Description Schema
200 OK Cluster updated. None
400 Bad Request Bad input None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found Cluster not found None
409 Conflict Cluster with the specified name already exists None
422 Unprocessable Entity The specified Cluster could not be validated using Kafka discovery mechanisms e.g. connection fails, certs mis-matched, SASL mis-match None
500 Internal Server Error Internal error None

readCluster

Code samples

# You can also use wget
curl -X GET /{organization}/clusters/{clusterId} \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/clusters/{clusterId}

Get details about a Cluster.

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
clusterId path string true The ID of the Cluster.

Example responses

200 Response

{
"type": "object",
"required": [
"id",
"owner",
"organization",
"name",
"validation"
],
"additionalProperties": false,
"properties": {
"bootstrapServers": {
"description": "Bootstrap servers for this cluster - only viewable with permissions",
"type": "array",
"minItems": 1,
"uniqueItems": true,
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"id": {
"description": "Unique cluster ID.",
"type": "string"
},
"name": {
"description": "Cluster name",
"type": "string"
},
"owner": {
"description": "Cluster owner.",
"type": "string"
},
"organization": {
"description": "Organization this cluster belongs to.",
"type": "string"
},
"lastUpdated": {
"description": "Time in ms since the epoch which represents the last time the cluster information was updated.",
"type": "integer"
},
"credentials": {
"type": "object",
"required": [
"type",
"data"
],
"description": "Credentials be used by the gateway to connect to Kafka",
"additionalProperties": false,
"properties": {
"type": {
"description": "The type of credentials. Used by parsers to determine how to handle the other fields",
"type": "string",
"enum": [
"NONE",
"SASL",
"MTLS",
"MTLS_SASL"
]
},
"data": {
"description": "Details of the SASL credential data to authenticate with Kafka",
"type": "object",
"additionalProperties": false,
"properties": {
"username": {
"description": "SASL username to authenticate with Kafka",
"type": "string"
},
"mechanism": {
"description": "SASL mechanism to authenticate with Kafka",
"type": "string",
"enum": [
"PLAIN",
"SCRAM-SHA-256",
"SCRAM-SHA-512"
]
},
"clientCertificateAndKey": {
"type": "object",
"description": "Client certificate and key to use in mTLS",
"required": [
"pem"
],
"additionalProperties": false,
"properties": {
"pem": {
"description": "Client certificate in PEM format",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"validation": {
"type": "object",
"required": [
"status",
"gatewayGroups"
],
"description": "Details of the visibility of this cluster amongst the gateways",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"description": "Overall status of all of the gateways. | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = No Gateways can see a Cluster/Topic - error state - either the configuration is incorrect, or there is a network issue | `success/partial` = success state - Some Gateways can see a Cluster/Topic | `success` = success state - All Gateways can see a Cluster/Topic",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gatewayGroups": {
"type": "array",
"description": "Gateway group names and if they can connect to this cluster",
"items": {
"type": "object",
"required": [
"name",
"gateways",
"status"
],
"additionalProperties": false,
"properties": {
"name": {
"type": "string"
},
"status": {
"type": "string",
"description": "Status on whether this gateway group can see the associated cluster. | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = error state - No Gateways can see the cluster | `success/partial` = success state - Some Gateways can see the cluster | `success` = success state - All Gateways can see the cluster",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gateways": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"validationErrors"
],
"additionalProperties": false,
"properties": {
"id": {
"type": "string"
},
"validationErrors": {
"type": "array",
"description": "List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the cluster.",
"items": {
"type": "string",
"description": "`network` = we cannot resolve this address | `certificates/tls` = we do not trust this address | `securityConfig` = this endpoint does not support the configured type of security (MTLS, SASL Plain etc) | `credentials` = provided username/password not accepted | `notKafka` server is resolvable but is not responding in the way a kafka server should",
"enum": [
"network",
"certificates/tls",
"securityConfig",
"credentials",
"notKafka"
]
}
}
}
}
}
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Cluster successfully read. Inline
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found Cluster not found None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» bootstrapServers [object] false none Bootstrap servers for this cluster - only viewable with permissions
»» host string true none Kafka server host name.
»» port integer true none Kafka server port.
»» ssl boolean false none Connect over SSL.
»» certificates [object] false none Certificates or CAs to trust when connecting to the server via SSL.
»»» pem string true none Certificate in PEM format
»»» subject string false none Subject name of the certificate
»»» sans [string] false none A list of subject alternative names of the certificate
»»» issuer string false none Issuer of the certificate
»»» expiry integer false none Expiration date of the certificate in epoch millis
» id string true none Unique cluster ID.
» name string true none Cluster name
» owner string true none Cluster owner.
» organization string true none Organization this cluster belongs to.
» lastUpdated integer false none Time in ms since the epoch which represents the last time the cluster information was updated.
» credentials object false none Credentials be used by the gateway to connect to Kafka
»» type string true none The type of credentials. Used by parsers to determine how to handle the other fields
»» data object true none Details of the SASL credential data to authenticate with Kafka
»»» username string false none SASL username to authenticate with Kafka
»»» mechanism string false none SASL mechanism to authenticate with Kafka
»»» clientCertificateAndKey object false none Client certificate and key to use in mTLS
»»»» pem string true none Client certificate in PEM format
»»»» expiry integer false none Expiration date of the certificate in epoch millis
» validation object true none Details of the visibility of this cluster amongst the gateways
»» status string true none Overall status of all of the gateways.
»» gatewayGroups [object] true none Gateway group names and if they can connect to this cluster
»»» name string true none none
»»» status string true none Status on whether this gateway group can see the associated cluster.
»»» gateways [object] true none none
»»»» id string true none none
»»»» validationErrors [string] true none List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the cluster.

Enumerated Values

Property Value
type NONE
type SASL
type MTLS
type MTLS_SASL
mechanism PLAIN
mechanism SCRAM-SHA-256
mechanism SCRAM-SHA-512
status pending
status error
status success/partial
status success
status pending
status error
status success/partial
status success

deleteCluster

Code samples

# You can also use wget
curl -X DELETE /{organization}/clusters/{clusterId} \
-H 'Authorization: Bearer {access-token}'

DELETE /{organization}/clusters/{clusterId}

Delete a Cluster.

All related Catalog Entries must be deleted prior to deleting a cluster. Note - You must be the owner to delete a Cluster. You can view all of the Clusters that you own (including their ‘id’) by using GET /{organization}/clusters

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
clusterId path string true The ID of the Cluster.

Responses

Status Meaning Description Schema
200 OK Cluster successfully deleted None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found Cluster not found None
409 Conflict catalog entries are still using this cluster and it cannot be deleted None
500 Internal Server Error Internal error None

createSubscription

Code samples

# You can also use wget
curl -X POST /{organization}/subscriptions \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

POST /{organization}/subscriptions

Create a subscription to a Catalog Entry

Body parameter

{
"type": "object",
"required": [
"entryId",
"credentials",
"contact"
],
"properties": {
"entryId": {
"description": "The list of entry ids this subscription gives access to, currently only supports 1.",
"type": "array",
"uniqueItems": true,
"minItems": 1,
"maxItems": 1,
"items": {
"type": "string"
}
},
"credentials": {
"type": "object",
"required": [
"type",
"data"
],
"description": "Credentials a client uses to connect to an Event Gateway",
"properties": {
"type": {
"description": "The type of credentials. Used by parsers to determine how to handle the other fields",
"type": "string",
"enum": [
"NONE",
"SASL",
"SASL_APIC",
"MTLS"
]
},
"data": {
"description": "Details of the SASL credential data to authenticate with an Event Gateway",
"type": "object",
"properties": {
"username": {
"description": "SASL username to authenticate with an Event Gateway",
"type": "string"
},
"password": {
"description": "SASL password to authenticate with an Event Gateway",
"type": "string"
},
"mechanism": {
"description": "SASL mechanism to authenticate with Kafka",
"type": "string",
"enum": [
"PLAIN"
]
},
"hashedPasswords": {
"description": "Hashed passwords from APIC to authenticate clients against an Event Gateway.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
}
}
}
}
},
"clientId": {
"description": "Optional client ID if this subscription is a legacy APIC one.",
"type": "string"
},
"contact": {
"description": "Subscription contact details.",
"type": "string"
},
"gateways": {
"description": "A list of gateway IDs that can access this data. If this property is missing or contains an empty list then this subscription has no gateway restrictions",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
body body object true none
» entryId body [string] true The list of entry ids this subscription gives access to, currently only supports 1.
» credentials body object true Credentials a client uses to connect to an Event Gateway
»» type body string true The type of credentials. Used by parsers to determine how to handle the other fields
»» data body object true Details of the SASL credential data to authenticate with an Event Gateway
»»» username body string false SASL username to authenticate with an Event Gateway
»»» password body string false SASL password to authenticate with an Event Gateway
»»» mechanism body string false SASL mechanism to authenticate with Kafka
»»» hashedPasswords body [string] false Hashed passwords from APIC to authenticate clients against an Event Gateway.
»»» subjectCommonName body string false Subject Common Name to match on.
»»» subjectOrganization body string false Subject Organization to match on.
»»» subjectCountry body string false Subject Country to match on.
»»» subjectStateOrProvince body string false Subject Region to match on.
»»» subjectLocality body string false Subject Locality to match on.
» clientId body string false Optional client ID if this subscription is a legacy APIC one.
» contact body string true Subscription contact details.
» gateways body [string] false A list of gateway IDs that can access this data. If this property is missing or contains an empty list then this subscription has no gateway restrictions

Enumerated Values

Parameter Value
»» type NONE
»» type SASL
»» type SASL_APIC
»» type MTLS
»»» mechanism PLAIN

Example responses

200 Response

{
"type": "object",
"properties": {
"id": {
"description": "The ID of your newly created Subscription",
"type": "string"
}
}
}

Responses

Status Meaning Description Schema
200 OK Subscription successfully created. Inline
400 Bad Request Bad input None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
409 Conflict Subscription with the specified ID already exists None
422 Unprocessable Entity subscribe to invalid topic etc None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string false none The ID of your newly created Subscription

readAllSubscriptions

Code samples

# You can also use wget
curl -X GET /{organization}/subscriptions \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/subscriptions

List all Subscriptions created by the current user in an Organization. If a page range is specified, then this will return the requested range.

Note - This will not include the subscription credentials

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
page query integer false The page number of results to retrieve. If this number exceeds the available data, then the last page is returned.
maxPageSize query integer false The maximum number of entries to return for a given page. If not specified, all data items will be returned.

Example responses

200 Response

{
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"organization",
"owner",
"entryId",
"contact"
],
"properties": {
"id": {
"description": "Unique subscription ID.",
"type": "string"
},
"owner": {
"description": "Subscription owner.",
"type": "string"
},
"entryId": {
"description": "The list of entry ids this subscription gives access to, currently only supports 1.",
"type": "array",
"uniqueItems": true,
"minItems": 1,
"maxItems": 1,
"items": {
"type": "string"
}
},
"organization": {
"description": "Organization this subscription belongs to.",
"type": "string"
},
"credentials": {
"type": "object",
"required": [
"type",
"data"
],
"description": "Credentials a client uses to connect to an Event Gateway",
"additionalProperties": false,
"properties": {
"type": {
"description": "The type of credentials. Used by parsers to determine how to handle the other fields",
"type": "string",
"enum": [
"NONE",
"SASL",
"SASL_APIC",
"MTLS"
]
},
"data": {
"description": "Details of the SASL credential data to authenticate with an Event Gateway",
"type": "object",
"additionalProperties": false,
"properties": {
"username": {
"description": "SASL username to authenticate with an Event Gateway",
"type": "string"
},
"mechanism": {
"description": "SASL mechanism to authenticate with Kafka",
"type": "string",
"enum": [
"PLAIN"
]
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
}
}
}
}
},
"clientId": {
"description": "Optional client ID if this subscription is a legacy APIC one.",
"type": "string"
},
"contact": {
"description": "Subscription contact details.",
"type": "string"
},
"gateways": {
"description": "A list of gateway IDs that can access this data. If this property is missing or contains an empty list then this subscription has no gateway restrictions",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Subscriptions successfully listed. Inline
304 Not Modified Data not changed None
400 Bad Request Invalid request, only one of page and maxPageSize were supplied or max page size exceeded. None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique subscription ID.
» owner string true none Subscription owner.
» entryId [string] true none The list of entry ids this subscription gives access to, currently only supports 1.
» organization string true none Organization this subscription belongs to.
» credentials object false none Credentials a client uses to connect to an Event Gateway
»» type string true none The type of credentials. Used by parsers to determine how to handle the other fields
»» data object true none Details of the SASL credential data to authenticate with an Event Gateway
»»» username string false none SASL username to authenticate with an Event Gateway
»»» mechanism string false none SASL mechanism to authenticate with Kafka
»»» subjectCommonName string false none Subject Common Name to match on.
»»» subjectOrganization string false none Subject Organization to match on.
»»» subjectCountry string false none Subject Country to match on.
»»» subjectStateOrProvince string false none Subject Region to match on.
»»» subjectLocality string false none Subject Locality to match on.
» clientId string false none Optional client ID if this subscription is a legacy APIC one.
» contact string true none Subscription contact details.
» gateways [string] false none A list of gateway IDs that can access this data. If this property is missing or contains an empty list then this subscription has no gateway restrictions

Enumerated Values

Property Value
type NONE
type SASL
type SASL_APIC
type MTLS
mechanism PLAIN

Response Headers

Status Header Type Format Description
200 ei-pagination-total integer Total number of items available for retrieval (including current page).
200 etag string An identifier which can be supplied with the If-None-Match header to indicate that unchanged results should return 304 with no data.

deleteSubscription

Code samples

# You can also use wget
curl -X DELETE /{organization}/subscriptions/{subscriptionId} \
-H 'Authorization: Bearer {access-token}'

DELETE /{organization}/subscriptions/{subscriptionId}

Delete a Subscription

Note - You must be the owner to delete a Subscription. You can view all of the Subscriptions that you own (including their ‘id’) by using GET /{organization}/subscriptions

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
subscriptionId path string true The ID of the Subscription.

Responses

Status Meaning Description Schema
200 OK Subscription successfully deleted None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found subscription not found None
500 Internal Server Error Internal error None

readAllGateways

Code samples

# You can also use wget
curl -X GET /{organization}/gateways \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/gateways

List all registered Event Gateways in an Organization. If a page range is specified, then this will return the requested range.

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
page query integer false The page number of results to retrieve. If this number exceeds the available data, then the last page is returned.
maxPageSize query integer false The maximum number of entries to return for a given page. If not specified, all data items will be returned.

Example responses

200 Response

{
"type": "array",
"items": {
"type": "object",
"description": "Detailed information about any registered gateways",
"required": [
"name",
"gateways"
],
"properties": {
"name": {
"description": "Unique gateway group name.",
"type": "string"
},
"gateways": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"gatewayId",
"group",
"organizations",
"servedOrganizations",
"endpoints",
"lastContact"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Event Gateway ID",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"owner": {
"description": "Owner of the Event Gateway.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"organization": {
"description": "Organization this Event Gateway belongs to.",
"type": "string"
},
"gatewayId": {
"description": "Unique Event Gateway ID within this group.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"group": {
"description": "Event Gateway group name.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"organizations": {
"description": "Organizations this Event Gateway serves",
"type": "array",
"deprecated": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 100
}
},
"servedOrganizations": {
"description": "Organizations this Event Gateway serves",
"type": "array",
"items": {
"type": "string",
"minLength": 1,
"maxLength": 100
}
},
"contact": {
"description": "The contact information for this Event Gateway",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"lastContact": {
"description": "Epoch time in ms of the last contact from this gateway.",
"type": "integer",
"minimum": 0
},
"endpoints": {
"description": "Endpoints that the gateway is listening on.",
"type": "array",
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"version": {
"type": "string",
"description": "Version of the gateway",
"minLength": 1,
"maxLength": 20
},
"productVersion": {
"type": "string",
"description": "EEM product version.",
"minLength": 1,
"maxLength": 100
},
"features": {
"type": "array",
"description": "Feature set in use by gateway",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 20
}
},
"deploymentMode": {
"type": "string",
"description": "Type of gateway deployment"
},
"capabilities": {
"type": "object",
"additionalProperties": true,
"description": "Freeform Description of what capabilities the gateway has"
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Event Gateways successfully listed. Inline
304 Not Modified Data not changed None
400 Bad Request Invalid request, only one of page and maxPageSize were supplied or max page size exceeded. None
401 Unauthorized Not authorized, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» name string true none Unique gateway group name.
» gateways [object] true none none
»» id string true none Unique Event Gateway ID
»» owner string true none Owner of the Event Gateway.
»» organization string true none Organization this Event Gateway belongs to.
»» gatewayId string true none Unique Event Gateway ID within this group.
»» group string true none Event Gateway group name.
»» organizations [string] true none Organizations this Event Gateway serves
»» servedOrganizations [string] true none Organizations this Event Gateway serves
»» contact string false none The contact information for this Event Gateway
»» lastContact integer true none Epoch time in ms of the last contact from this gateway.
»» endpoints [object] true none Endpoints that the gateway is listening on.
»»» host string true none Kafka server host name.
»»» port integer true none Kafka server port.
»»» ssl boolean false none Connect over SSL.
»»» certificates [object] false none Certificates or CAs to trust when connecting to the server via SSL.
»»»» pem string true none Certificate in PEM format
»»»» subject string false none Subject name of the certificate
»»»» sans [string] false none A list of subject alternative names of the certificate
»»»» issuer string false none Issuer of the certificate
»»»» expiry integer false none Expiration date of the certificate in epoch millis
»» version string false none Version of the gateway
»» productVersion string false none EEM product version.
»» features [string] false none Feature set in use by gateway
»» deploymentMode string false none Type of gateway deployment
»» capabilities object false none Freeform Description of what capabilities the gateway has

Response Headers

Status Header Type Format Description
200 ei-pagination-total integer Total number of items available for retrieval (including current page).
200 etag string An identifier which can be supplied with the If-None-Match header to indicate that unchanged results should return 304 with no data.

readAllEventSources

Code samples

# You can also use wget
curl -X GET /{organization}/eventsources \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/eventsources

List all Event Sources created by the current user in an Organization. If a page range is specified, then this will return the requested range.

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
page query integer false The page number of results to retrieve. If this number exceeds the available data, then the last page is returned.
maxPageSize query integer false The maximum number of entries to return for a given page. If not specified, all data items will be returned.
filterBy query string false capability to filterBy

Enumerated Values

Parameter Value
filterBy consume
filterBy produce

Example responses

200 Response

{
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"clusterId",
"type",
"encoding",
"name",
"contact",
"capabilities"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Event Source ID.",
"type": "string"
},
"owner": {
"description": "Event Source owner.",
"type": "string"
},
"organization": {
"description": "Organization this Event Source belongs to.",
"type": "string"
},
"clusterId": {
"description": "ID for the cluster that contains the connection details for this Event Source.",
"type": "string"
},
"type": {
"description": "Type of Event Source",
"type": "string",
"enum": [
"kafka"
]
},
"encoding": {
"description": "The encoding of the data on this Event Source",
"type": "string",
"enum": [
"unknown",
"text/plain",
"application/octet-stream",
"application/json",
"avro/binary",
"avro/json"
]
},
"name": {
"description": "Event Source name",
"type": "string"
},
"contact": {
"description": "Who to contact for more information about this Event Source.",
"type": "string"
},
"description": {
"description": "A description for this Event Source",
"type": "string",
"maxLength": 1500
},
"topic": {
"type": "object",
"additionalProperties": false,
"properties": {
"name": {
"description": "Actual topic name in the cluster.",
"type": "string"
},
"partitions": {
"description": "The number of partitions for this topic. Discovered from the Kafka cluster",
"type": "number"
},
"replicas": {
"description": "The number of replicas for this topic. Discovered from the Kafka cluster",
"type": "number"
}
},
"required": [
"name"
]
},
"schema": {
"type": "object",
"properties": {
"type": {
"description": "Type of Schema from the list of valid types",
"type": "string",
"enum": [
"avro",
"json",
"unknown"
]
},
"content": {
"description": "Contents of the Schema",
"type": "string",
"maxLength": 1048576
},
"description": {
"description": "Description of the data available on the Event Source",
"type": "string",
"maxLength": 1500
}
},
"additionalProperties": false
},
"tags": {
"description": "List of tags associated with this Event Source",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 50
}
},
"sampleMessages": {
"type": "array",
"items": {
"type": "string"
}
},
"capabilities": {
"type": "array",
"minItems": 1,
"maxItems": 1,
"uniqueItems": true,
"items": {
"description": "Capabilities enum.",
"type": "string",
"enum": [
"consume",
"produce"
]
}
},
"validation": {
"type": "object",
"required": [
"status",
"gatewayGroups"
],
"description": "Details of the visibility of this event source amongst the gateway groups.",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"description": "Status for all of the gateway groups. Can they see the topic associated with this event source? | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = error state - No Gateway Groups can see the topic | `success/partial` = success state - Some Gateway Groups can see the topic | `success` = success state - All Gateway Groups can see the topic",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gatewayGroups": {
"type": "array",
"description": "Gateway group names and if they can connect to this cluster and find the associated topic.",
"items": {
"type": "object",
"required": [
"name",
"status",
"gateways"
],
"additionalProperties": false,
"properties": {
"name": {
"type": "string"
},
"status": {
"type": "string",
"description": "Status on whether this gateway group can see the topic associated with this event source. | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = error state - No Gateways can see the topic | `success/partial` = success state - Some Gateways can see the topic | `success` = success state - All Gateways can see the topic",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gateways": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"validationErrors"
],
"properties": {
"id": {
"type": "string"
},
"validationErrors": {
"type": "array",
"description": "List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the topic.",
"items": {
"type": "string",
"description": "`notFound` = topic not found in cluster.",
"enum": [
"notFound"
]
}
}
}
}
}
}
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Event Sources successfully listed. Inline
304 Not Modified Data not changed None
400 Bad Request Invalid request, only one of page and maxPageSize were supplied or max page size exceeded. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique Event Source ID.
» owner string true none Event Source owner.
» organization string true none Organization this Event Source belongs to.
» clusterId string true none ID for the cluster that contains the connection details for this Event Source.
» type string true none Type of Event Source
» encoding string true none The encoding of the data on this Event Source
» name string true none Event Source name
» contact string true none Who to contact for more information about this Event Source.
» description string false none A description for this Event Source
» topic object false none none
»» name string true none Actual topic name in the cluster.
»» partitions number false none The number of partitions for this topic. Discovered from the Kafka cluster
»» replicas number false none The number of replicas for this topic. Discovered from the Kafka cluster
» schema object false none none
»» type string false none Type of Schema from the list of valid types
»» content string false none Contents of the Schema
»» description string false none Description of the data available on the Event Source
» tags [string] false none List of tags associated with this Event Source
» sampleMessages [string] false none none
» capabilities [string] true none none
» validation object false none Details of the visibility of this event source amongst the gateway groups.
»» status string true none Status for all of the gateway groups. Can they see the topic associated with this event source?
»» gatewayGroups [object] true none Gateway group names and if they can connect to this cluster and find the associated topic.
»»» name string true none none
»»» status string true none Status on whether this gateway group can see the topic associated with this event source.
»»» gateways [object] true none none
»»»» id string true none none
»»»» validationErrors [string] true none List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the topic.

Enumerated Values

Property Value
type kafka
encoding unknown
encoding text/plain
encoding application/octet-stream
encoding application/json
encoding avro/binary
encoding avro/json
type avro
type json
type unknown
status pending
status error
status success/partial
status success
status pending
status error
status success/partial
status success

Response Headers

Status Header Type Format Description
200 ei-pagination-total integer Total number of items available for retrieval (including current page).
200 etag string An identifier which can be supplied with the If-None-Match header to indicate that unchanged results should return 304 with no data.

createEventSource

Code samples

# You can also use wget
curl -X POST /{organization}/eventsources \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

POST /{organization}/eventsources

Create an event source

Body parameter

{
"type": "object",
"required": [
"clusterId",
"type",
"encoding",
"name",
"contact"
],
"properties": {
"clusterId": {
"description": "ID for the cluster that contains the connection details for this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"type": {
"description": "Type of Event Source",
"type": "string",
"enum": [
"kafka"
]
},
"encoding": {
"description": "The encoding of the data on this Event Source",
"type": "string",
"enum": [
"unknown",
"text/plain",
"application/octet-stream",
"application/json",
"avro/binary",
"avro/json"
]
},
"name": {
"description": "Event Source name",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"contact": {
"description": "Who to contact for more information about this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "A description for this Event Source",
"type": "string",
"maxLength": 1500
},
"topic": {
"type": "object",
"properties": {
"name": {
"description": "Actual topic name in the cluster.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"partitions": {
"description": "The number of partitions for this topic. ",
"type": "number"
},
"replicas": {
"description": "The number of replicas for this topic.",
"type": "number"
}
},
"required": [
"name"
]
},
"schema": {
"type": "object",
"properties": {
"type": {
"description": "Type of Schema from the list of valid types",
"type": "string",
"enum": [
"avro",
"json",
"unknown"
]
},
"content": {
"description": "Contents of the Schema",
"type": "string",
"maxLength": 1048576
},
"description": {
"description": "Description of the data available on the Event Source",
"type": "string",
"maxLength": 1500
}
},
"anyOf": [
{
"required": [
"content",
"type"
]
},
{
"required": [
"description"
]
}
]
},
"tags": {
"description": "List of tags associated with this Event Source",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 50
}
},
"sampleMessages": {
"type": "array",
"items": {
"type": "string"
}
},
"capabilities": {
"type": "array",
"minItems": 1,
"maxItems": 1,
"uniqueItems": true,
"items": {
"description": "Capabilities enum.",
"type": "string",
"enum": [
"consume",
"produce"
]
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
disableValidation query boolean false disable immediate validation against the remote server
body body object true Event Source data
» clusterId body string true ID for the cluster that contains the connection details for this Event Source.
» type body string true Type of Event Source
» encoding body string true The encoding of the data on this Event Source
» name body string true Event Source name
» contact body string true Who to contact for more information about this Event Source.
» description body string false A description for this Event Source
» topic body object false none
»» name body string true Actual topic name in the cluster.
»» partitions body number false The number of partitions for this topic.
»» replicas body number false The number of replicas for this topic.
» schema body object false none
»» type body string false Type of Schema from the list of valid types
»» content body string false Contents of the Schema
»» description body string false Description of the data available on the Event Source
»» anonymous body object false none
»» anonymous body object false none
» tags body [string] false List of tags associated with this Event Source
» sampleMessages body [string] false none
» capabilities body [string] false none

Enumerated Values

Parameter Value
» type kafka
» encoding unknown
» encoding text/plain
» encoding application/octet-stream
» encoding application/json
» encoding avro/binary
» encoding avro/json
»» type avro
»» type json
»» type unknown
» capabilities consume
» capabilities produce

Example responses

200 Response

{
"type": "object",
"properties": {
"id": {
"type": "string"
}
}
}

Responses

Status Meaning Description Schema
200 OK The id of the created event source Inline
400 Bad Request Invalid request, request data does not match schema. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
409 Conflict Event Source could not be created due to a conflict None
422 Unprocessable Entity Event Source could not be created as it does not map to a valid cluster None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string false none none

readEventSource

Code samples

# You can also use wget
curl -X GET /{organization}/eventsources/{eventSourceId} \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/eventsources/{eventSourceId}

Read an event source

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
eventSourceId path string true The ID of the Event Source to read.

Example responses

200 Response

{
"type": "object",
"required": [
"id",
"owner",
"organization",
"clusterId",
"type",
"encoding",
"name",
"contact",
"capabilities"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Event Source ID.",
"type": "string"
},
"owner": {
"description": "Event Source owner.",
"type": "string"
},
"organization": {
"description": "Organization this Event Source belongs to.",
"type": "string"
},
"clusterId": {
"description": "ID for the cluster that contains the connection details for this Event Source.",
"type": "string"
},
"type": {
"description": "Type of Event Source",
"type": "string",
"enum": [
"kafka"
]
},
"encoding": {
"description": "The encoding of the data on this Event Source",
"type": "string",
"enum": [
"unknown",
"text/plain",
"application/octet-stream",
"application/json",
"avro/binary",
"avro/json"
]
},
"name": {
"description": "Event Source name",
"type": "string"
},
"contact": {
"description": "Who to contact for more information about this Event Source.",
"type": "string"
},
"description": {
"description": "A description for this Event Source",
"type": "string",
"maxLength": 1500
},
"topic": {
"type": "object",
"additionalProperties": false,
"properties": {
"name": {
"description": "Actual topic name in the cluster.",
"type": "string"
},
"partitions": {
"description": "The number of partitions for this topic. Discovered from the Kafka cluster",
"type": "number"
},
"replicas": {
"description": "The number of replicas for this topic. Discovered from the Kafka cluster",
"type": "number"
}
},
"required": [
"name"
]
},
"schema": {
"type": "object",
"properties": {
"type": {
"description": "Type of Schema from the list of valid types",
"type": "string",
"enum": [
"avro",
"json",
"unknown"
]
},
"content": {
"description": "Contents of the Schema",
"type": "string",
"maxLength": 1048576
},
"description": {
"description": "Description of the data available on the Event Source",
"type": "string",
"maxLength": 1500
}
},
"additionalProperties": false
},
"tags": {
"description": "List of tags associated with this Event Source",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 50
}
},
"sampleMessages": {
"type": "array",
"items": {
"type": "string"
}
},
"capabilities": {
"type": "array",
"minItems": 1,
"maxItems": 1,
"uniqueItems": true,
"items": {
"description": "Capabilities enum.",
"type": "string",
"enum": [
"consume",
"produce"
]
}
},
"validation": {
"type": "object",
"required": [
"status",
"gatewayGroups"
],
"description": "Details of the visibility of this event source amongst the gateway groups.",
"additionalProperties": false,
"properties": {
"status": {
"type": "string",
"description": "Status for all of the gateway groups. Can they see the topic associated with this event source? | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = error state - No Gateway Groups can see the topic | `success/partial` = success state - Some Gateway Groups can see the topic | `success` = success state - All Gateway Groups can see the topic",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gatewayGroups": {
"type": "array",
"description": "Gateway group names and if they can connect to this cluster and find the associated topic.",
"items": {
"type": "object",
"required": [
"name",
"status",
"gateways"
],
"additionalProperties": false,
"properties": {
"name": {
"type": "string"
},
"status": {
"type": "string",
"description": "Status on whether this gateway group can see the topic associated with this event source. | `pending` = Pending validation - we are waiting for gateways to report a status | `error` = error state - No Gateways can see the topic | `success/partial` = success state - Some Gateways can see the topic | `success` = success state - All Gateways can see the topic",
"enum": [
"pending",
"error",
"success/partial",
"success"
]
},
"gateways": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"validationErrors"
],
"properties": {
"id": {
"type": "string"
},
"validationErrors": {
"type": "array",
"description": "List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the topic.",
"items": {
"type": "string",
"description": "`notFound` = topic not found in cluster.",
"enum": [
"notFound"
]
}
}
}
}
}
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK The data for the requested event source Inline
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Event Source does not exist None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique Event Source ID.
» owner string true none Event Source owner.
» organization string true none Organization this Event Source belongs to.
» clusterId string true none ID for the cluster that contains the connection details for this Event Source.
» type string true none Type of Event Source
» encoding string true none The encoding of the data on this Event Source
» name string true none Event Source name
» contact string true none Who to contact for more information about this Event Source.
» description string false none A description for this Event Source
» topic object false none none
»» name string true none Actual topic name in the cluster.
»» partitions number false none The number of partitions for this topic. Discovered from the Kafka cluster
»» replicas number false none The number of replicas for this topic. Discovered from the Kafka cluster
» schema object false none none
»» type string false none Type of Schema from the list of valid types
»» content string false none Contents of the Schema
»» description string false none Description of the data available on the Event Source
» tags [string] false none List of tags associated with this Event Source
» sampleMessages [string] false none none
» capabilities [string] true none none
» validation object false none Details of the visibility of this event source amongst the gateway groups.
»» status string true none Status for all of the gateway groups. Can they see the topic associated with this event source?
»» gatewayGroups [object] true none Gateway group names and if they can connect to this cluster and find the associated topic.
»»» name string true none none
»»» status string true none Status on whether this gateway group can see the topic associated with this event source.
»»» gateways [object] true none none
»»»» id string true none none
»»»» validationErrors [string] true none List of failed validation stages. If this array is empty, it can be assumed that this gateway group can connect and see the topic.

Enumerated Values

Property Value
type kafka
encoding unknown
encoding text/plain
encoding application/octet-stream
encoding application/json
encoding avro/binary
encoding avro/json
type avro
type json
type unknown
status pending
status error
status success/partial
status success
status pending
status error
status success/partial
status success

updateEventSource

Code samples

# You can also use wget
curl -X PUT /{organization}/eventsources/{eventSourceId} \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer {access-token}'

PUT /{organization}/eventsources/{eventSourceId}

Update an event source

Body parameter

{
"type": "object",
"required": [
"clusterId",
"type",
"encoding",
"name",
"contact"
],
"properties": {
"clusterId": {
"description": "ID for the cluster that contains the connection details for this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"type": {
"description": "Type of Event Source",
"type": "string",
"enum": [
"kafka"
]
},
"encoding": {
"description": "The encoding of the data on this Event Source",
"type": "string",
"enum": [
"unknown",
"text/plain",
"application/octet-stream",
"application/json",
"avro/binary",
"avro/json"
]
},
"name": {
"description": "Event Source name",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"contact": {
"description": "Who to contact for more information about this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "A description for this Event Source",
"type": "string",
"maxLength": 1500
},
"topic": {
"type": "object",
"properties": {
"name": {
"description": "Actual topic name in the cluster.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"partitions": {
"description": "The number of partitions for this topic. ",
"type": "number"
},
"replicas": {
"description": "The number of replicas for this topic.",
"type": "number"
}
},
"required": [
"name"
]
},
"schema": {
"type": "object",
"properties": {
"type": {
"description": "Type of Schema from the list of valid types",
"type": "string",
"enum": [
"avro",
"json",
"unknown"
]
},
"content": {
"description": "Contents of the Schema",
"type": "string",
"maxLength": 1048576
},
"description": {
"description": "Description of the data available on the Event Source",
"type": "string",
"maxLength": 1500
}
},
"anyOf": [
{
"required": [
"content",
"type"
]
},
{
"required": [
"description"
]
}
]
},
"tags": {
"description": "List of tags associated with this Event Source",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 50
}
},
"sampleMessages": {
"type": "array",
"items": {
"type": "string"
}
},
"capabilities": {
"type": "array",
"minItems": 1,
"maxItems": 1,
"uniqueItems": true,
"items": {
"description": "Capabilities enum.",
"type": "string",
"enum": [
"consume",
"produce"
]
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
eventSourceId path string true The ID of the Event Source to update.
disableValidation query boolean false disable immediate validation against the remote server
body body object true Event Source data
» clusterId body string true ID for the cluster that contains the connection details for this Event Source.
» type body string true Type of Event Source
» encoding body string true The encoding of the data on this Event Source
» name body string true Event Source name
» contact body string true Who to contact for more information about this Event Source.
» description body string false A description for this Event Source
» topic body object false none
»» name body string true Actual topic name in the cluster.
»» partitions body number false The number of partitions for this topic.
»» replicas body number false The number of replicas for this topic.
» schema body object false none
»» type body string false Type of Schema from the list of valid types
»» content body string false Contents of the Schema
»» description body string false Description of the data available on the Event Source
»» anonymous body object false none
»» anonymous body object false none
» tags body [string] false List of tags associated with this Event Source
» sampleMessages body [string] false none
» capabilities body [string] false none

Enumerated Values

Parameter Value
» type kafka
» encoding unknown
» encoding text/plain
» encoding application/octet-stream
» encoding application/json
» encoding avro/binary
» encoding avro/json
»» type avro
»» type json
»» type unknown
» capabilities consume
» capabilities produce

Responses

Status Meaning Description Schema
200 OK Event Source successfully updated None
400 Bad Request Invalid request, request data does not match schema. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Event Source does not exist None
409 Conflict Event Source could not be updated due to a conflict None
422 Unprocessable Entity Event Source could not be created as it does not map to a valid cluster None
500 Internal Server Error Internal error None

deleteEventSource

Code samples

# You can also use wget
curl -X DELETE /{organization}/eventsources/{eventSourceId} \
-H 'Authorization: Bearer {access-token}'

DELETE /{organization}/eventsources/{eventSourceId}

Delete an Event Source

The Event Source must have no attached published or archived Options. Note - You must be the owner to delete an Event Source. You can view all of the Event Sources that you own (including their ‘id’) by using GET /{organization}/eventsources

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
eventSourceId path string true The ID of the Event Source to delete.

Responses

Status Meaning Description Schema
200 OK Event Source successfully deleted None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Event Source does not exist None
409 Conflict Event Source could not be deleted due to a conflict None
500 Internal Server Error Internal error None

readAllOptions

Code samples

# You can also use wget
curl -X GET /{organization}/options \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/options

List all Options created by the current user in an Organization. If a page range is specified, then this will return the requested range

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
page query integer false The page number of results to retrieve. If this number exceeds the available data, then the last page is returned.
maxPageSize query integer false The maximum number of entries to return for a given page. If not specified, all data items will be returned.

Example responses

200 Response

{
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"eventSourceId",
"name",
"controls",
"alias",
"gatewayGroups",
"allowSubscriptions",
"hidden"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"organization": {
"description": "Organization this Option belongs to.",
"type": "string"
},
"eventSourceId": {
"description": "Event source that this option belongs to",
"type": "string"
},
"alias": {
"description": "Unique, descriptive alias for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"name": {
"description": "Descriptive name for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "Longer description used to describe what this option is used for",
"type": "string",
"maxLength": 1500
},
"gatewayGroups": {
"description": "List of gateway groups this option should be published to",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"hidden": {
"description": "Indicates if this option is visible in the catalog (draft)",
"type": "boolean"
},
"allowSubscriptions": {
"description": "Indicates if this option is allowing new subscriptions",
"type": "boolean"
},
"controls": {
"description": "Controls on this option",
"type": "array",
"items": {
"anyOf": [
{
"type": "object",
"required": [
"id",
"requests",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"approval"
]
},
"requests": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"status",
"description",
"contact"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"lastUpdated": {
"description": "Unix Epoch timestamp of last update to approval request.",
"type": "integer"
},
"status": {
"description": "The status of this approval request.",
"type": "string",
"enum": [
"pending",
"approved",
"rejected",
"fulfilled"
]
},
"description": {
"description": "Description of why the request was created.",
"type": "string",
"minLength": 1,
"maxLength": 1500
},
"contact": {
"description": "Contact details of the person making the request.",
"type": "string",
"minLength": 1,
"maxLength": 250
},
"outcome": {
"description": "Description of the outcome of this request.",
"type": "string",
"maxLength": 250
},
"subscriptionId": {
"description": "The id of the subscription associated with this request.",
"type": "string",
"maxLength": 250
}
}
}
}
}
},
{
"allOf": [
{
"type": "object",
"required": [
"id",
"redactions",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"redaction"
]
},
"redactions": {
"type": "array",
"items": {
"anyOf": [
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceString"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "string",
"maxLength": 200
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceIntegral",
"replaceDouble"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "number"
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"algorithm",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"hash"
]
},
"algorithm": {
"type": "string",
"description": "Algorithm to use for hashing the current value",
"enum": [
"SHA-256",
"SHA-512"
]
}
}
}
]
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
]
},
{
"type": "object",
"required": [
"id",
"schema",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"schema-filtering"
]
},
"schema": {
"type": "object",
"required": [
"filtered"
],
"properties": {
"filtered": {
"description": "If true, any schema associated with the Event Source will be used to filter records sent to applications",
"type": "boolean"
}
}
}
}
},
{
"type": "object",
"required": [
"type",
"id"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"quota"
]
}
},
"anyOf": [
{
"type": "object",
"required": [
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond",
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
}
]
},
{
"type": "object",
"required": [
"type",
"id",
"identificationType",
"subjectCommonName"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"mtls"
]
},
"identificationType": {
"description": "The type of Identification users will use to distinguish between Subscriptions.",
"type": "string",
"enum": [
"MTLS",
"SASL"
]
},
"identificationSubjectFields": {
"description": "Certificate Subject fields to identify users by if using MTLS identificationType.",
"type": "array",
"items": {
"type": "string",
"enum": [
"subjectCommonName",
"subjectOrganization",
"subjectCountry",
"subjectStateOrProvince",
"subjectLocality"
]
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
},
"approvedCipherSuites": {
"description": "Cipher Suites that are approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"disapprovedCipherSuites": {
"description": "Cipher Suites that are not approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"notValidBefore": {
"description": "Certificate not valid before time.",
"type": "integer"
},
"notValidAfter": {
"description": "Certificate not valid after time.",
"type": "integer"
},
"trustPem": {
"description": "Certificate Authority in PEM format",
"type": "string"
}
}
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Options successfully listed. Inline
304 Not Modified Data not changed None
400 Bad Request Invalid request, only one of page and maxPageSize were supplied or max page size exceeded. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique Option ID.
» owner string true none Option owner.
» organization string true none Organization this Option belongs to.
» eventSourceId string true none Event source that this option belongs to
» alias string true none Unique, descriptive alias for this option
» name string true none Descriptive name for this option
» description string false none Longer description used to describe what this option is used for
» gatewayGroups [string] true none List of gateway groups this option should be published to
» hidden boolean true none Indicates if this option is visible in the catalog (draft)
» allowSubscriptions boolean true none Indicates if this option is allowing new subscriptions
» controls [anyOf] true none Controls on this option

anyOf

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» requests [object] true none none
»»»» id string true none Unique Option ID.
»»»» owner string true none Option owner.
»»»» lastUpdated integer false none Unix Epoch timestamp of last update to approval request.
»»»» status string true none The status of this approval request.
»»»» description string true none Description of why the request was created.
»»»» contact string true none Contact details of the person making the request.
»»»» outcome string false none Description of the outcome of this request.
»»»» subscriptionId string false none The id of the subscription associated with this request.

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» redactions [anyOf] true none none

anyOf

Name Type Required Restrictions Description
»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» type string true none Type of redaction.
»»»»»» replaceWith string true none The value to replace with

or

Name Type Required Restrictions Description
»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» type any true none Type of redaction.
»»»»»» replaceWith number true none The value to replace with

or

Name Type Required Restrictions Description
»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» type string true none Type of redaction.
»»»»»» algorithm string true none Algorithm to use for hashing the current value

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» schema object true none none
»»»» filtered boolean true none If true, any schema associated with the Event Source will be used to filter records sent to applications

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none

anyOf

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond number false none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» megabytesPerSecond number false none Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» identificationType string true none The type of Identification users will use to distinguish between Subscriptions.
»»» identificationSubjectFields [string] false none Certificate Subject fields to identify users by if using MTLS identificationType.
»»» subjectCommonName string true none Subject Common Name to match on.
»»» subjectOrganization string false none Subject Organization to match on.
»»» subjectCountry string false none Subject Country to match on.
»»» subjectStateOrProvince string false none Subject Region to match on.
»»» subjectLocality string false none Subject Locality to match on.
»»» approvedCipherSuites [string] false none Cipher Suites that are approved for use.
»»» disapprovedCipherSuites [string] false none Cipher Suites that are not approved for use.
»»» notValidBefore integer false none Certificate not valid before time.
»»» notValidAfter integer false none Certificate not valid after time.
»»» trustPem string false none Certificate Authority in PEM format

Enumerated Values

Property Value
type approval
status pending
status approved
status rejected
status fulfilled
type redaction
type replaceString
type replaceIntegral
type replaceDouble
type hash
algorithm SHA-256
algorithm SHA-512
type schema-filtering
type quota
type mtls
identificationType MTLS
identificationType SASL

Response Headers

Status Header Type Format Description
200 ei-pagination-total integer Total number of items available for retrieval (including current page).
200 etag string An identifier which can be supplied with the If-None-Match header to indicate that unchanged results should return 304 with no data.

createOption

Code samples

# You can also use wget
curl -X POST /{organization}/options \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

POST /{organization}/options

Create an option

Body parameter

{
"type": "object",
"required": [
"eventSourceId",
"name",
"controls",
"alias",
"gatewayGroups",
"allowSubscriptions",
"hidden"
],
"properties": {
"eventSourceId": {
"description": "Event source that this option belongs to",
"type": "string"
},
"alias": {
"description": "Unique, descriptive alias for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"name": {
"description": "Descriptive name for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "Longer description used to describe what this option is used for",
"type": "string",
"maxLength": 1500
},
"gatewayGroups": {
"description": "List of gateway groups this option should be published to",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"hidden": {
"description": "Indicates if this option is visible in the catalog (draft)",
"type": "boolean"
},
"allowSubscriptions": {
"description": "Indicates if this option is allowing new subscriptions",
"type": "boolean"
},
"controls": {
"description": "Controls on this option",
"type": "array",
"items": {
"anyOf": [
{
"type": "object",
"required": [
"id",
"requests",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"approval"
]
},
"requests": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"status",
"description",
"contact"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"lastUpdated": {
"description": "Unix Epoch timestamp of last update to approval request.",
"type": "integer"
},
"status": {
"description": "The status of this approval request.",
"type": "string",
"enum": [
"pending",
"approved",
"rejected",
"fulfilled"
]
},
"description": {
"description": "Description of why the request was created.",
"type": "string",
"minLength": 1,
"maxLength": 1500
},
"contact": {
"description": "Contact details of the person making the request.",
"type": "string",
"minLength": 1,
"maxLength": 250
},
"outcome": {
"description": "Description of the outcome of this request.",
"type": "string",
"maxLength": 250
},
"subscriptionId": {
"description": "The id of the subscription associated with this request.",
"type": "string",
"maxLength": 250
}
}
}
}
}
},
{
"allOf": [
{
"type": "object",
"required": [
"id",
"redactions",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"redaction"
]
},
"redactions": {
"type": "array",
"items": {
"anyOf": [
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceString"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "string",
"maxLength": 200
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceIntegral",
"replaceDouble"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "number"
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"algorithm",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"hash"
]
},
"algorithm": {
"type": "string",
"description": "Algorithm to use for hashing the current value",
"enum": [
"SHA-256",
"SHA-512"
]
}
}
}
]
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
]
},
{
"type": "object",
"required": [
"id",
"schema",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"schema-filtering"
]
},
"schema": {
"type": "object",
"required": [
"filtered"
],
"properties": {
"filtered": {
"description": "If true, any schema associated with the Event Source will be used to filter records sent to applications",
"type": "boolean"
}
}
}
}
},
{
"type": "object",
"required": [
"type",
"id"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"quota"
]
}
},
"anyOf": [
{
"type": "object",
"required": [
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond",
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
}
]
},
{
"type": "object",
"required": [
"type",
"id",
"identificationType",
"subjectCommonName"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"mtls"
]
},
"identificationType": {
"description": "The type of Identification users will use to distinguish between Subscriptions.",
"type": "string",
"enum": [
"MTLS",
"SASL"
]
},
"identificationSubjectFields": {
"description": "Certificate Subject fields to identify users by if using MTLS identificationType.",
"type": "array",
"items": {
"type": "string",
"enum": [
"subjectCommonName",
"subjectOrganization",
"subjectCountry",
"subjectStateOrProvince",
"subjectLocality"
]
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
},
"approvedCipherSuites": {
"description": "Cipher Suites that are approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"disapprovedCipherSuites": {
"description": "Cipher Suites that are not approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"notValidBefore": {
"description": "Certificate not valid before time.",
"type": "integer"
},
"notValidAfter": {
"description": "Certificate not valid after time.",
"type": "integer"
},
"trustPem": {
"description": "Certificate Authority in PEM format",
"type": "string"
}
}
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
body body object true Option data
» eventSourceId body string true Event source that this option belongs to
» alias body string true Unique, descriptive alias for this option
» name body string true Descriptive name for this option
» description body string false Longer description used to describe what this option is used for
» gatewayGroups body [string] true List of gateway groups this option should be published to
» hidden body boolean true Indicates if this option is visible in the catalog (draft)
» allowSubscriptions body boolean true Indicates if this option is allowing new subscriptions
» controls body [anyOf] true Controls on this option
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» requests body [object] true none
»»»» id body string true Unique Option ID.
»»»» owner body string true Option owner.
»»»» lastUpdated body integer false Unix Epoch timestamp of last update to approval request.
»»»» status body string true The status of this approval request.
»»»» description body string true Description of why the request was created.
»»»» contact body string true Contact details of the person making the request.
»»»» outcome body string false Description of the outcome of this request.
»»»» subscriptionId body string false The id of the subscription associated with this request.
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» redactions body [anyOf] true none
»»»» anonymous body any false none
»»»»» anonymous body object false none
»»»»»» path body string true The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)
»»»»» anonymous body object false none
»»»»»» type body string true Type of redaction.
»»»»»» replaceWith body string true The value to replace with
»»»» anonymous body any false none
»»»»» anonymous body object false none
»»»»»» path body string true The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)
»»»»» anonymous body object false none
»»»»»» type body any true Type of redaction.
»»»»»» replaceWith body number true The value to replace with
»»»» anonymous body any false none
»»»»» anonymous body object false none
»»»»»» path body string true The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)
»»»»» anonymous body object false none
»»»»»» type body string true Type of redaction.
»»»»»» algorithm body string true Algorithm to use for hashing the current value
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» schema body object true none
»»»» filtered body boolean true If true, any schema associated with the Event Source will be used to filter records sent to applications
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» anonymous body object false none
»»»» megabytesPerSecond body number true Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond body number false Upper limit to messages per second produced/consumed
»»» anonymous body object false none
»»»» megabytesPerSecond body number false Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond body number true Upper limit to messages per second produced/consumed
»»» anonymous body object false none
»»»» megabytesPerSecond body number true Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond body number true Upper limit to messages per second produced/consumed
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» identificationType body string true The type of Identification users will use to distinguish between Subscriptions.
»»» identificationSubjectFields body [string] false Certificate Subject fields to identify users by if using MTLS identificationType.
»»» subjectCommonName body string true Subject Common Name to match on.
»»» subjectOrganization body string false Subject Organization to match on.
»»» subjectCountry body string false Subject Country to match on.
»»» subjectStateOrProvince body string false Subject Region to match on.
»»» subjectLocality body string false Subject Locality to match on.
»»» approvedCipherSuites body [string] false Cipher Suites that are approved for use.
»»» disapprovedCipherSuites body [string] false Cipher Suites that are not approved for use.
»»» notValidBefore body integer false Certificate not valid before time.
»»» notValidAfter body integer false Certificate not valid after time.
»»» trustPem body string false Certificate Authority in PEM format

Enumerated Values

Parameter Value
»»» type approval
»»»» status pending
»»»» status approved
»»»» status rejected
»»»» status fulfilled
»»» type redaction
»»»»»» type replaceString
»»»»»» type replaceIntegral
»»»»»» type replaceDouble
»»»»»» type hash
»»»»»» algorithm SHA-256
»»»»»» algorithm SHA-512
»»» type schema-filtering
»»» type quota
»»» type mtls
»»» identificationType MTLS
»»» identificationType SASL
»»» identificationSubjectFields subjectCommonName
»»» identificationSubjectFields subjectOrganization
»»» identificationSubjectFields subjectCountry
»»» identificationSubjectFields subjectStateOrProvince
»»» identificationSubjectFields subjectLocality

Example responses

200 Response

{
"type": "object",
"properties": {
"id": {
"type": "string"
}
}
}

Responses

Status Meaning Description Schema
200 OK The id of the created option Inline
400 Bad Request Invalid request, request data does not match schema or Controls specified not compatible with gateway group. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string false none none

readOption

Code samples

# You can also use wget
curl -X GET /{organization}/options/{optionId} \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/options/{optionId}

Read an option

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
optionId path string true The ID of the Option to read.

Example responses

200 Response

{
"type": "object",
"required": [
"id",
"owner",
"organization",
"eventSourceId",
"name",
"controls",
"alias",
"gatewayGroups",
"allowSubscriptions",
"hidden"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"organization": {
"description": "Organization this Option belongs to.",
"type": "string"
},
"eventSourceId": {
"description": "Event source that this option belongs to",
"type": "string"
},
"alias": {
"description": "Unique, descriptive alias for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"name": {
"description": "Descriptive name for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "Longer description used to describe what this option is used for",
"type": "string",
"maxLength": 1500
},
"gatewayGroups": {
"description": "List of gateway groups this option should be published to",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"hidden": {
"description": "Indicates if this option is visible in the catalog (draft)",
"type": "boolean"
},
"allowSubscriptions": {
"description": "Indicates if this option is allowing new subscriptions",
"type": "boolean"
},
"controls": {
"description": "Controls on this option",
"type": "array",
"items": {
"anyOf": [
{
"type": "object",
"required": [
"id",
"requests",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"approval"
]
},
"requests": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"status",
"description",
"contact"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"lastUpdated": {
"description": "Unix Epoch timestamp of last update to approval request.",
"type": "integer"
},
"status": {
"description": "The status of this approval request.",
"type": "string",
"enum": [
"pending",
"approved",
"rejected",
"fulfilled"
]
},
"description": {
"description": "Description of why the request was created.",
"type": "string",
"minLength": 1,
"maxLength": 1500
},
"contact": {
"description": "Contact details of the person making the request.",
"type": "string",
"minLength": 1,
"maxLength": 250
},
"outcome": {
"description": "Description of the outcome of this request.",
"type": "string",
"maxLength": 250
},
"subscriptionId": {
"description": "The id of the subscription associated with this request.",
"type": "string",
"maxLength": 250
}
}
}
}
}
},
{
"allOf": [
{
"type": "object",
"required": [
"id",
"redactions",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"redaction"
]
},
"redactions": {
"type": "array",
"items": {
"anyOf": [
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceString"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "string",
"maxLength": 200
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceIntegral",
"replaceDouble"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "number"
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"algorithm",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"hash"
]
},
"algorithm": {
"type": "string",
"description": "Algorithm to use for hashing the current value",
"enum": [
"SHA-256",
"SHA-512"
]
}
}
}
]
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
]
},
{
"type": "object",
"required": [
"id",
"schema",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"schema-filtering"
]
},
"schema": {
"type": "object",
"required": [
"filtered"
],
"properties": {
"filtered": {
"description": "If true, any schema associated with the Event Source will be used to filter records sent to applications",
"type": "boolean"
}
}
}
}
},
{
"type": "object",
"required": [
"type",
"id"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"quota"
]
}
},
"anyOf": [
{
"type": "object",
"required": [
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond",
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
}
]
},
{
"type": "object",
"required": [
"type",
"id",
"identificationType",
"subjectCommonName"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"mtls"
]
},
"identificationType": {
"description": "The type of Identification users will use to distinguish between Subscriptions.",
"type": "string",
"enum": [
"MTLS",
"SASL"
]
},
"identificationSubjectFields": {
"description": "Certificate Subject fields to identify users by if using MTLS identificationType.",
"type": "array",
"items": {
"type": "string",
"enum": [
"subjectCommonName",
"subjectOrganization",
"subjectCountry",
"subjectStateOrProvince",
"subjectLocality"
]
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
},
"approvedCipherSuites": {
"description": "Cipher Suites that are approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"disapprovedCipherSuites": {
"description": "Cipher Suites that are not approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"notValidBefore": {
"description": "Certificate not valid before time.",
"type": "integer"
},
"notValidAfter": {
"description": "Certificate not valid after time.",
"type": "integer"
},
"trustPem": {
"description": "Certificate Authority in PEM format",
"type": "string"
}
}
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK The data for the requested option Inline
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Option does not exist None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique Option ID.
» owner string true none Option owner.
» organization string true none Organization this Option belongs to.
» eventSourceId string true none Event source that this option belongs to
» alias string true none Unique, descriptive alias for this option
» name string true none Descriptive name for this option
» description string false none Longer description used to describe what this option is used for
» gatewayGroups [string] true none List of gateway groups this option should be published to
» hidden boolean true none Indicates if this option is visible in the catalog (draft)
» allowSubscriptions boolean true none Indicates if this option is allowing new subscriptions
» controls [anyOf] true none Controls on this option

anyOf

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» requests [object] true none none
»»»» id string true none Unique Option ID.
»»»» owner string true none Option owner.
»»»» lastUpdated integer false none Unix Epoch timestamp of last update to approval request.
»»»» status string true none The status of this approval request.
»»»» description string true none Description of why the request was created.
»»»» contact string true none Contact details of the person making the request.
»»»» outcome string false none Description of the outcome of this request.
»»»» subscriptionId string false none The id of the subscription associated with this request.

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» redactions [anyOf] true none none

anyOf

Name Type Required Restrictions Description
»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» type string true none Type of redaction.
»»»»»» replaceWith string true none The value to replace with

or

Name Type Required Restrictions Description
»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» type any true none Type of redaction.
»»»»»» replaceWith number true none The value to replace with

or

Name Type Required Restrictions Description
»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»» anonymous object false none none
»»»»»» type string true none Type of redaction.
»»»»»» algorithm string true none Algorithm to use for hashing the current value

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» schema object true none none
»»»» filtered boolean true none If true, any schema associated with the Event Source will be used to filter records sent to applications

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none

anyOf

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond number false none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» megabytesPerSecond number false none Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»» anonymous object false none none
»»» id string true none Unique Control ID.
»»» type string true none none
»»» identificationType string true none The type of Identification users will use to distinguish between Subscriptions.
»»» identificationSubjectFields [string] false none Certificate Subject fields to identify users by if using MTLS identificationType.
»»» subjectCommonName string true none Subject Common Name to match on.
»»» subjectOrganization string false none Subject Organization to match on.
»»» subjectCountry string false none Subject Country to match on.
»»» subjectStateOrProvince string false none Subject Region to match on.
»»» subjectLocality string false none Subject Locality to match on.
»»» approvedCipherSuites [string] false none Cipher Suites that are approved for use.
»»» disapprovedCipherSuites [string] false none Cipher Suites that are not approved for use.
»»» notValidBefore integer false none Certificate not valid before time.
»»» notValidAfter integer false none Certificate not valid after time.
»»» trustPem string false none Certificate Authority in PEM format

Enumerated Values

Property Value
type approval
status pending
status approved
status rejected
status fulfilled
type redaction
type replaceString
type replaceIntegral
type replaceDouble
type hash
algorithm SHA-256
algorithm SHA-512
type schema-filtering
type quota
type mtls
identificationType MTLS
identificationType SASL

updateOption

Code samples

# You can also use wget
curl -X PUT /{organization}/options/{optionId} \
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer {access-token}'

PUT /{organization}/options/{optionId}

Update an option

Body parameter

{
"type": "object",
"required": [
"eventSourceId",
"name",
"controls",
"alias",
"gatewayGroups",
"allowSubscriptions",
"hidden"
],
"properties": {
"eventSourceId": {
"description": "Event source that this option belongs to",
"type": "string"
},
"alias": {
"description": "Unique, descriptive alias for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"name": {
"description": "Descriptive name for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "Longer description used to describe what this option is used for",
"type": "string",
"maxLength": 1500
},
"gatewayGroups": {
"description": "List of gateway groups this option should be published to",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"hidden": {
"description": "Indicates if this option is visible in the catalog (draft)",
"type": "boolean"
},
"allowSubscriptions": {
"description": "Indicates if this option is allowing new subscriptions",
"type": "boolean"
},
"controls": {
"description": "Controls on this option",
"type": "array",
"items": {
"anyOf": [
{
"type": "object",
"required": [
"id",
"requests",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"approval"
]
},
"requests": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"status",
"description",
"contact"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"lastUpdated": {
"description": "Unix Epoch timestamp of last update to approval request.",
"type": "integer"
},
"status": {
"description": "The status of this approval request.",
"type": "string",
"enum": [
"pending",
"approved",
"rejected",
"fulfilled"
]
},
"description": {
"description": "Description of why the request was created.",
"type": "string",
"minLength": 1,
"maxLength": 1500
},
"contact": {
"description": "Contact details of the person making the request.",
"type": "string",
"minLength": 1,
"maxLength": 250
},
"outcome": {
"description": "Description of the outcome of this request.",
"type": "string",
"maxLength": 250
},
"subscriptionId": {
"description": "The id of the subscription associated with this request.",
"type": "string",
"maxLength": 250
}
}
}
}
}
},
{
"allOf": [
{
"type": "object",
"required": [
"id",
"redactions",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"redaction"
]
},
"redactions": {
"type": "array",
"items": {
"anyOf": [
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceString"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "string",
"maxLength": 200
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceIntegral",
"replaceDouble"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "number"
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"algorithm",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"hash"
]
},
"algorithm": {
"type": "string",
"description": "Algorithm to use for hashing the current value",
"enum": [
"SHA-256",
"SHA-512"
]
}
}
}
]
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
]
},
{
"type": "object",
"required": [
"id",
"schema",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"schema-filtering"
]
},
"schema": {
"type": "object",
"required": [
"filtered"
],
"properties": {
"filtered": {
"description": "If true, any schema associated with the Event Source will be used to filter records sent to applications",
"type": "boolean"
}
}
}
}
},
{
"type": "object",
"required": [
"type",
"id"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"quota"
]
}
},
"anyOf": [
{
"type": "object",
"required": [
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond",
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
}
]
},
{
"type": "object",
"required": [
"type",
"id",
"identificationType",
"subjectCommonName"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"mtls"
]
},
"identificationType": {
"description": "The type of Identification users will use to distinguish between Subscriptions.",
"type": "string",
"enum": [
"MTLS",
"SASL"
]
},
"identificationSubjectFields": {
"description": "Certificate Subject fields to identify users by if using MTLS identificationType.",
"type": "array",
"items": {
"type": "string",
"enum": [
"subjectCommonName",
"subjectOrganization",
"subjectCountry",
"subjectStateOrProvince",
"subjectLocality"
]
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
},
"approvedCipherSuites": {
"description": "Cipher Suites that are approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"disapprovedCipherSuites": {
"description": "Cipher Suites that are not approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"notValidBefore": {
"description": "Certificate not valid before time.",
"type": "integer"
},
"notValidAfter": {
"description": "Certificate not valid after time.",
"type": "integer"
},
"trustPem": {
"description": "Certificate Authority in PEM format",
"type": "string"
}
}
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
optionId path string true The ID of the Option to update.
body body object true Option data
» eventSourceId body string true Event source that this option belongs to
» alias body string true Unique, descriptive alias for this option
» name body string true Descriptive name for this option
» description body string false Longer description used to describe what this option is used for
» gatewayGroups body [string] true List of gateway groups this option should be published to
» hidden body boolean true Indicates if this option is visible in the catalog (draft)
» allowSubscriptions body boolean true Indicates if this option is allowing new subscriptions
» controls body [anyOf] true Controls on this option
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» requests body [object] true none
»»»» id body string true Unique Option ID.
»»»» owner body string true Option owner.
»»»» lastUpdated body integer false Unix Epoch timestamp of last update to approval request.
»»»» status body string true The status of this approval request.
»»»» description body string true Description of why the request was created.
»»»» contact body string true Contact details of the person making the request.
»»»» outcome body string false Description of the outcome of this request.
»»»» subscriptionId body string false The id of the subscription associated with this request.
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» redactions body [anyOf] true none
»»»» anonymous body any false none
»»»»» anonymous body object false none
»»»»»» path body string true The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)
»»»»» anonymous body object false none
»»»»»» type body string true Type of redaction.
»»»»»» replaceWith body string true The value to replace with
»»»» anonymous body any false none
»»»»» anonymous body object false none
»»»»»» path body string true The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)
»»»»» anonymous body object false none
»»»»»» type body any true Type of redaction.
»»»»»» replaceWith body number true The value to replace with
»»»» anonymous body any false none
»»»»» anonymous body object false none
»»»»»» path body string true The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)
»»»»» anonymous body object false none
»»»»»» type body string true Type of redaction.
»»»»»» algorithm body string true Algorithm to use for hashing the current value
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» schema body object true none
»»»» filtered body boolean true If true, any schema associated with the Event Source will be used to filter records sent to applications
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» anonymous body object false none
»»»» megabytesPerSecond body number true Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond body number false Upper limit to messages per second produced/consumed
»»» anonymous body object false none
»»»» megabytesPerSecond body number false Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond body number true Upper limit to messages per second produced/consumed
»»» anonymous body object false none
»»»» megabytesPerSecond body number true Upper limit to megabytes per second produced/consumed
»»»» messagesPerSecond body number true Upper limit to messages per second produced/consumed
»» anonymous body object false none
»»» id body string true Unique Control ID.
»»» type body string true none
»»» identificationType body string true The type of Identification users will use to distinguish between Subscriptions.
»»» identificationSubjectFields body [string] false Certificate Subject fields to identify users by if using MTLS identificationType.
»»» subjectCommonName body string true Subject Common Name to match on.
»»» subjectOrganization body string false Subject Organization to match on.
»»» subjectCountry body string false Subject Country to match on.
»»» subjectStateOrProvince body string false Subject Region to match on.
»»» subjectLocality body string false Subject Locality to match on.
»»» approvedCipherSuites body [string] false Cipher Suites that are approved for use.
»»» disapprovedCipherSuites body [string] false Cipher Suites that are not approved for use.
»»» notValidBefore body integer false Certificate not valid before time.
»»» notValidAfter body integer false Certificate not valid after time.
»»» trustPem body string false Certificate Authority in PEM format

Enumerated Values

Parameter Value
»»» type approval
»»»» status pending
»»»» status approved
»»»» status rejected
»»»» status fulfilled
»»» type redaction
»»»»»» type replaceString
»»»»»» type replaceIntegral
»»»»»» type replaceDouble
»»»»»» type hash
»»»»»» algorithm SHA-256
»»»»»» algorithm SHA-512
»»» type schema-filtering
»»» type quota
»»» type mtls
»»» identificationType MTLS
»»» identificationType SASL
»»» identificationSubjectFields subjectCommonName
»»» identificationSubjectFields subjectOrganization
»»» identificationSubjectFields subjectCountry
»»» identificationSubjectFields subjectStateOrProvince
»»» identificationSubjectFields subjectLocality

Responses

Status Meaning Description Schema
200 OK Option successfully updated None
400 Bad Request Invalid request, request data does not match schema or Controls specified not compatible with gateway group. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Option does not exist None
500 Internal Server Error Internal error None

deleteOption

Code samples

# You can also use wget
curl -X DELETE /{organization}/options/{optionId} \
-H 'Authorization: Bearer {access-token}'

DELETE /{organization}/options/{optionId}

Delete an Option.

The Option must be unpublished with no remaining Subscriptions. Note - You must be the owner to delete an Option. You can view all of the Options that you own (including their ‘id’) by using GET /{organization}/options

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
optionId path string true The ID of the Option to delete.

Responses

Status Meaning Description Schema
200 OK Option successfully deleted None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Option does not exist None
409 Conflict Option could not be deleted due to a conflict None
500 Internal Server Error Internal error None

exportAPICAsyncAPI

Code samples

# You can also use wget
curl -X GET /{organization}/options/{optionId}/apicasyncapi \
-H 'Accept: application/yaml' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/options/{optionId}/apicasyncapi

Generate an AsyncAPI document for a selected Option with connections added for IBM API Connect.

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
optionId path string true The ID of the option in the Event source.
version query string false The version of AsyncAPI

Example responses

200 Response

Responses

Status Meaning Description Schema
200 OK AsyncAPI successfully generated. string
400 Bad Request Bad input None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found Option not found None
422 Unprocessable Entity Cannot export option with approval control None
500 Internal Server Error Internal error None

exportAsyncAPI

Code samples

# You can also use wget
curl -X GET /{organization}/options/{optionId}/asyncapi \
-H 'Accept: application/yaml' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/options/{optionId}/asyncapi

Generate an AsyncAPI document for a selected Option.

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
optionId path string true The ID of the option in the Event source.
version query string false The version of AsyncAPI

Example responses

200 Response

Responses

Status Meaning Description Schema
200 OK AsyncAPI successfully generated. string
400 Bad Request Bad input None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found Option not found None
500 Internal Server Error Internal error None

readAllEventEndpoints

Code samples

# You can also use wget
curl -X GET /{organization}/eventendpoints \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/eventendpoints

List all Event Endpoints in an Organization. If a page range is specified, then this will return the requested range.

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
page query integer false The page number of results to retrieve. If this number exceeds the available data, then the last page is returned.
maxPageSize query integer false The maximum number of entries to return for a given page. If not specified, all data items will be returned.
filterBy query string false capability to filterBy

Enumerated Values

Parameter Value
filterBy consume
filterBy produce

Example responses

200 Response

{
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"clusterId",
"type",
"encoding",
"name",
"contact",
"capabilities",
"options"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique ID of related EventSource.",
"type": "string"
},
"owner": {
"description": "Owner of related EventSource.",
"type": "string"
},
"organization": {
"description": "Organization the related EventSource belongs to.",
"type": "string"
},
"clusterId": {
"description": "ID for the cluster that contains the connection details for this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"type": {
"description": "Type of Event Source",
"type": "string",
"enum": [
"kafka"
]
},
"encoding": {
"description": "The encoding of the data on this Event Source",
"type": "string",
"enum": [
"unknown",
"text/plain",
"application/octet-stream",
"application/json",
"avro/binary",
"avro/json"
]
},
"name": {
"description": "Event Source name",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"contact": {
"description": "Who to contact for more information about this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "A description for this Event Source",
"type": "string",
"maxLength": 1500
},
"topic": {
"type": "object",
"required": [
"name"
],
"additionalProperties": false,
"properties": {
"name": {
"description": "Actual topic name in the cluster.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"partitions": {
"description": "The number of partitions for this topic. ",
"type": "number"
},
"replicas": {
"description": "The number of replicas for this topic.",
"type": "number"
}
}
},
"schema": {
"type": "object",
"properties": {
"type": {
"description": "Type of Schema from the list of valid types",
"type": "string",
"enum": [
"avro",
"json",
"unknown"
]
},
"content": {
"description": "Contents of the Schema",
"type": "string",
"maxLength": 1048576
},
"description": {
"description": "Description of the data available on the Event Source",
"type": "string",
"maxLength": 1500
}
},
"additionalProperties": false
},
"tags": {
"description": "List of tags associated with this Event Source",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 50
}
},
"sampleMessages": {
"type": "array",
"items": {
"type": "string"
}
},
"capabilities": {
"type": "array",
"minItems": 1,
"maxItems": 1,
"uniqueItems": true,
"items": {
"description": "Capabilities enum.",
"type": "string",
"enum": [
"consume",
"produce"
]
}
},
"options": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"eventSourceId",
"name",
"controls",
"alias",
"gatewayGroups",
"allowSubscriptions",
"hidden",
"gatewaysPublishedTo"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"organization": {
"description": "Organization this Option belongs to.",
"type": "string"
},
"eventSourceId": {
"description": "Event source that this option belongs to",
"type": "string"
},
"alias": {
"description": "Unique, descriptive alias for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"name": {
"description": "Descriptive name for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "Longer description used to describe what this option is used for",
"type": "string",
"maxLength": 1500
},
"gatewayGroups": {
"description": "List of gateway groups this option should be published to",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"hidden": {
"description": "Indicates if this option is visible in the catalog (draft)",
"type": "boolean"
},
"allowSubscriptions": {
"description": "Indicates if this option is allowing new subscriptions",
"type": "boolean"
},
"controls": {
"description": "Controls on this option",
"type": "array",
"items": {
"anyOf": [
{
"type": "object",
"required": [
"id",
"requests",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"approval"
]
},
"requests": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"status",
"description",
"contact"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"lastUpdated": {
"description": "Unix Epoch timestamp of last update to approval request.",
"type": "integer"
},
"status": {
"description": "The status of this approval request.",
"type": "string",
"enum": [
"pending",
"approved",
"rejected",
"fulfilled"
]
},
"description": {
"description": "Description of why the request was created.",
"type": "string",
"minLength": 1,
"maxLength": 1500
},
"contact": {
"description": "Contact details of the person making the request.",
"type": "string",
"minLength": 1,
"maxLength": 250
},
"outcome": {
"description": "Description of the outcome of this request.",
"type": "string",
"maxLength": 250
},
"subscriptionId": {
"description": "The id of the subscription associated with this request.",
"type": "string",
"maxLength": 250
}
}
}
}
}
},
{
"allOf": [
{
"type": "object",
"required": [
"id",
"redactions",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"redaction"
]
},
"redactions": {
"type": "array",
"items": {
"anyOf": [
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceString"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "string",
"maxLength": 200
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceIntegral",
"replaceDouble"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "number"
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"algorithm",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"hash"
]
},
"algorithm": {
"type": "string",
"description": "Algorithm to use for hashing the current value",
"enum": [
"SHA-256",
"SHA-512"
]
}
}
}
]
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
]
},
{
"type": "object",
"required": [
"id",
"schema",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"schema-filtering"
]
},
"schema": {
"type": "object",
"required": [
"filtered"
],
"properties": {
"filtered": {
"description": "If true, any schema associated with the Event Source will be used to filter records sent to applications",
"type": "boolean"
}
}
}
}
},
{
"type": "object",
"required": [
"type",
"id"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"quota"
]
}
},
"anyOf": [
{
"type": "object",
"required": [
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond",
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
}
]
},
{
"type": "object",
"required": [
"type",
"id",
"identificationType",
"subjectCommonName"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"mtls"
]
},
"identificationType": {
"description": "The type of Identification users will use to distinguish between Subscriptions.",
"type": "string",
"enum": [
"MTLS",
"SASL"
]
},
"identificationSubjectFields": {
"description": "Certificate Subject fields to identify users by if using MTLS identificationType.",
"type": "array",
"items": {
"type": "string",
"enum": [
"subjectCommonName",
"subjectOrganization",
"subjectCountry",
"subjectStateOrProvince",
"subjectLocality"
]
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
},
"approvedCipherSuites": {
"description": "Cipher Suites that are approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"disapprovedCipherSuites": {
"description": "Cipher Suites that are not approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"notValidBefore": {
"description": "Certificate not valid before time.",
"type": "integer"
},
"notValidAfter": {
"description": "Certificate not valid after time.",
"type": "integer"
},
"trustPem": {
"description": "Certificate Authority in PEM format",
"type": "string"
}
}
}
],
"discriminator": {
"propertyName": "type"
}
}
},
"gatewaysPublishedTo": {
"description": "List of gateways that this option has been published to.",
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"gatewayId",
"group",
"organizations",
"servedOrganizations",
"endpoints",
"lastContact"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Event Gateway ID",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"owner": {
"description": "Owner of the Event Gateway.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"organization": {
"description": "Organization this Event Gateway belongs to.",
"type": "string"
},
"gatewayId": {
"description": "Unique Event Gateway ID within this group.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"group": {
"description": "Event Gateway group name.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"organizations": {
"description": "Organizations this Event Gateway serves",
"type": "array",
"deprecated": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 100
}
},
"servedOrganizations": {
"description": "Organizations this Event Gateway serves",
"type": "array",
"items": {
"type": "string",
"minLength": 1,
"maxLength": 100
}
},
"contact": {
"description": "The contact information for this Event Gateway",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"lastContact": {
"description": "Epoch time in ms of the last contact from this gateway.",
"type": "integer",
"minimum": 0
},
"endpoints": {
"description": "Endpoints that the gateway is listening on.",
"type": "array",
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"version": {
"type": "string",
"description": "Version of the gateway",
"minLength": 1,
"maxLength": 20
},
"productVersion": {
"type": "string",
"description": "EEM product version.",
"minLength": 1,
"maxLength": 100
},
"features": {
"type": "array",
"description": "Feature set in use by gateway",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 20
}
},
"deploymentMode": {
"type": "string",
"description": "Type of gateway deployment"
},
"capabilities": {
"type": "object",
"additionalProperties": true,
"description": "Freeform Description of what capabilities the gateway has"
}
}
}
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Event Endpoints successfully listed. Inline
304 Not Modified Data not changed None
400 Bad Request Invalid request, only one of page and maxPageSize were supplied or max page size exceeded. None
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique ID of related EventSource.
» owner string true none Owner of related EventSource.
» organization string true none Organization the related EventSource belongs to.
» clusterId string true none ID for the cluster that contains the connection details for this Event Source.
» type string true none Type of Event Source
» encoding string true none The encoding of the data on this Event Source
» name string true none Event Source name
» contact string true none Who to contact for more information about this Event Source.
» description string false none A description for this Event Source
» topic object false none none
»» name string true none Actual topic name in the cluster.
»» partitions number false none The number of partitions for this topic.
»» replicas number false none The number of replicas for this topic.
» schema object false none none
»» type string false none Type of Schema from the list of valid types
»» content string false none Contents of the Schema
»» description string false none Description of the data available on the Event Source
» tags [string] false none List of tags associated with this Event Source
» sampleMessages [string] false none none
» capabilities [string] true none none
» options [object] true none none
»» id string true none Unique Option ID.
»» owner string true none Option owner.
»» organization string true none Organization this Option belongs to.
»» eventSourceId string true none Event source that this option belongs to
»» alias string true none Unique, descriptive alias for this option
»» name string true none Descriptive name for this option
»» description string false none Longer description used to describe what this option is used for
»» gatewayGroups [string] true none List of gateway groups this option should be published to
»» hidden boolean true none Indicates if this option is visible in the catalog (draft)
»» allowSubscriptions boolean true none Indicates if this option is allowing new subscriptions
»» controls [anyOf] true none Controls on this option

anyOf

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» requests [object] true none none
»»»»» id string true none Unique Option ID.
»»»»» owner string true none Option owner.
»»»»» lastUpdated integer false none Unix Epoch timestamp of last update to approval request.
»»»»» status string true none The status of this approval request.
»»»»» description string true none Description of why the request was created.
»»»»» contact string true none Contact details of the person making the request.
»»»»» outcome string false none Description of the outcome of this request.
»»»»» subscriptionId string false none The id of the subscription associated with this request.

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» redactions [anyOf] true none none

anyOf

Name Type Required Restrictions Description
»»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» type string true none Type of redaction.
»»»»»»» replaceWith string true none The value to replace with

or

Name Type Required Restrictions Description
»»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» type any true none Type of redaction.
»»»»»»» replaceWith number true none The value to replace with

or

Name Type Required Restrictions Description
»»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» type string true none Type of redaction.
»»»»»»» algorithm string true none Algorithm to use for hashing the current value

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» schema object true none none
»»»»» filtered boolean true none If true, any schema associated with the Event Source will be used to filter records sent to applications

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none

anyOf

Name Type Required Restrictions Description
»»»» anonymous object false none none
»»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»»» messagesPerSecond number false none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»»» anonymous object false none none
»»»»» megabytesPerSecond number false none Upper limit to megabytes per second produced/consumed
»»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»»» anonymous object false none none
»»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» identificationType string true none The type of Identification users will use to distinguish between Subscriptions.
»»»» identificationSubjectFields [string] false none Certificate Subject fields to identify users by if using MTLS identificationType.
»»»» subjectCommonName string true none Subject Common Name to match on.
»»»» subjectOrganization string false none Subject Organization to match on.
»»»» subjectCountry string false none Subject Country to match on.
»»»» subjectStateOrProvince string false none Subject Region to match on.
»»»» subjectLocality string false none Subject Locality to match on.
»»»» approvedCipherSuites [string] false none Cipher Suites that are approved for use.
»»»» disapprovedCipherSuites [string] false none Cipher Suites that are not approved for use.
»»»» notValidBefore integer false none Certificate not valid before time.
»»»» notValidAfter integer false none Certificate not valid after time.
»»»» trustPem string false none Certificate Authority in PEM format

continued

Name Type Required Restrictions Description
»» gatewaysPublishedTo [object] true none List of gateways that this option has been published to.
»»» id string true none Unique Event Gateway ID
»»» owner string true none Owner of the Event Gateway.
»»» organization string true none Organization this Event Gateway belongs to.
»»» gatewayId string true none Unique Event Gateway ID within this group.
»»» group string true none Event Gateway group name.
»»» organizations [string] true none Organizations this Event Gateway serves
»»» servedOrganizations [string] true none Organizations this Event Gateway serves
»»» contact string false none The contact information for this Event Gateway
»»» lastContact integer true none Epoch time in ms of the last contact from this gateway.
»»» endpoints [object] true none Endpoints that the gateway is listening on.
»»»» host string true none Kafka server host name.
»»»» port integer true none Kafka server port.
»»»» ssl boolean false none Connect over SSL.
»»»» certificates [object] false none Certificates or CAs to trust when connecting to the server via SSL.
»»»»» pem string true none Certificate in PEM format
»»»»» subject string false none Subject name of the certificate
»»»»» sans [string] false none A list of subject alternative names of the certificate
»»»»» issuer string false none Issuer of the certificate
»»»»» expiry integer false none Expiration date of the certificate in epoch millis
»»» version string false none Version of the gateway
»»» productVersion string false none EEM product version.
»»» features [string] false none Feature set in use by gateway
»»» deploymentMode string false none Type of gateway deployment
»»» capabilities object false none Freeform Description of what capabilities the gateway has

Enumerated Values

Property Value
type kafka
encoding unknown
encoding text/plain
encoding application/octet-stream
encoding application/json
encoding avro/binary
encoding avro/json
type avro
type json
type unknown
type approval
status pending
status approved
status rejected
status fulfilled
type redaction
type replaceString
type replaceIntegral
type replaceDouble
type hash
algorithm SHA-256
algorithm SHA-512
type schema-filtering
type quota
type mtls
identificationType MTLS
identificationType SASL

Response Headers

Status Header Type Format Description
200 ei-pagination-total integer Total number of items available for retrieval (including current page).
200 etag string An identifier which can be supplied with the If-None-Match header to indicate that unchanged results should return 304 with no data.

readEventEndpoint

Code samples

# You can also use wget
curl -X GET /{organization}/eventendpoints/{eventSourceId} \
-H 'Accept: application/json' \
-H 'Authorization: Bearer {access-token}'

GET /{organization}/eventendpoints/{eventSourceId}

Read an event endpoint

Parameters

Name In Type Required Description
organization path string true The ID of the Organization.
eventSourceId path string true The ID of the Event Source to read an Event Endpoint from.

Example responses

200 Response

{
"type": "object",
"required": [
"id",
"owner",
"organization",
"clusterId",
"type",
"encoding",
"name",
"contact",
"capabilities",
"options"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique ID of related EventSource.",
"type": "string"
},
"owner": {
"description": "Owner of related EventSource.",
"type": "string"
},
"organization": {
"description": "Organization the related EventSource belongs to.",
"type": "string"
},
"clusterId": {
"description": "ID for the cluster that contains the connection details for this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"type": {
"description": "Type of Event Source",
"type": "string",
"enum": [
"kafka"
]
},
"encoding": {
"description": "The encoding of the data on this Event Source",
"type": "string",
"enum": [
"unknown",
"text/plain",
"application/octet-stream",
"application/json",
"avro/binary",
"avro/json"
]
},
"name": {
"description": "Event Source name",
"type": "string",
"minLength": 1,
"maxLength": 50
},
"contact": {
"description": "Who to contact for more information about this Event Source.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "A description for this Event Source",
"type": "string",
"maxLength": 1500
},
"topic": {
"type": "object",
"required": [
"name"
],
"additionalProperties": false,
"properties": {
"name": {
"description": "Actual topic name in the cluster.",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"partitions": {
"description": "The number of partitions for this topic. ",
"type": "number"
},
"replicas": {
"description": "The number of replicas for this topic.",
"type": "number"
}
}
},
"schema": {
"type": "object",
"properties": {
"type": {
"description": "Type of Schema from the list of valid types",
"type": "string",
"enum": [
"avro",
"json",
"unknown"
]
},
"content": {
"description": "Contents of the Schema",
"type": "string",
"maxLength": 1048576
},
"description": {
"description": "Description of the data available on the Event Source",
"type": "string",
"maxLength": 1500
}
},
"additionalProperties": false
},
"tags": {
"description": "List of tags associated with this Event Source",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 50
}
},
"sampleMessages": {
"type": "array",
"items": {
"type": "string"
}
},
"capabilities": {
"type": "array",
"minItems": 1,
"maxItems": 1,
"uniqueItems": true,
"items": {
"description": "Capabilities enum.",
"type": "string",
"enum": [
"consume",
"produce"
]
}
},
"options": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"eventSourceId",
"name",
"controls",
"alias",
"gatewayGroups",
"allowSubscriptions",
"hidden",
"gatewaysPublishedTo"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"organization": {
"description": "Organization this Option belongs to.",
"type": "string"
},
"eventSourceId": {
"description": "Event source that this option belongs to",
"type": "string"
},
"alias": {
"description": "Unique, descriptive alias for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"name": {
"description": "Descriptive name for this option",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"description": {
"description": "Longer description used to describe what this option is used for",
"type": "string",
"maxLength": 1500
},
"gatewayGroups": {
"description": "List of gateway groups this option should be published to",
"type": "array",
"uniqueItems": true,
"items": {
"type": "string"
}
},
"hidden": {
"description": "Indicates if this option is visible in the catalog (draft)",
"type": "boolean"
},
"allowSubscriptions": {
"description": "Indicates if this option is allowing new subscriptions",
"type": "boolean"
},
"controls": {
"description": "Controls on this option",
"type": "array",
"items": {
"anyOf": [
{
"type": "object",
"required": [
"id",
"requests",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"approval"
]
},
"requests": {
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"status",
"description",
"contact"
],
"properties": {
"id": {
"description": "Unique Option ID.",
"type": "string"
},
"owner": {
"description": "Option owner.",
"type": "string"
},
"lastUpdated": {
"description": "Unix Epoch timestamp of last update to approval request.",
"type": "integer"
},
"status": {
"description": "The status of this approval request.",
"type": "string",
"enum": [
"pending",
"approved",
"rejected",
"fulfilled"
]
},
"description": {
"description": "Description of why the request was created.",
"type": "string",
"minLength": 1,
"maxLength": 1500
},
"contact": {
"description": "Contact details of the person making the request.",
"type": "string",
"minLength": 1,
"maxLength": 250
},
"outcome": {
"description": "Description of the outcome of this request.",
"type": "string",
"maxLength": 250
},
"subscriptionId": {
"description": "The id of the subscription associated with this request.",
"type": "string",
"maxLength": 250
}
}
}
}
}
},
{
"allOf": [
{
"type": "object",
"required": [
"id",
"redactions",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"redaction"
]
},
"redactions": {
"type": "array",
"items": {
"anyOf": [
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceString"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "string",
"maxLength": 200
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"replaceWith",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"replaceIntegral",
"replaceDouble"
]
},
"replaceWith": {
"description": "The value to replace with",
"type": "number"
}
}
}
]
},
{
"allOf": [
{
"type": "object",
"required": [
"path"
],
"properties": {
"path": {
"description": "The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)",
"type": "string",
"maxLength": 200,
"minLength": 2
}
}
},
{
"type": "object",
"required": [
"algorithm",
"type"
],
"properties": {
"type": {
"description": "Type of redaction.",
"enum": [
"hash"
]
},
"algorithm": {
"type": "string",
"description": "Algorithm to use for hashing the current value",
"enum": [
"SHA-256",
"SHA-512"
]
}
}
}
]
}
],
"discriminator": {
"propertyName": "type"
}
}
}
}
}
]
},
{
"type": "object",
"required": [
"id",
"schema",
"type"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"schema-filtering"
]
},
"schema": {
"type": "object",
"required": [
"filtered"
],
"properties": {
"filtered": {
"description": "If true, any schema associated with the Event Source will be used to filter records sent to applications",
"type": "boolean"
}
}
}
}
},
{
"type": "object",
"required": [
"type",
"id"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"quota"
]
}
},
"anyOf": [
{
"type": "object",
"required": [
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
},
{
"type": "object",
"required": [
"messagesPerSecond",
"megabytesPerSecond"
],
"properties": {
"megabytesPerSecond": {
"description": "Upper limit to megabytes per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
},
"messagesPerSecond": {
"description": "Upper limit to messages per second produced/consumed",
"type": "number",
"minimum": 1,
"maximum": 2147483647
}
}
}
]
},
{
"type": "object",
"required": [
"type",
"id",
"identificationType",
"subjectCommonName"
],
"properties": {
"id": {
"description": "Unique Control ID.",
"type": "string"
},
"type": {
"type": "string",
"enum": [
"mtls"
]
},
"identificationType": {
"description": "The type of Identification users will use to distinguish between Subscriptions.",
"type": "string",
"enum": [
"MTLS",
"SASL"
]
},
"identificationSubjectFields": {
"description": "Certificate Subject fields to identify users by if using MTLS identificationType.",
"type": "array",
"items": {
"type": "string",
"enum": [
"subjectCommonName",
"subjectOrganization",
"subjectCountry",
"subjectStateOrProvince",
"subjectLocality"
]
}
},
"subjectCommonName": {
"description": "Subject Common Name to match on.",
"type": "string",
"maxLength": 200
},
"subjectOrganization": {
"description": "Subject Organization to match on.",
"type": "string",
"maxLength": 200
},
"subjectCountry": {
"description": "Subject Country to match on.",
"type": "string",
"maxLength": 200
},
"subjectStateOrProvince": {
"description": "Subject Region to match on.",
"type": "string",
"maxLength": 200
},
"subjectLocality": {
"description": "Subject Locality to match on.",
"type": "string",
"maxLength": 200
},
"approvedCipherSuites": {
"description": "Cipher Suites that are approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"disapprovedCipherSuites": {
"description": "Cipher Suites that are not approved for use.",
"type": "array",
"items": {
"type": "string"
}
},
"notValidBefore": {
"description": "Certificate not valid before time.",
"type": "integer"
},
"notValidAfter": {
"description": "Certificate not valid after time.",
"type": "integer"
},
"trustPem": {
"description": "Certificate Authority in PEM format",
"type": "string"
}
}
}
],
"discriminator": {
"propertyName": "type"
}
}
},
"gatewaysPublishedTo": {
"description": "List of gateways that this option has been published to.",
"type": "array",
"items": {
"type": "object",
"required": [
"id",
"owner",
"organization",
"gatewayId",
"group",
"organizations",
"servedOrganizations",
"endpoints",
"lastContact"
],
"additionalProperties": false,
"properties": {
"id": {
"description": "Unique Event Gateway ID",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"owner": {
"description": "Owner of the Event Gateway.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"organization": {
"description": "Organization this Event Gateway belongs to.",
"type": "string"
},
"gatewayId": {
"description": "Unique Event Gateway ID within this group.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"group": {
"description": "Event Gateway group name.",
"type": "string",
"minLength": 1,
"maxLength": 100
},
"organizations": {
"description": "Organizations this Event Gateway serves",
"type": "array",
"deprecated": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 100
}
},
"servedOrganizations": {
"description": "Organizations this Event Gateway serves",
"type": "array",
"items": {
"type": "string",
"minLength": 1,
"maxLength": 100
}
},
"contact": {
"description": "The contact information for this Event Gateway",
"type": "string",
"minLength": 1,
"maxLength": 200
},
"lastContact": {
"description": "Epoch time in ms of the last contact from this gateway.",
"type": "integer",
"minimum": 0
},
"endpoints": {
"description": "Endpoints that the gateway is listening on.",
"type": "array",
"items": {
"type": "object",
"required": [
"host",
"port"
],
"properties": {
"host": {
"description": "Kafka server host name.",
"type": "string"
},
"port": {
"description": "Kafka server port.",
"type": "integer"
},
"ssl": {
"description": "Connect over SSL.",
"type": "boolean",
"default": false
},
"certificates": {
"description": "Certificates or CAs to trust when connecting to the server via SSL.",
"type": "array",
"uniqueItems": true,
"items": {
"type": "object",
"description": "X509 certificate presented by an endpoint",
"required": [
"pem"
],
"properties": {
"pem": {
"description": "Certificate in PEM format",
"type": "string"
},
"subject": {
"description": "Subject name of the certificate",
"type": "string"
},
"sans": {
"description": "A list of subject alternative names of the certificate",
"type": "array",
"items": {
"type": "string"
}
},
"issuer": {
"description": "Issuer of the certificate",
"type": "string"
},
"expiry": {
"description": "Expiration date of the certificate in epoch millis",
"type": "integer"
}
}
}
}
}
}
},
"version": {
"type": "string",
"description": "Version of the gateway",
"minLength": 1,
"maxLength": 20
},
"productVersion": {
"type": "string",
"description": "EEM product version.",
"minLength": 1,
"maxLength": 100
},
"features": {
"type": "array",
"description": "Feature set in use by gateway",
"uniqueItems": true,
"items": {
"type": "string",
"minLength": 1,
"maxLength": 20
}
},
"deploymentMode": {
"type": "string",
"description": "Type of gateway deployment"
},
"capabilities": {
"type": "object",
"additionalProperties": true,
"description": "Freeform Description of what capabilities the gateway has"
}
}
}
}
}
}
}
}
}

Responses

Status Meaning Description Schema
200 OK Event Endpoint successfully retrieved. Inline
401 Unauthorized Not authorised, successful login required None
403 Forbidden Access denied for this user and/or role None
404 Not Found This Event Endpoint does not exist None
500 Internal Server Error Internal error None

Response Schema

Status Code 200

Name Type Required Restrictions Description
» id string true none Unique ID of related EventSource.
» owner string true none Owner of related EventSource.
» organization string true none Organization the related EventSource belongs to.
» clusterId string true none ID for the cluster that contains the connection details for this Event Source.
» type string true none Type of Event Source
» encoding string true none The encoding of the data on this Event Source
» name string true none Event Source name
» contact string true none Who to contact for more information about this Event Source.
» description string false none A description for this Event Source
» topic object false none none
»» name string true none Actual topic name in the cluster.
»» partitions number false none The number of partitions for this topic.
»» replicas number false none The number of replicas for this topic.
» schema object false none none
»» type string false none Type of Schema from the list of valid types
»» content string false none Contents of the Schema
»» description string false none Description of the data available on the Event Source
» tags [string] false none List of tags associated with this Event Source
» sampleMessages [string] false none none
» capabilities [string] true none none
» options [object] true none none
»» id string true none Unique Option ID.
»» owner string true none Option owner.
»» organization string true none Organization this Option belongs to.
»» eventSourceId string true none Event source that this option belongs to
»» alias string true none Unique, descriptive alias for this option
»» name string true none Descriptive name for this option
»» description string false none Longer description used to describe what this option is used for
»» gatewayGroups [string] true none List of gateway groups this option should be published to
»» hidden boolean true none Indicates if this option is visible in the catalog (draft)
»» allowSubscriptions boolean true none Indicates if this option is allowing new subscriptions
»» controls [anyOf] true none Controls on this option

anyOf

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» requests [object] true none none
»»»»» id string true none Unique Option ID.
»»»»» owner string true none Option owner.
»»»»» lastUpdated integer false none Unix Epoch timestamp of last update to approval request.
»»»»» status string true none The status of this approval request.
»»»»» description string true none Description of why the request was created.
»»»»» contact string true none Contact details of the person making the request.
»»»»» outcome string false none Description of the outcome of this request.
»»»»» subscriptionId string false none The id of the subscription associated with this request.

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» redactions [anyOf] true none none

anyOf

Name Type Required Restrictions Description
»»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» type string true none Type of redaction.
»»»»»»» replaceWith string true none The value to replace with

or

Name Type Required Restrictions Description
»»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» type any true none Type of redaction.
»»»»»»» replaceWith number true none The value to replace with

or

Name Type Required Restrictions Description
»»»»» anonymous any false none none

allOf

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» path string true none The JSON path specifying the field to redact. JSON path is currently restricted to just field names (no arrays or functions)

and

Name Type Required Restrictions Description
»»»»»» anonymous object false none none
»»»»»»» type string true none Type of redaction.
»»»»»»» algorithm string true none Algorithm to use for hashing the current value

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» schema object true none none
»»»»» filtered boolean true none If true, any schema associated with the Event Source will be used to filter records sent to applications

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none

anyOf

Name Type Required Restrictions Description
»»»» anonymous object false none none
»»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»»» messagesPerSecond number false none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»»» anonymous object false none none
»»»»» megabytesPerSecond number false none Upper limit to megabytes per second produced/consumed
»»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»»» anonymous object false none none
»»»»» megabytesPerSecond number true none Upper limit to megabytes per second produced/consumed
»»»»» messagesPerSecond number true none Upper limit to messages per second produced/consumed

or

Name Type Required Restrictions Description
»»» anonymous object false none none
»»»» id string true none Unique Control ID.
»»»» type string true none none
»»»» identificationType string true none The type of Identification users will use to distinguish between Subscriptions.
»»»» identificationSubjectFields [string] false none Certificate Subject fields to identify users by if using MTLS identificationType.
»»»» subjectCommonName string true none Subject Common Name to match on.
»»»» subjectOrganization string false none Subject Organization to match on.
»»»» subjectCountry string false none Subject Country to match on.
»»»» subjectStateOrProvince string false none Subject Region to match on.
»»»» subjectLocality string false none Subject Locality to match on.
»»»» approvedCipherSuites [string] false none Cipher Suites that are approved for use.
»»»» disapprovedCipherSuites [string] false none Cipher Suites that are not approved for use.
»»»» notValidBefore integer false none Certificate not valid before time.
»»»» notValidAfter integer false none Certificate not valid after time.
»»»» trustPem string false none Certificate Authority in PEM format

continued

Name Type Required Restrictions Description
»» gatewaysPublishedTo [object] true none List of gateways that this option has been published to.
»»» id string true none Unique Event Gateway ID
»»» owner string true none Owner of the Event Gateway.
»»» organization string true none Organization this Event Gateway belongs to.
»»» gatewayId string true none Unique Event Gateway ID within this group.
»»» group string true none Event Gateway group name.
»»» organizations [string] true none Organizations this Event Gateway serves
»»» servedOrganizations [string] true none Organizations this Event Gateway serves
»»» contact string false none The contact information for this Event Gateway
»»» lastContact integer true none Epoch time in ms of the last contact from this gateway.
»»» endpoints [object] true none Endpoints that the gateway is listening on.
»»»» host string true none Kafka server host name.
»»»» port integer true none Kafka server port.
»»»» ssl boolean false none Connect over SSL.
»»»» certificates [object] false none Certificates or CAs to trust when connecting to the server via SSL.
»»»»» pem string true none Certificate in PEM format
»»»»» subject string false none Subject name of the certificate
»»»»» sans [string] false none A list of subject alternative names of the certificate
»»»»» issuer string false none Issuer of the certificate
»»»»» expiry integer false none Expiration date of the certificate in epoch millis
»»» version string false none Version of the gateway
»»» productVersion string false none EEM product version.
»»» features [string] false none Feature set in use by gateway
»»» deploymentMode string false none Type of gateway deployment
»»» capabilities object false none Freeform Description of what capabilities the gateway has

Enumerated Values

Property Value
type kafka
encoding unknown
encoding text/plain
encoding application/octet-stream
encoding application/json
encoding avro/binary
encoding avro/json
type avro
type json
type unknown
type approval
status pending
status approved
status rejected
status fulfilled
type redaction
type replaceString
type replaceIntegral
type replaceDouble
type hash
algorithm SHA-256
algorithm SHA-512
type schema-filtering
type quota
type mtls
identificationType MTLS
identificationType SASL