Adding an endpoint with the Post method type
Use the POST method type to send data via an API to a back end.
- Sign in to the Rhythm website as a site editor or tenant administrator.
- Click the Menu button.
- Click the Control Panel tab.
- Click Generic API.
- Click the name of the API.
- Click Add Endpoint.
- In the Incoming URL field, specify the last part of the URL that the generic wrapper uses to identify the endpoint. This value must be unique in the tenant.
- Click the Post method type.
-
Select a content type from the Content-Type drop down list.
Note: The content type is the format used on the ION Body Template field. If no content type is selected, the Content-Type drop down list detects the format of the ION Body Template value. The Content-Type drop down list is only available in the Post method.
-
In the Body Template field, specify
the json code use in the POST call. You can use one or more of these
types:
- Lookup
- Use this replacement type to look up a value from another
API to use in the POST call.
{ "customerID": { "type": "lookup", "call": "/delegate/ecom-api/users/current", "path": "$.activeUserGroup.customerNumber" } }
In the sample code,
/delegate/ecom-api/users/current
is called. In the results, the user ID that was passed from the API wrapper is searched for in theactiveUserGroup
key. The value in thecustomerNumber
key is returned. If the value in thecustomerNumber
key isABC-123
, then the template results in this json:{ "customerID": "ABC-123" }
This table shows the components of the sample json template:Component Description "customerID" The key to use for the result of the json call. "type" The type of replacement. Specify "type":"lookup"
."call" The call to the API that you are using to look up information. The value that you specify is appended to the base URL for your Rhythm server. "path" The json path expression to use to look up a value in the result of the call. Specify an expression that returns one result. - Input
- Use this replacement type to input a value from the data
that was passed from the API wrapper.
{ "itemID": { "type": "input", "path": "$.itemNumber" } }
In the sample code, the data that was passed from the API wrapper is searched for the
itemNumber
key. If the value in theitemNumber
key is12345
, then the template results in this json:{ "itemID": "12345" }
This table shows the components of the sample json template:Component Description "itemID" The key to use for the result of the json call. "type" The type of replacement. Specify "type":"input"
."path" The json path expression to use to look up a value in the data sent in the API wrapper. Specify an expression that returns one result. - Static value
- Use this template to send a specific value in the API call.
{ "color": "blue" }
In the sample code,
blue
is also sent in thecolor
key.
Note: Arrays and objects are accepted in the Body Template. - If you have an XML payload, you can use the ION Body Template field. Specify the XML payload used in the POST call. You can place values dynamically by adding a placeholder inside the ION body template wrapped with curly braces.
-
Declare these values in the Body
Template.
You can use this sample json format:
{"TenantID":{"type":"input","path":"$.TenantID":}}
- Specify the key. Ensure that the name is similar to the one you specified in the ION body
template. For example,
TenantID
. - Specify the
type
andinput
. These values are static. Ensure to add these to the payload when you add a variable. - For the path type, specify a similar value with the variable name. For
example,
$.TenantID
. - To add more variables inside the ION Body Template, you can add the value inside curly braces. Declare the values in the Body Template by adding a comma after the first payload then repeat the steps for declaring values in the Body Template.
Note: XML and json formats are accepted in the ION Body Template. - Specify the key. Ensure that the name is similar to the one you specified in the ION body
template. For example,
-
In the Outgoing Endpoint field,
specify the endpoint. If you included lookup and input types in the body, the
result of the lookup and input is used in the json. For example, presume you
specified this json in the Body
Template field.
{ "customerID": { "type": "lookup", "call": "/delegate/ecom-api/users/current", "path": "$.activeUserGroup.customerNumber" }, "emailAddress": { "type": "lookup", "call": "/delegate/ecom-api/users/current", "path": "$.email" }, "itemID": { "type": "input", "path": "$.itemNumber" }, "color": "blue" }
The lookup and input types are replaced with values, for example:
{ "customerID": "ABC-123", "emailAddress": "user@example.com", "itemID": "12345", "color": "blue" }
- Click Save.