REST Direct Delivery Method

The REST Direct delivery method differs from the standard REST delivery method in that the data is delivered directly to the REST service and no call-back URL is required.

This delivery option is only available in OIEPs and if the delivery fails, the OIEP will be disabled. There is no special resilience handling.

To use mTLS or TLS with this type of endpoint, refer to the Mutual Transport Layer Security topic here.

Prerequisites

Changes to the properties file, outlined below, are implemented when the server is restarted.

  1. The REST Direct delivery method reads the outgoing file into memory before sending. To handle the size of the outgoing file and prevent time-outs and rejections you must scale the heap size.

  2. Prior to configuration, clicking the URL dropdown parameter displays the required property name. Provide a selection for the dropdown parameter via the sharedconfig.properties file on the STEP application server using the case-sensitive RestDirectDeliveryURL property. If necessary, use a comma to separate multiple URLs. The image below shows the result of using the following example for a property entry involving two systems:

    RestDirectDeliveryURL = 1=http://myfirstendpoint, 2=http://mysecondendpoint

Configuration

For information on a parameter, hover over the parameter field to display help text.

  1. For Select Delivery Method, choose REST Direct.

  2. In URL, select the URL that points to the REST endpoint where the delivered data should be received.

  3. In Proxy Config, select the desired HTTP proxy configuration if the delivery connection must first pass through a proxy server with its own login requirement.

  4. In the HTTP Method option, use the dropdown to select a POST, PUT, or PATCH method.

    If required, in the Query Parameters field add any query parameters that are required for a successful REST transaction. Click on the Add parameter link to add the first query parameter. Once a query parameter is added, click the ellipsis button () to add additional query parameters. To remove query parameters, click on the 'X.'

  5. For Headers, click the Add Parameter link and add a key and a value. This is part of the HTTP network protocol.

  6. On the Add parameter dialog, click the OK button and the Header is displayed in the field. If multiple headers are needed, use the Add Parameter link to add each additional key and value pair.

    Note: Once a header is displayed, click the ellipsis button () to edit it or the X button to remove it.

    For more information about headers, refer to the 'Additional Request Information' section at the end of this topic.

  7. In Footer, add data required for the recipient to verify that the full message was received. This is part of the HTTP network protocol but not required.

    The footer can be used to mark the end of a multi-part REST call (that is a REST call containing the payload split in more packages). The footer could also contain a checksum that the receiver can use to detect if the payload in a multi-part message has been changed by the middleware.

  8. In Zip Content, specify whether to zip the contents before upload.

  9. On the Edit Delivery Configuration dialog, click the OK button to save the delivery method.

Note: For more information regarding HTTP proxy configurations, refer to the topic HTTP Proxy Configurations in the Data Exchange documentation here.

Authentication

The REST Direct delivery plugin supports both basic authentication and token-based authentication.

Basic Authentication

For basic authentication, enter the username and password and specify whether or not the plugin should use preemptive authentication. With preemptive authentication enabled, the basic authentication value for the Authorization header will be sent with the first request to the external service, instead of only sending the value after having received a basic authentication challenge from the service.

Token-Based Authentication

With the token-based authentication option, the responsibility for producing any required request headers is delegated to a business function. The business function must be configured to not expect any input and must produce a Map<String, String>. Each map entry is a header that will be sent with the request to the service.

The following screenshot shows the editor for a compatible business function that retrieves a token using the OAuth 2.0 client credentials flow and passes the token back to the delivery plugin as a value for the Authorization header.

The REST Direct delivery plugin will automatically call the business function when a new token is required.

Note: It is strongly discouraged to configure both basic authentication and token-based authentication. This configuration combination is not supported.

Additional Request Information

By default, the REST Direct delivery option sends multipart/form-data POST requests with the exported file available in the part named 'file' with Content-Type application/octet-stream. The example below shows the properties for such a request:

Headers

Accept-Encoding = gzip,deflate

Connection = close

Content-Length = 1354

Content-Type = multipart/form-data; boundary=JN_qruUpDaHqm9BgW_b4-adAHDftQbjuvDI

Body (Metadata)

Content-Disposition: form-data; name="file"; filename="result.zip"

Content-Type: application/octet-stream

Via the UI it is possible to change the HTTP method and also to overwrite the Content-Type header. For instance, this header could be set to 'application/xml' for a STEPXML export (unzipped) thereby overwriting the default 'multipart/form-data' value making the request properties be:

Headers

Accept-Encoding: gzip,deflate

Connection: close

Content-Length: 1354

Content-Type: application/xml

Body <The exported XML>Additional Request Information

By default, the REST Direct delivery option sends multipart/form-data POST requests with the exported file available in the part named 'file' with Content-Type application/octet-stream. The example below shows the properties for such a request:

Headers

Accept-Encoding = gzip,deflate

Connection = close

Content-Length = 1354

Content-Type = multipart/form-data; boundary=JN_qruUpDaHqm9BgW_b4-adAHDftQbjuvDI

Body (Metadata)

Content-Disposition: form-data; name="file"; filename="result.zip"

Content-Type: application/octet-stream

Via the UI it is possible to change the HTTP method and also to overwrite the Content-Type header. For instance, this header could be set to 'application/xml' for a STEPXML export (unzipped) thereby overwriting the default 'multipart/form-data' value making the request properties be:

Headers

Accept-Encoding: gzip,deflate

Connection: close

Content-Length: 1354

Content-Type: application/xml

Body <The exported XML>