restApi
Source processor for exposing REST endpoints. Can be built from an API specification or exposed as a generic endpoint.
By default, an error encountered by the REST endpoint is returned to the client and not processed further by the server. Such errors include malformed JSON or request bodies that don’t validate against the OpenAPI spec.
However, if the forwardMessagePreprocessingErrors
option is enabled, these errors are captured by the flow-server and displayed in the Flow Traces page in Heartbeat. If forwardMessagePreprocessingErrors
is also configured on the flow’s deadLetterStrategy, the error can be forwarded to a dead letter flow, just like errors occurring in the flow pipeline.
Properties
Name | Summary |
---|---|
|
ID of the API specification following the pattern |
|
Whether to configure validation of the REST API response. Response validation is turned off by default. |
|
Optional character encoding to use if the response received after processing in the flow needs to be converted from binary format. Binary decoding defaults to |
|
Whether to treat errors encountered at the rest endpoint as regular message processing errors. Example of such errors can be request parsing and validation failures. When this feature is active (the default), these kinds of errors will be treated just like any other message processing error happening in the flow pipeline. I.e. they will be subject to regular error handing, and reported as failed messages in the monitoring tools. If the feature is deactivated the request will be rejected without any further processing. This property is optional, and |
|
Optional, descriptive name for the processor. |
|
Required identifier of the processor, unique across all processors within the flow. Must be between 3 and 30 characters long; contain only lower and uppercase alphabetical characters (a-z and A-Z), numbers, dashes ("-"), and underscores ("_"); and start with an alphabetical character. In other words, it adheres to the regex pattern |
|
Optional set of custom properties in a simple jdk-format, that are added to the message exchange properties before processing the incoming payload. Any existing properties with the same name will be replaced by properties defined here. |
|
Whether the incoming payload is available for error processing on failure. Defaults to |
Sub-builders
Name | Summary |
---|---|
Strategy for describing how a processor’s message is logged on the server. |
|
Strategy for archiving payloads. |
|
Strategy that customizes the conversion of an incoming payload by a processor (e.g., string to object). Should be used when the processor’s default conversion logic cannot be used. |
Details
Endpoints
There are two ways to define a REST source:
-
Using a schema-based approach (requires passing an
apiSpecId
). -
Using generic behavior (when an
apiSpecId
isn’t provided).
REST resources are exposed as endpoints under /{ownerId}/rs/{flowId}
.
Both definition options support flow disablement through the management dashboard. Disabled flows will not process messages and will return a status of 503 (Service Unavailable) as long as they are disabled. Even though a flow is disabled, messages will still be pre-processed for validation.
Exchange Properties
There is a standard set of message exchange properties that will be associated with each message emitted from a REST source. These include the following:
Exchange Property | Description |
---|---|
|
The protocol of the request (e.g., |
|
The HTTP request method (e.g., |
|
Prefix for request headers (e.g., A |
|
Prefix for query parameters (e.g., A |
|
Prefix for path parameters. Values depend on which mode was used to create the REST source. |
|
Original URI that was used in the endpoint. |
|
Shorthand property specifically for the |
|
Entity size (in bytes), if the size is known. The size cannot be determined if chunked transfer encoding is used. |
If there are duplicate headers or query parameters (e.g., ?k1=v1&k1=v2 ), both values will be available.
A map processor, for instance, would have access to them in the #input.messageExchangeProperties array, where the corresponding array elements have the same name of http.query.k1 .
|
The following exchange properties can also be set at any point in the flow to affect the response headers:
Exchange Property | Description |
---|---|
|
The response status. Value must be an integer between 100 and 599. If this header is not set, a default value will be used. Otherwise, 500 will be returned and an error logged. |
|
Properties prefixed with |
Schema-Based Model
This is the recommended approach to create REST sources. It exposes endpoints that are defined in an API specification. Currently, only the following schema type is supported:
Type | File Extensions |
---|---|
json, yml, yaml |
The path for a specific operation is /{ownerId}/rs/{flowId}/{path from OpenAPI spec}
.
For example, if there is a defined path for /user
, then it will be visible under /{ownerId}/rs/{flowId}/user
.
The selected operation will be used for both request and response validations.
In order to uniquely identify which endpoint was used, the http.operationId
exchange property is added.
If operationId
is present in the OpenAPI spec, then that value is used.
If not, the default generated value uses the pattern path_template-HTTPmethod
.
For example, the path template {param}/operation
for a GET request will be translated to param_operation-GET
.
A templated path is also used to generate the http.path
exchange properties.
For example, the path template {p1}/op/{p2}
and request path v1/op/v2
would create the following properties:
Exchange Property | Value |
---|---|
|
|
|
|
Schema-based endpoints have the following restrictions:
All non-2xx responses defined in the OpenAPI spec are not processed and will be used only for documentation purposes.
Generic Model
The generic model is designed to handle only basic cases where the default behavior is sufficient. There is no schema defined. Therefore, there is no input or output validation.
All HTTP operations are supported.
If the request contains an entity, it will be deserialized like this:
-
If the request content type is not set, or if it indicates a JSON type (e.g.
application/json
), the entity will be deserialized to a JSON compliant object or array. -
If the request content type is set to
application/x-www-form-urlencoded
, the entity is deserialized to a JSON compliant object where the form values are available as a list to accommodate possible duplicate keys. For example:{ "key1": ["value1", "value2"], "key2": ["value"] }
-
If the request content type is set to another text based type, the entity is converted to a string. This includes content types
application/xml
,application/javascript
, types that start withtext/
, and those that end with+xml
. -
Otherwise, the content type is assumed to be binary, and the entity is processed as a binary.
By default, the response content type is set to application/json
.
The flow can override this by setting a response header for a different content type (e.g., responseHeader.Content-Type=application/xml;charset=UTF-8
).
The path is divided into indexed segments.
For example, the path one/two/three
will be converted into the following exchange properties:
Exchange Property | Value |
---|---|
|
|
|
|
|
|
It’s up to the flow developer to identity which endpoint was executed based on the http.*
exchange properties.
Responses
Validation of the response is turned off by default.
If the REST source is configured with response validation, then the following apply:
-
Schema-based sources will validate the response code, headers, and body.
-
Generic sources will ignore the validation config.
The following algorithm is used to calculate the response status code:
-
Use the value from the
httpResponseCode
exchange property. -
Find the first 2xx code defined in the OpenAPI spec, if schema-based.
-
Use the default behavior:
-
201 for
POST
operations. -
200 for all other operations.
-
Validation of the response when the response code is not defined in an OpenAPI spec will be done only when the default code is defined.
In other cases, the response will be assumed to be correct.
|