REST

If you have access to technical personnel (software developers) and are looking to tightly integrate with our platform, then this Connector option is worth a look.

 

The REST Connector will automatically send form entry data in XML or JSON format to a web service address that you specify.

 

This allows you to integrate with us on an event level - i.e. whenever a new Form entry is received by us, you will receive the data on the nominal REST verb - e.g. POST.

 

Your web service should implement the API that we specify in order to understand the data we send by default.

Technical staff should see our Form Entries API documentation (found in the Integration section of our help site).

 

Alternatively, you can define your own custom request body to match into existing APIs endpoints that you wish to send form entry data to.

 

Table of Contents

Adding the Connector
Configuring the Connector
Customising the Request Body
Setting up a Dynamic Request URL
Adding Custom HTTP Headers
Adding a Run Condition
Adding a REST Step
Troubleshooting

 


Adding the Connector

 

The Connectors page can be accessed from the Screens listing if you mouse over the Form row in question or from your Form Design or Settings page.

 

Screens Listing

 

Form Design

 

 

Once you are in the Connectors page, setting up a REST Connector is easy:

 

1. Hover over the "Add Connector" button, top right corner, to see all available Connectors.

Click the REST option.

 

 

2. This will refresh the page and display your Connector, ready for configuration.

Note that at this stage nothing has been saved - you must click the Save button to save your Connector after you've finished setting it up.

 


Configuring the Connector

 

  1. HTTP Action
  2. Destination URL
  3. Body

 

1. Specify the desired request format, JSON or XML, and the desired REST verb (usually POST)

 

2. You need to specify the destination URL to which our platform will POST data.

You can either enter an address directly into the given field, or you can "Use Global Forms REST URL" if set up on your organisation setup page.

 

 

The Global Forms REST URL option allows you to have a single global URL that can be reused for multiple Forms.

This option is configured in the Organisation Setup page (Menu>Organisation Setup>Integration Settings).

 

Organisation Setup

Specify a global REST endpoint for use by REST Form connectors

 

Form Connector

Use the {{GLOBAL}} placeholder as the Destination URL.

 

3. If you are sending form entry data into an existing external API service, then you will need to customise the request body to match this.

Hit the "customise body" link to reveal a text area that you can use to define the request format, injecting your form fields using the same {{ }} syntax you would use to create a Data Template.

This opens up the ability to plug into almost any external service that exposes a REST API.  

Simply read up on their API documentation about the required data structure and submission endpoints, then plug those into your REST connector URL and body.

 

4. At this stage, your Connector is ready to go.

Hit the Save button to save your changes and activate the Connector.

 


Customising the Request Body

 

The "customise body" option allows you to set up your own custom JSON or XML data payloads and inject form answer values using our standard {{fieldname}} syntax.

You can even cater for repeating data in your body by using our {{!REPEATSTART}} {{!REPEATEND}} syntax normally reserved for data templates.

 

For example, you might have a JSON body that repeats timesheet rows like so:

{"timeEntries":[{{!REPEATSTART}}{"entryDate":"{{entryDate}}","startTime":""{{startTime}}","finishTime":""{{finishTime}}","timeTotal":{{timeTotal}},"description":"{{entryDescription}}"},{{!REPEATEND}}],"entryCount":{{hiddenEntryCount}},"headerSummary":"{{headerSummary}}","entrySummary":"{{entrySummary}}"}
Undefined

 


Setting up a Dynamic Request URL

 

You can also inject answer values to dynamically build up the URL that the request will be sent to.

So for example your target URL could look like: 

http://somewhere.com/service/{{myfield}}/contact?option={{myoption}}

 

Click on the hammer next to the Destination URL box.

 

 


Adding Custom HTTP Headers

 

Use the "customise headers" option to add HTTP request headers onto the REST request that is sent out by the platform.

This is useful for external API services that require you to authenticate using Auth headers that contain your username/password combinations.

Header values can be dynamic as well - you can inject form field values using the usual {{myfieldname}} syntax.

 

NOTE: HTTP Headers are NOT a way to send your form field names to the target API.  

Research HTTP Headers to understand what these are and how to use them.

 

 


Adding a Run Condition

 

Sometimes you may have a Connector that you only want to fire in the event that the Form entry has a given answer value.

 

For example, you may have an Audit Form, which has a risk rating question with options like "Low", "Medium" and "High".

If the user answers the risk rating as "High", then you want an email to be sent to a supervisor for followup and action.

 

This is where a Run Condition comes in.

Run Conditions are defined by creating a true/false formula.

The Connector will only run if the formula you define in the Run Condition has a true result.

 

So in the example above, the Run Condition formula would be something like:

{{riskRating}} = 'High'

 

When you hover over the Run Condition field, you will see a hammer icon appear.

Clicking the hammer will take you into the Formula Builder, which helps you to put together the formula you desire.

 

See the Creating a Formula page to learn more about form formulae.

 

 


Adding a REST Step

 

Sometimes you may have a Connector that requires data from an external web service to be used in the request. This is where our "Add REST Step" option may be of use.

 

The added REST step triggers first, allowing for retrieved data to be used in the request.

 

 

The result from the REST step returned as $response for use in the subsequent request below.

Access properties or lists of elements from JSON responses via the JSONVAL() and JSONLIST() formula functions.

Similarly for XML responses, use XMLVAL() and XMLLIST().

 

e.g. {(JSONVAL($response, 'path.to.property'))}

 


Troubleshooting

 

Timeouts on your REST connector jobs  

You may encounter situations where timeout errors are reported for your REST connector when it runs on a Form entry.
This will be because your REST web service is not responding with a 200 OK status within 10 seconds of our platform sending the REST request.

The 10-second timeout applies purely to the time taken to execute the REST request, deliver the data, and get a response back.
Any PDF file that is sent as part of the request will be first generated prior to commencing the request timeout clock.

Note that we don't send any actual media files captured in a Form entry with REST requests, instead, we send the file names so you can retrieve the files separately via our API.
Thus the only images sent with a REST connector request would be those within a generated PDF file.

Our data center has gigabit connections and transmits very fast. Obviously, your servers should have similarly fast transport links.

If we raised the timeout, the issue for us is that this can create very large backlogs on our connector job queues when the target REST web services have an issue and do not respond. In that scenario, our connector process will sit waiting for the full timeout period hoping for a response. That would be 20, 30, 40 etc seconds that a connector process is doing nothing, when it could be processing the next job.
When this happens at scale (i.e. with thousands of connector jobs) then this can create big backlogs on our connector infrastructure.

At this point, we have no plans to increase the timeout beyond 10 seconds.

If you are regularly hitting the timeout limit, then we recommend you examine your web service and make changes to process incoming requests faster.
A simple way to do this is to simply store the incoming request on a queue/database and respond with a 200 OK immediately.
Then do any time-consuming processing (e.g. database inserts) asynchronously by having a separate process pick up the incomings from the queue/database.

 

 


  • 0 Benutzer fanden dies hilfreich
War diese Antwort hilfreich?

Verwandte Artikel

Twilio Connector

  A Twilio Form Connector helps you send and manage short messages programmatically. Our...

SQL Connector

A Premium connector for direct connection to Microsoft SQL Server.    Our platform...

Snowflake Connector

    A Premium connector for direct connection to a Snowflake database.    Our platform...

SharePoint List Connector

The SharePoint List Connector extends our SharePoint integration to allow the manipulation of...

Salesforce

A Premium connector for direct connection to Salesforce. Our platform enables you to quickly...