Exact Online Read

In this article

Overview

Exact Online is a Read-type Snap that reads and retrieves data objects from the Exact Online instance.

Prerequisites

A valid OAuth 2.0 account that supports Exact Online instance, with the appropriate access permissions. See Exact Online OAuth 2.0 Account.

Support for Ultra Pipelines  

Works in Ultra Pipelines. 

Limitations and Known Issues

None.

Snap Views

View Type

View Format

Number of Views

Examples of Upstream and Downstream Snaps

Description

View Type

View Format

Number of Views

Examples of Upstream and Downstream Snaps

Description

Input 

Document

  • Min: 0

  • Max: 1

  • Mapper Snap

  • Copy Snap

  • JSON Parser

A document with data that indicates the entities to be filtered and retrieved from an Exact Online instance. 

Output

Document

  • Min: 1

  • Max: 1

  • Mapper Snap

  • Copy Snap

  • JSON Formatter

A document containing the entity data retrieved from an Exact Online instance.

Error

Document

  • Min: 1

  • Max: 1

N/A

The error view contains error, reason, resolution and stack trace. For more information, see Handling Errors with an Error Pipeline.

Snap Settings

Field Name

Field Type

Description

Field Name

Field Type

Description

Label*

String

Specify a unique name for the Snap. You can modify this to be more specific, especially if you have more than one of the same Snap in your Pipeline.

Default Value: N/A
Example: Exact Online Read

Version*

Dropdown list

Choose or specify the version of the Exact Online API.

Default Value: v1
Example: v1

Division*

String/Expression/Suggestion

