Skip to content

Latest commit

 

History

History
39 lines (26 loc) · 3.2 KB

File metadata and controls

39 lines (26 loc) · 3.2 KB

v4 Message API Endpoints

Overview

{% hint style="warning" %} Enterprise-only

The ability to create APIs with message API endpoints is an Enterprise Edition capability. To learn more about Gravitee Enterprise Edition and what's included in various enterprise packages:

v4 message APIs currently support the following endpoints:

  • Kafka: Enables the Gravitee API Gateway to establish a persistent connection with a Kafka topic as a backend resource or target.
  • MQTT 5: Enables the Gravitee API Gateway to establish a persistent connection with an MQTT topic as a backend resource or target.
  • RabbitMQ: Enables the Gravitee API Gateway to establish a persistent connection with RabbitMQ as a backend resource or target. This will only work if you are using RabbitMQ and the AMQP 0-9-1 protocol. Because this endpoint supports the AMQP 0-9-1 protocol, it may support other event brokers and message queues that communicate over the AMQP 0-9-1 protocol. However, Gravitee does not guarantee or officially support these implementations.
  • Solace: Enables the Gravitee API Gateway to establish a persistent connection with Solace as a backend resource or target.
  • Mock: Enables the Gateway to simulate responses from a server for testing API implementations.

Configuration and Implementation

To access endpoint configuration:

  1. Select APIs from the left nav
  2. Select your API
  3. Select Endpoints from the inner left nav

The integrations Gravitee uses to enable Kafka, MQTT, RabbitMQ, and Solace endpoints for v4 API definitions rely on the following terminology and functionality:

  • Request-Id: A Universally Unique Identifier (UUID) generated for any new request. This can be overridden using X-Gravitee-Request-Idas a Header or Query parameter.
  • Transaction-Id: A UUID generated for any new request. This can be overridden using X-Gravitee-Transaction-Idas a Header or Query parameter.
  • Client-Identifier: Inferred from the subscription attached to the request. It is either the subscription ID, or, with a Keyless plan, a hash of the remote address. The Client-Identifier can be provided by the client via the header X-Gravitee-Client-Identifier. In this case, the value used by Gravitee will be the original inferred value suffixed with the provided overridden value.

Click on the tiles below for specific configuration and implementation details.

Kafkakafka.md
MQTT5mqtt5.md
Solacesolace.md
RabbitMQrabbitmq.md
Mockmock.md