Webhooks in Workflows
Webhook workflows allow working with parameters from events and from the contact’s profile in eSputnik.
data:image/s3,"s3://crabby-images/45963/459630d627dc66c8f1fc56420edd51a8bb90db62" alt="webhooks5.png Webhooks in Workflows"
This request uploads and sends the contact’s data from eSputnik to other systems and contrariwise collects data into eSputnik from external systems. Using this as a part of a workflow, you can:
- Address your own resource, which will process the request and return data for personalization (for example, a personal promo code or a token for authorization) in the message.
- Send data from an event or from the contact’s card (for example, order id, additional field “contact’s id in messenger” or “Birthday”) to an external resource.
Note
Only the contact’s data (fields + additional fields) and the parameters from an event that triggered a workflow with a webhook can be sent through a webhook. In most cases, data transfer in webhooks is configured in JSON format, but XML and text formats are also available.
Creating a Webhook in a Workflow
- Go to Automation → Workflows and click the New workflow button.
data:image/s3,"s3://crabby-images/649a6/649a64b0766daf4584452279c94f4c32c7d9ffa5" alt="Creating a new workflow"
- Open the Other tab on the left panel, and select Webhook.
data:image/s3,"s3://crabby-images/e6ec7/e6ec7d7958e6d3e8d38e8fdd943859b5072ef65b" alt="Other tab"
- Click the Create webhook button on the Settings panel on the right side.
data:image/s3,"s3://crabby-images/95605/9560562621da4465ef8fb8fb3d61949d6808caee" alt="Create webhook"
- The Create webhook window opens. Select the
GET
orPOST
request type from the drop-down menu.
data:image/s3,"s3://crabby-images/fa3a3/fa3a3229666bcd8a779f9332c8f7e1f37031af66" alt="Select the `GET` or` POST` request"
Working with GET Request
Use this request type when you want to request data on an external resource using the link to use the data in a workflow and insert it inside the workflow. The data is transmitted to an URL as “name-value” pairs.
data:image/s3,"s3://crabby-images/febad/febad76df0bf8ad53cfccbf479bf854e8954c076" alt="webhooks14.png GET request type"
In order to configure the webhook:
- Enter the webhook name using any symbols (required field) and description (optional field).
- Enter the resource’s URL through secured
HTTPS
protocol (if you enterHTTP
the system does not save the link). Type in variables you want to return after the interrogation symbol. In this example, we transmit the email parameter’s value from an event triggering the workflow and address the EMAIL field related to the contact’s card on the resource to which we sent theGET
request. - If your resource reads parameters from headers, enable Pass parameters in headers slide button and enter corresponding variables and values you want to address.
data:image/s3,"s3://crabby-images/4fefb/4fefb6263c932b982f18ba399927e1572d776d91" alt=""
Below are examples of parameter names and their values that can be used:
Parameter | Value |
---|---|
phone | $phone |
$email | |
name | $name |
city | $city |
contactID | $contact_ID |
param | $workflowInstanceId |
Note
For GET requests, the $workflowInstanceId value can be passed in the webhook parameters — it is a unique identifier for the workflow instance. It allows identifying which specific events belong to the instance and, based on that, calculating statistics and conversions.
Important
For
$workflowInstanceId
, the character case matters, while for contact fields, it does not.
- Enable Authentication slide button and select authentication connector. If you need to configure a new one, click the New connector button to open the Create connector window.
- In Create connector window enter the following details:
data:image/s3,"s3://crabby-images/11da5/11da50f3a7ff45d518fdb0dc887b8e0ef225ab25" alt="connector.png Creating connector"
- Connector name.
- Authentication type from the drop-down list: Basic, Bearer token, API key.
- Enter login and password/token/key.
Click the Done button to apply the new connector in the webhook automatically.
GET-request Testing
- Click the Send test button.
data:image/s3,"s3://crabby-images/ccd44/ccd442117c7a46cda3b186bebf691d333d4a2a88" alt="Click the Send test button"
- Select a contact from the list or find it through the search and click Next.
data:image/s3,"s3://crabby-images/0045d/0045d55e80283010289096f390315dd061fffe61" alt="Select a contact from the list"
To find contacts in a segment, select Preview contacts from the selected segment.
data:image/s3,"s3://crabby-images/d0aa1/d0aa1278ac01817e0014e08c5d3d2e725d072661" alt="Preview contacts from the selected segment"
- Click Send request.
data:image/s3,"s3://crabby-images/6b026/6b026c14647382597c28cffeb449e1711d5d209b" alt="Send request"
- In the testing window, you get the response:
data:image/s3,"s3://crabby-images/02a44/02a4402527649fc407a85c105a02af7e6134cafc" alt="GET_request.png Sending GET request"
Click the Back arrow in the top left corner of the dialog window, and click the Done button.
Now the new webhook is available for selection in your workflow.
data:image/s3,"s3://crabby-images/45265/452658c61906e973ac10224d4a93eda0ed05fe64" alt="webhooks3.png Created webhook"
Now you can show the received data in a message using the expression in Velocity language. Go to Messages → Messages → New Email or choose your template.
data:image/s3,"s3://crabby-images/a0417/a0417e032b14e9ed4eac7952064c410fe9406003" alt="New Email"
Insert the expression with the value of the received variable to output dynamic data into any text area.
data:image/s3,"s3://crabby-images/3baee/3baee6e2ed896d4050d53d47e1ba182e61981c84" alt="webhooks15.png Message variable"
Example: $!mathTool.toInteger($data.contacts_get_by_email.get(0).id)
,
where contacts_get_by_email
is the name of your webhook (here it plays the role of a data source),
get(0).id
is a call to a variable in the source pointing to the required parameter. In this case that is contact id.
When testing, the contact ID is inserted into the message that has been found by the email from an event using the webhook.
Working with POST Requests
Let’s see the example of when it is necessary to send the data about the contact’s city to get a promo code for him/her from an external source.
Follow the steps below to configure a webhook with the POST
request:
- In the webhook block settings, click the Create webhook button.
data:image/s3,"s3://crabby-images/e19a0/e19a037ed730a798a427f607f1c2de7f2670fcb1" alt="Create webhook"
- In the Webhook configuration window, enter the webhook name and select the
POST
request type. Enter the URL of a resource using the secureHTTPS
protocol. In this link, you can use variables calling event parameters or contact fields. In the example, we callTOWN
– the standard contact field in eSputnik.
data:image/s3,"s3://crabby-images/10f0b/10f0be3770b44af3aa1823220746b93363745c03" alt="POST Request"
- If your application reads parameters from headers, enable the Pass parameters in headers slide button. Enter corresponding variables and their values
data:image/s3,"s3://crabby-images/ec7dd/ec7dd625878195633950a0971408878d1e4b6bb7" alt=""
Note
For POST requests, the $workflowInstanceId value can be passed in the webhook parameters — it is a unique identifier for the workflow instance. It allows identifying which specific events belong to the instance and, based on that, calculating statistics and conversions.
Important
For
$workflowInstanceId
, the character case matters, while for contact fields, it does not.
- Enable the Authentication slide button to configure authentication parameters. Select from existing connectors or create a new one.
data:image/s3,"s3://crabby-images/d97b3/d97b30ea342f3ec635fcd8d3e36af2930ded8dc9" alt="Configure authentication parameters"
If you need to configure a new one, click the New connector button to open the Create connector window.
In Create connector window:
- Enter the Connector name.
- Select Authentication type from the dropdown list: Basic, Bearer token, API key.
- Enter login and password/token/key.
Click the Done button.
data:image/s3,"s3://crabby-images/73a64/73a6488c1eb8bec483ad9633e4609c7bf591a360" alt="Create connector"
In the body of the POST
request, you can send a random amount of data. For that, enable the corresponding slide button, select the format of the data to be inserted and insert it below. Available formats: JSON, XML, text.
data:image/s3,"s3://crabby-images/5ffef/5ffef8a735312b4e8c2b85be47af2a118c9cd5fa" alt="Available formats: JSON, XML, text"
To access event parameters, use Apache Velocity, for example: "param": "$data.get('param')"
.
Note
The value of
$workflowInstanceId
can be passed in the request body.
data:image/s3,"s3://crabby-images/ba433/ba433dd1afbdab922ce36bcb3e514b28916a603b" alt="$workflowInstanceId in the request body"
Displaying the value of $workflowInstanceId
in the event parameters:
data:image/s3,"s3://crabby-images/db5ee/db5ee3b2d83d203773449d8d431772c86382777c" alt="$workflowInstanceId in the event parameters"
POST-request Testing
- Click the Send test button.
data:image/s3,"s3://crabby-images/03290/0329041446b12dd8176ebbea17a05b7ce808ca40" alt="webhooks6.png POST request type"
- The system suggests where to take the data for testing – from the contact’s card or from an event. If the webhook URL is configured to address a parameter from an event, then during testing the system suggests choosing an event from the list of those received by the system at any time, or to enter the event’s body manually.
data:image/s3,"s3://crabby-images/64eee/64eeeeb8f6a72c206407e2ce0d831d2c1369acd3" alt="webhooks4.png POST request parameters"
Since in our example we indicate addressing to the contact field, then it is necessary to select a contact from the base in the eSputnik account.
data:image/s3,"s3://crabby-images/71bfe/71bfe8f32245bc4e4c46dc570673dda67389cff0" alt="webhooks7.png POST request dynamic data"
You can choose another contact (1) or view the selected one (2).
Upon pressing the Next and Send request buttons you receive the response with Headers and Body:
data:image/s3,"s3://crabby-images/93c98/93c9836cf2f9b6f3b56e9f9cd0476a1abc902564" alt="Campaign-details.png Sending POST request"
To show the promo code in the message, enter the following expression into the text area:
$data.get('WH5').get('promocode')
, where
WH5
is the source name (webhook name).promocode
is the name of the variable containing the promo code value.
data:image/s3,"s3://crabby-images/2ba76/2ba763bbf1238ce3a4b665a013432b07c1ea885f" alt="webhooks1.png Promo code variable in the message"
The result of a promo code inserted in the email:
data:image/s3,"s3://crabby-images/dac64/dac64af45bc52a79f09421f69b940b2cc84a2427" alt="webhooks12.png Promo code inserted in the email"
Advanced Parameters
data:image/s3,"s3://crabby-images/7a4a2/7a4a2fe22d385066e3e4c5a38001987af0215313" alt="Advanced Parameters"
The block contains advanced parameters, and the cases for filling them out are detailed in a separate article
Webhook Management
Press Manage Webhook in the webhook block settings. The window containing the list of webhooks opens. There you can:
- create a new webhook
- edit existing webhooks
- test webhooks
- delete webhooks
- view the list of deleted webhooks
data:image/s3,"s3://crabby-images/139dc/139dcd757b5c072185f586911dc741e38dd29313" alt="webhook.png Webhook management"
In the start history of the workflow with a webhook, you will see the details of the request:
data:image/s3,"s3://crabby-images/c64ba/c64bae7167185a53c2b4c166b74734ec15e9add8" alt="Start-history.png Details of the request"
Updated 9 days ago