Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Snap type:

...

Write

 

...

Description:

...

This Snap provides the functionality to execute the HTTP Delete method to a REST API service endpoint to delete business object resources.

 

...

None

 

...

  • Ultra pipelines: Supported for use in Ultra Pipelines if a timeout is specified.
  • Spark mode: Not supported in Spark mode.

 

...

This Snap uses account references created on the Accounts page of SnapLogic Manager to handle access to this endpoint. See REST Account for information on setting up this type of account.

 

The Snap supports an optional REST Basic Auth Account or REST Oauth2 Account. In the case of using an REST OAuth2 Account instance, one can access the token of the account through $account.access_token explicitly. The property then needs to be marked as an expression. An example URL for LinkedIn is: "https://api.linkedin.com/v1/people/~?oauth2_access_token=" + $account.access_token

 

...

In this article

Table of Contents
maxLevel2
absoluteUrltrue

Overview

Multiexcerpt include macro
nameKI_use_HTTP_client_instead
templateData[]
pageREST Snap Pack
addpanelfalse

You can use the REST Delete Snap to delete business object resources using a REST API call.

Image Added

Prerequisites

None.

Supported Features

Works in Ultra Tasks. We recommend that you set the batch size to 1.

Limitations and Known Issues

None.

Snap Input and Output

Input/OutputType of ViewNumber of ViewsExamples of Upstream and Downstream SnapsDescription
Input Document
  • Min: 0
  • Max: 1
  • REST Get
  • Mapper
  • Script
Each input document contains the ID of the object to be deleted at the REST API service endpoint.
Output

...

Document
  • Min: 0
  • Max: 1
  • REST Post
  • JSON Formatter
  • Mapper

Each output document contains response data from the REST API service endpoint detailing the status of the request.

...

 

...

Settings

...

Label

Required.

 

...

Service URL
Required.

 

...

Snap Settings

Field NameField TypeDescription
Label*String

Insert excerpt
File Writer
File Writer
nopaneltrue

Default Value: REST Delete
ExampleREST Delete

Service URL*

String/Expression

Specify the service endpoint URL of REST API. You can provide the URL in one of the following ways:

  • As a JavaScript expression in the expression language.

For example: http://coresnapsqa-v4.s3.us-east-2.amazonaws.com/S3Account/'+encodeURIComponent("Special_char_owner_!3)12.json")

  • As a plain string that you should enclose in double quotes ("").

For example: "https://www.example.com/slm/webservice/v2.0/defect/%s".replace("%s", $.

...

widg et.id)

For Snaps using AWS Signature V4 accounts, you can use the canonical name (CNAME) for the URI, so it's not necessary for the URL to end with amazonaws.com or have the region and service provided in it. However, if you are using the CNAME, you must provide it in the AWS Region and Service Name fields in the AWS Signature V4 account.

The

...

hostname in the CNAME must be equal to the bucket name.

For example:
Previous URI: https://jsmith-bucket.nia3.snaplogic.net.s3.us-west-1.amazonaws.com/HttpClientTest/test1

New URI with CNAME: https://jsmith-sltest.nia3.snaplogic.net/HttpClientTest/test1

Here, the bucket name is jsmith-bucket.nia3.snaplogic.net

The Snap finds the value at the JSON path $.widget.id

...

in the input data and

...

replaces "%s" in the Service URL with the value.

...

You

...

can connect

...

File Reader

...

and JSON Parser Snaps upstream of a REST Put Snap and prepare the

...

following JSON file for the File Reader Snap:

...


Note

The Service URL for the REST snap has to be valid. If the Service URL contains any special characters, such as !, =, %21, $, and ^, the Snap throws an exception error. You can escape the special characters (using expression language) using one of the following methods:

We recommend you use the former (encodeURIComponent) method to escape the special characters.

Default Value: N/A
Examplehttps://www.example.com/slm/webservice/v2.0/defect/

...

            

Default value: [None]

 

HTTP entity

...

The JSON path to the HTTP entity data in the input Map data, or leave this property empty if there is no entity data to send to the service URL.
Example$.entity (if the HTTP entity data is the value of the "entity" key at the root of the input Map data)
Default value$ (the HTTP entity data is at the root of the input Map data)  

 

Batch size

...

Defines the batch size of the request. The incoming documents will be accumulated in a list up to the defined batch size before it is submitted to the endpoint. Make sure to only set this if your REST endpoint expects a list.

Default value: None

 

Show all headers

...

%s".replace("%s", $.widget.id)