Specify a unique ID of the Exact Online Division (you can retrieve this ID using a REST call, https://start.exactonline.nl/api/v1/current/Me?). Alternatively, click the Suggestion  icon to fetch the list of supported divisions and select a division. 

Default Value: N/A
Example: 1234567

API object*

String/Expression/Suggestion

Specify the API that you want to access in the Exact Online instance. This dropdown list contains supported services available for the Exact Online instance. Alternatively, click the Suggestion  icon to fetch the list of API objects and select an object. 

Default Value: N/A
Example: CRM

Endpoint*

String/Expression/Suggestion

Specify an Exact Online Endpoint to be connected for each of the API objects.

Default Value: N/A
Example: Accounts

Filter records

Use this field set to define the filter criteria for the response result based on the specified parameters. Click to add a new row to define the filter criteria. You can enter only one filter criteria in each row. This field set comprises the following fields:

  • Field name

  • Operation

  • Field value

  • Condition

When you define multiple filters, the final output is generated based on the order that you have defined.

Field name

String

Specify the system parameter ($filter) field for filtering the records in the output.

Operation

String

Choose the comparison operator for the $filter field specified above from this drop-down list. Available options are: 

  • Equals

  • Not Equals

  • Greater than or Equal

  • Greater than

  • Less than or Equal

  • Less than

  • Starts with

  • Ends with

Field value

String

Specify the value with which the above $filter field must be compared. The data types: String, Integer, Boolean, or any other data type depends on the $filter field that you specified for the filter criterion.

Condition

String

Choose a value from this drop-down list to set the correlation between this filter criterion (row) and the next one (row), if being defined at all, to apply the filters for generating the final output. Available options are: 

  • Or: To retrieve records that match either the current criterion or the next criterion.

  • And: To retrieve only records that match both the current criterion and the next criterion.

  • None: To specify that the current and the next criteria can be evaluated independently of each other in retrieving the records.

Output field selection

This field set enables you to select the fields to include in the output. Click to add a new row to define the output field. You can enter only one output field in each row. 

To return all available fields in the output, do not specify any output fields.

 

String

Specify the fields from the result dataset to be populated in the output.

Default Value: N/A
Example: ID, name1, name2

Order by

Use this field set to define the sort order for the records in the output. Click   to define the sort order criteria. Multiple criteria is applied in the same sequence as they are defined. This field set comprises the following fields:

  • Element

  • Order by type

Element

String

Specify the field in the expected output by which the records in the output must be ordered.

Default Value: N/A
Example: name1

Order by type

String

Depending on the field selected above, define whether the rows must be sorted in the ascending order or descending order. Available options are:

  • Ascending

  • Descending

Default Value: Descending
Example: Descending

Function parameter

This field set enables you to define the sort order for the records in the output. 
Only one column name can be specified in each row. Click   to add a new row and define the value accordingly. Multiple parameters are applied in the same sequence as they are defined. This field set comprises the following fields:

  • Field name

  • Field value

Field name

String

Specify the name of functional properties.

Default Value: N/A
Example: searchText

Field value

String

Specify the values of specified functional fields.

Default Value: N/A
Example: test_text

Output fields advanced options

Use this section of Snap Settings to customize the output set: the number of output entries and the index of the starting entry. Available options are:

  • Output entry limit

  • Output entry offset

  • Automatic pagination

  • Inline count

  • Allow empty result

Output entry limit

Integer

Specify the maximum number of entries that Exact Online on-premise instance must return in the output.

Default Value: N/A
Example: 10

Output entry offset

Integer

Specify the record index starting from which the Exact Online on-premise instance must return records in the output. Use this property along with the Output entry limit to retrieve a specific set of entries in the output.

Default Value: N/A
Example: 10

Automatic pagination

Checkbox

Select this checkbox to return the records of all the pages retrieved in the API response. By default, the Exact Online API returns a maximum of 60 records per page. But for the bulk endpoint, a maximum of 1000 records can be returned per page.  If you select this checkbox, all matching records are automatically returned.

Default Value: Selected

Inline count

Checkbox

Select this checkbox to return the total number of records retrieved in the API response. The count number will be added to each document record with a property name of "__count".

Default Value: Deselected

Allow empty result

Checkbox

Select this checkbox to allow empty results on the output views. If you deselect this checkbox, an error is thrown when the output has no records.

Default Value: Selected

Connection details

Use this field set to specify the connectivity parameters: timeout, retry count, and retry interval. This field set contains the following fields:

  • Connection timeout

  • Maximum request attempts

  • Retry Interval

Connection timeout*

Integer

Enter, in seconds, the duration for which Snap must try to establish a connection with the Exact Online instance. If the connection cannot be established within this duration, the Snap times out, writes the event to the log, and waits until the specified RetryInterval before attempting to reconnect.

Default Value: 300
Example: 120

Maximum request attempts*

Integer

Specify an integer value to set the maximum number of reconnection attempts that the Snap must perform, in case of connection failure or timeout.

Default Value: 3
Example: 5

Retry Interval*

Integer

Enter, in seconds, the duration for which the Snap must wait between two reconnection attempts until the number of retries is reached.

Default Value: 1
Example: 10

Snap Execution

String

Select one of the three modes in which the Snap executes. Available options are:

  • Validate & Execute: Performs limited execution of the Snap, and generates a data preview during Pipeline validation. Subsequently, performs full execution of the Snap (unlimited records) during Pipeline runtime.

  • Execute only: Performs full execution of the Snap during Pipeline execution without generating preview data.

  • Disabled: Disables the Snap and all Snaps that are downstream from it.

Default Value: Validate & Execute
Example: Execute Only

Troubleshooting

Error

Reason

Resolution

Error

Reason

Resolution

API object is not existing.

The API object is not found for the Exact Online API.

Search and select an API object from the dropdown list.

The endpoint is not existing.

The Endpoint that you have entered is not found for the selected API object in the server.

Search and select the Endpoint from the dropdown list.

Additional Information

Here is some information to assist you while using the Exact Online Read Snap.

Snap General Behavior

The Exact Online Read Snap supports the following:

  • GET operation to read data from the Exact Online server.

  • OData querying operations: $filter (Filter records), $select (Output field selection), $orderby (Order by), $inlinecount(Inline count),$top (Output entry limit), and $skip (Output entry offset).

  • Connection-failed-retry mechanism.

  • Client-side pagination through $top (Output entry limit) and $skip (Output entry offset) mechanisms. For more information, see Pagination.

  • Server-side pagination for automatically getting all the response records if multiple pages returned.

  • Dynamic loading of API metadata with a Parent-child dependency structure. This means that you can:

    • Select an API object from the API Object field to view only endpoints that are related to the API object and support GET queries (read operations).

    • And then, select an endpoint to view and specify values for only read-compatible parameters related to this entity in  Filter records, Output field selection, Order by and Function parameter fields.

Pagination

Client-side pagination is supported through the use of the $stop (Output entry limit), and $skip (Output entry offset) OData operations.
Examples

Snap Output Setting

Pagination result

Snap Output Setting

Pagination result

Output entry limit: 50

  • Retrieves the first 50 API responses from the server (if more than 50 records are present in the API response).

  • Retrieves all the available API response records from the server (if 50 or fewer records are present in the API response).

Output entry offset: 50

  • Retrieves API responses starting from index 51 from the server (if more than 50 records are present in the API response).

  • Returns empty result (if 50 or fewer records are present in the the API response).

Output entry offset: 50, and  Output entry limit: 50

  • Skips the first 50 records and collects the 51 - 100 records in the API response from the server.

Server-side pagination is applied to the Exact Online API. By default, the Exact Online API returns a maximum of 60 records per page. But for the bulk endpoint, a maximum of 1000 records can be returned per page. To get the total amount of response records after validating or executing, select Automatic pagination checkbox. For example, if you have 100 records of CRM/Accounts endpoint, and if you do not select Automatic pagination, only 60 documents are returned after validating or executing the Pipeline, (you will only get the records from the first page - 60 records by default). If you select this checkbox, you will get 100 documents after validating or executing the Pipeline.

Example

Retrieving Account Data from Exact Online Instance CRM Service

This Pipeline example demonstrates how to retrieve accounts data from the Exact Online instance CRM services and write it into a JSON file. This example assumes you have configured a valid Exact Online Account. See Configuring Exact Online Accounts.

We define the following settings for the Exact Online Read Snap to retrieve Accounts data from the Exact Online instance CRM service it accesses.

  • API object: CRM

  • Endpoint: Accounts

After successful validation, we can view the following output in the Snap’s preview.

We connect the JSON Formatter Snap to the upstream Snap to read and format the output data into standard JSON format.

Next, we connect the File Writer Snap to the JSON Formatter Snap to write the JSON data into a file.

To view the output JSON file, you must SSH to the target directory and open the newly-created JSON file. The preview of the output JSON file can be seen below:

Download this Pipeline.

Downloads

  1. Download and import the Pipeline into SnapLogic.

  2. Configure Snap accounts as applicable.

  3. Provide Pipeline parameters as applicable.

Â