Published REST Operation

Last modified: August 20, 2024

Introduction

A published REST operation is part of a published REST resource and defines an endpoint that a client can call to GET, PUT, POST, PATCH, or DELETE items from the resource.

In the Published REST Service document, you can add items to be included in the service as Resources:

Published REST Service

Operation Definition

When you Add or Edit a resource, you can define the resource in the Operation definition dialog box for the selected item as follows:

REST Operation

General

In the General tab, you can enter the operation details as described in this section.

Method

The method specifies the type of operation that is performed by the microflow. From the drop-down menu, you can select one of the following:

  • GET – retrieve the entry or entries at the specified location
  • PUT – replace the entry or entries at the specified location, or create them if they do not exist
  • POST – create an entry in the collection at the specified location
  • PATCH – update (part of) the entry at the specified location
  • DELETE – delete the entry or entries at the specified location
  • HEAD - retrieve information about the entry or entries at the specified location; this is identical to GET, except that a message body is not returned
  • OPTIONS - return information about the available communication options

Operation Path

The location where the operation can be reached starts with the URL of the resource, and the Operation path specifies the remainder of the path for the operation. You can leave it empty to use the location of the resource.

You can use path parameters to capture part of the location as a microflow parameter or as a parameter to the import mapping. Specify path parameters in the operation path between { and }. The value that is in the URL for the path parameter will be passed to the microflow or the import mapping.

The Method and Operation path define the operation that is executed for a given request URL as described in Published Rest Routing.

Example Location

The Example Location gives an example of a URL on which the operation can be reached.

Microflow

An operation can have the following parameters:

  • Query parameters, which are at the end of the URL in the form of ?name1=value1&name2=value2

  • Path parameters, which form part of the path of the URL

  • A body parameter (optional), which is in the body of the request to the operation

  • Header parameters, which come from the HTTP headers of the request

  • A form parameter (optional), which is a part of the body of a multipart form request

A microflow for an operation takes these operation parameters as input.

A microflow parameter that has the List or Object type indicates a body parameter. You can specify an import mapping to convert the incoming JSON or XML. A parameter of the FileDocument type (or that inherits from a FileDocument) is special; it can also be used for form parameters, and an import mapping is not needed.

An operation microflow may also take an HttpRequest parameter. You can add this parameter if you want to inspect the requested URL and headers.

To set the status code and headers, add an HttpResponse object parameter and set the attributes of that object, or return an HttpResponse. Setting a custom reason phrase on the HttpResponse object has no effect.

The result of the microflow is the result of the operation and can include the following:

  1. Return a file document – have the microflow return a file document when you want to return a file stream (such as a PDF or image). The following HTTP response headers are especially relevant here: a. Use the Content-Type header to specify the file’s MIME type. b. Use the Content-Disposition header to specify the file name and to indicate whether the file should be downloaded as an attachment. c. Use additional HTTP response headers to communicate other information about the file. See the Setting Up the MIME Type section of Publish and Consume Images and Files with REST for more information.

  2. Return a list of an object – specify an export mapping to convert it to XML or JSON.

  3. Return a primitive – when the microflow returns a value (for example, a string, integer, or Boolean), the response to the operation will be that value.

  4. Return an HttpResponse – in the HttpResponse, you can set the status code and content (as a string). You can fill the content with, for example, the result of a mapping or a string from another source. You can also add headers to the response.

If the microflow throws an unhandled exception, the response is 500: Internal server error.

When security is enabled, the microflow needs to have at least one role configured to be accessible.

Deprecated

Check this box to mark the operation as deprecated in the service’s OpenApi (Swagger) documentation page as described in the Documentation section of Published REST services. This informs clients not to use it anymore.

Parameters

You can Add, Update, or Delete the parameters of the operation, which is described in Operation Parameters for Published REST.

Import Mapping

For a body parameter, you can select an import mapping that converts the body of the request into an object. All object and list parameters except file documents must have an import mapping selected.

To select an import mapping, double-click the parameter or click Edit in the grid after you select the parameter. When selecting the import mapping, you can also choose the commit behavior of the mapping: you can choose to either commit, commit without events, or not commit imported objects.

You can select an import mapping that takes no parameter, or an import mapping that takes a primitive parameter (for example, string, or integer). If you select an import mapping with a primitive parameter, you need to have exactly one path parameter with the same type. That path parameter will be passed to the import mapping.

You can indicate what should happen If no object was found when the import mapping has checked the box Decide this at the place where the mapping gets used.

If you select an import mapping that supports both XML and JSON (for example, a mapping that is based on a message definition), the operation will be able to handle both XML and JSON requests.

Valid requests must contain a Content-Type header. See Recognized media types for a list of media types that are understood by the import mapping. If an unsupported content type is used, the operation will result in a 400 Bad Request response.

The import mapping is also used to generate object schemas for operation responses in OpenAPI (Swagger) documentation page based on JSON Schema.

Response

This defines the response of the operation. You can specify the type of the microflow result and the export mapping applied to it (if any).

Type

This shows the result type of the microflow.

Export Mapping

When the microflow returns an object or a list of objects, you must specify how this result is mapped to JSON or XML. Select an export mapping that takes the result of the microflow as input.

If you select an export mapping that supports both XML and JSON (for example, a mapping that is based on a message definition), the output depends on whether the microflow has a parameter of type System.HttpResponse and adds a Content-Type header to it. The possible scenarios are given below:

  • When the microflow sets the Content-Type header parameter with a media type that is XML, the operation returns XML as seen in the table below.

    Recognized media types

    Media Type Recognized As
    application/xml XML
    text/xml XML
    anything ending with +xml XML
    application/json JSON
    anything ending with +json JSON
  • When the microflow sets the Content-Type header to something else, the operation returns JSON.

  • When the microflow does not set the Content-Type header, the output is determined by inspecting the Accept header in the request. The first media type that is recognized to be XML or JSON (as given in the table above) determines the operation result: the Content-Type is application/xml (when it is XML) or application/json (when it is JSON).

  • When there is no Accept header or the Accept header does not contain a recognizable media type, the operation returns JSON and the Content-Type is application/json.

The export mapping is also used to generate object schemas for operation responses in the OpenAPI (Swagger) documentation page based on the JSON schema.

Public Documentation

In the Public Documentation tab, you can specify the documentation that will be used in the service’s OpenAPI (Swagger) documentation page.

Summary

Provide a short description of what the operation does.

Description

Enter a complete overview of what the operation does. You can use GitHub-flavored markdown syntax to style the text.