HTTP entityString/Expression

Multiexcerpt include macro
nameHTTP_entity
pageREST Post

Default Value: N/A
Example$response.entity.id 

Batch sizeString

Multiexcerpt include macro
nameBatch_Size
pageREST Patch

Default Value: N/A
Example50

Show all headersCheckbox


Multiexcerpt macro
nameShow_All_Headers

The REST endpoint may return a response with multiple headers with the same header name.

  • If this property is deselected, only one response header will be shown in the output document.
  • If selected, the response header

...

  • displays all the response header values received as a list of objects.

If any of these objects

...

has a key-value format, it is parsed into

...

the map data.


Default

...

Value:

...

 Deselected
Example: N/A

Trust all certificates

...

Required.

...

Trust all certificates, such as self-signed certificates.

Default value: Not selected

 

...

Follow redirects

Required.

...

When selected, HTTP redirects will be followed.
Example: When selected, if a redirect response (e.g. a 301 or 302 response code) is received, another request to the URL specified in the Location header will be automatically made.
When not selected, another request will not be made and the 301/302 response will show up in the output view.
Default value: Selected

 

Query parameters

...

Lets you define query parameters. This is optional and can either be defined directly in the service URL, as separate parameters or both. 
Example:               

 Query parameter Query parameter value  
 oauth2_access_token $account.access_token

 

...

Key Value
 Content-Type application/json;charset=UTF-8
 User-Agent SnapLogic

Default value: [None]

 

Response entity type

This property allows you to select the response entity type in the output document. The available options include:

...

*Checkbox

Multiexcerpt include macro
nameTrust_All_Certificates
pageREST Post

Default ValueDeselected
Example: N/A

Follow redirects*Checkbox

Multiexcerpt include macro
nameFollow_Redirects
pageREST Post

Default ValueSelected
Example: N/A

Query parameters

Multiexcerpt include macro
nameQuery_Parameters_REST
pageREST Post

Query parameter

String

Specify the name (or key) of the query parameter.

Default Value: N/A
Exampleoauth2_access_token

Query parameter value

String/Expression

Specify the value associated with the query parameter.

Default Value: N/A
Example$account.access_token

HTTP header

Multiexcerpt include macro
nameHTTP_Header
pageREST Post

Key

String

Specify the name that you want to use for the HTTP header.

Default Value: N/A
ExampleUser-Agent

Value

String/Expression

Specify the value that you want to assign to the HTTP header.

Default Value: N/A
ExampleSnapLogic

Response entity typeString

Select one of the following response entity types you want the Snap to display in the output document.:

  • DEFAULT - Select this option to enable the Snap to process the response automatically. The response entity is processed automatically based on the Content-Type header in the response. If the content provided does not parse with the provided Content-Type, the snap will result in an error.
    The following two scenarios describe the Snap’s behavior when using the Process Array checkbox::

    • When you select the Process Array checkbox, the Snap parses JSON or XML and produces a stream of documents at the output view.

    • When you deselect the Process Array checkbox, the Snaps sends the data as it is at the output view.   

  • TEXT - Select this option to enable, the Snap to produce an entity of string type.

  • BINARY -

...

  • Select this option to enable the Snap

...

  • to produce an entity of byte array type.

...

Info

If you select TEXT or BINARY

...

, the Snap

...

does not

...

parse the entity content. If you select DEFAULT

...

, the Snap produces the expected result in most cases, but

...

if it fails to process as expected, you can set the Response entity type to TEXT or BINARY.


Default

...

Value: DEFAULT
Example: 

...

This option lets you specify a timeout value in seconds after which the request gets aborted. 

...

Note
  •  In some cases, the request does not return, such as during network issues. For those a timeout can be configured to allow failing fast. 
  • Every Snap instance can have its own timeout settings.
  • The Snap will execute five retries within a couple of seconds back-off time before it fails.

Maximum request attempts 

Specifies the maximum number of attempts to be made to receive a response. The request is terminated if the attempts do not result in a response. 

Example: 3

Default value: 5

Retry request interval

Specifies the interval (in seconds) between two successive requests. A retry happens only when the previous attempt resulted in an exception. 

Example:  10

Default value: 3

...

This property enables you to execute the Snap during the Save operation so that the output view can produce the preview data.

Default value: Not selected

 

 Examples

Image Removed

 

The REST Delete Snap in the above example pipeline deletes the JIRA issue created and updated in the preceding Snaps in the pipeline.

 

The following JSON data is the input document to the Snap:

Expand to see input data.

 

The following JSON data is the output provided by the Snap:

Expand to see output data. 

 

Pipeline Downloads

...

4.7.0 Patch rest2260

  • Updated the Snap with the field, Follow redirects. 

4.7.0 Patch rest2555

  • Updated the Snap with the field, Show all headers.

4.7.0

  • Updated the Snap with the field, Response entity type (The DEFAULT option under this property allows the backward compatibilityThe addition of the property will not affect the existing production pipelines and allows them to run as before).
  • Updated with the fields,  Maximum request attempts and Retry request interval

4.5.1

  • Input view changed from exactly one view to at most one view; output views changed from exactly one view to at most one view. 

July 2013

...

TEXT

Cookie Policy

Dropdown list


Multiexcerpt macro
nameCookie Policy

Select a Cookie Policy from the following options:

  • Browser Compatibility: This policy is compatible with different servers even if they are not completely standards-compliant. If you are facing issues while parsing cookies, you should try using this policy.

  • Ignore Cookies: This cookie policy ignores all cookies. You should use this policy to prevent HTTP Client from accepting and sending cookies.

  • RFC Strict: This policy uses the set-cookie header

  • RFC Lax: The policy uses set-cookie and set-cookie2 for parsing.

When using a cookie policy, you must select Show All Headers checkbox to view the parsed cookies from the cookie policy specification.

Default Value: Ignore Cookies




Example: RFC Strict


Read timeoutInteger

Multiexcerpt include macro
nameRead_Timeout
pageREST Post

Default Value900
Example1500

Connection timeoutInteger

Multiexcerpt include macro
nameConnection_Timeout
pageREST Post

Default Value30
Example45

Maximum request attemptsInteger

Multiexcerpt include macro
nameMaximum_Request_Attempts
pageREST Post

Default Value5
Example3

Retry request intervalInteger

Specify the time in seconds to wait before retrying the request.

Default Value3
Example10

Normalize URLCheckbox
Insert excerpt
REST Get
REST Get
nopaneltrue
Snap ExecutionString

Multiexcerpt include macro
nameExecution_Detail_Write
pageSOAP Execute

ExampleValidate and Execute

Troubleshooting

ErrorReasonResolution
Batch execution failedThe Pipeline ended before the batch could complete execution due to a connection error.

Verify that the Batch size field is configured to handle the inputs properly. If you are not sure when the input data is available, configure this field as zero to keep the connection always open.

The provided URI is invalidIllegal character in scheme nameVerify the URI and parameters that you provide are syntactically correct.
URL Parse Exception - 403The Service URL path might be containing any of the following special characters: !, =, %, #, $, ^&()_¢äâêîôûñç¡¿ÉÙËǨ°¸ðø©¢¾A+²½µ®§÷¶þ To escape the special characters, use the global function encodeURIComponent on any variables that might contain special characters so that they are encoded properly.
Too many Requests - 429

There are too many requests to REST endpoint.

Wait for the retry to succeed.

Rest related Snaps extract the response header and automatically retry when they encounter status 429.

By default, the retry interval (Retry-After) is specified in the HTTP response header. If no value is available for Retry-After, then the Snap’s Retry Interval value is used.

Example

Creating and Deleting an Account in SnapLogic Using REST Snaps

Prerequisites:

  • A valid account.

This example Pipeline demonstrates how to create an account in SnapLogic and delete it using REST Snaps.
          Image Added

Initially, we configure the JSON Generator Snap where we mention the project name - testDeleteProject111.

          Image Added


Then, we configure the REST Post Snap to create the project in SnapLogic using the account-name string of your choice. To do so:

  1. We use the SnapLogic URL for creating the project in your instance.
  2. We use '$projectName' in the HTTP entity field to indicate that we want to use the string coming from the upstream Snap.
    Image Added

 We click the Account tab and select the account that we want to use with Snap. 

          Image Added

When we validate the Snap, it creates a project in the SnapLogic instance. The Snap displays the following output:

         Image Added

The id field lists out the unique identifier of the new project created by Snap.

We now want to delete the project that you just created. To do so, we use a REST Delete for this task.

         Image Added
The project you created is deleted from the SnapLogic instance. Upon validation, the REST Delete Snap displays the following output:

          Image Added

Download this Pipeline.

Downloads

Multiexcerpt include macro
namedownload_instructions
pageOpenAPI

Attachments
patterns*.slp, *.zip

Insert excerpt
REST Snap Pack
REST Snap Pack
nopaneltrue