This Justuno support article will cover how to submit setup Justuno webhooks
At a glance:
Introduction
General feature overview
Using the JSON editor
Changing the type for a dynamic property
Send checkboxes and multi selects as comma separated string
Introduction
Webhooks are one way that Justuno can send automated messages or information to other apps. You can configure what to send and when to send it and in what format.
General Feature Overview
Supports the following HTTP methods:
GET, POST, PUT, PATCH, and DELETE
Supports the following content-type for HTTP body:
json, form url encoded, and form data
Send Justuno profile properties dynamically in HTTP body
Justuno profile properties can be passed with dynamic names, e.g. if we have a profile property named sms, then the client can send it over as any name. Client isn't tied to our naming conventions for profile properties, as in client can move around the dynamic properties as they please
Send static headers and values
Headers are key/value pairs and are usually used for authentication.
Send static values in HTTP body
JSON editor helps visualize the payload for requests set up. Add static values here and move around dynamic variables here as you like.
Using the JSON Editor
The JSON editor is a representation of the HTTP body to be sent, regardless of the content-type selected.
When you are moving around dynamic variables i.e. properties wrapped in double curly braces for example {{email}}, be sure to NOT wrap it in quotes. This will cause our parser to fail.
Note: do not rename the dynamic variable. This will cause our parser to fail
Changing the type for a dynamic property
We support the ability for most dynamic profile property to be sent as these following JSON data types when format is defined.
boolean
|
number
|
string
|
For dynamic properties that are checkboxes or multi select, each element in the array will be converted to a specified type from above.
If format is used with a data type not in the supported JSON data types, then the dynamic profile property value will be passed as a string
If the dynamic property fails to convert, then it will fallback to being passed as the zero value of that type.
boolean
|
false
|
number
|
0.0
|
string
|
empty string or ""
|
If a format type is not defined, then it property is sent over as it's respective property type.
Here is a table for that breakdown
Profile Property Types
|
JSON Type Sent
|
boolean
|
boolean
|
date
|
string
|
datetime
|
string
|
short text
|
string
|
long text
|
string
|
radio
|
string
|
single select
|
string
|
checkboxes
|
array of strings
|
multi select
|
array of strings
|
number
|
number
|
currency
|
number
|
json
|
object
|
You can change the type of dynamic property by adding specific text for the property in the JSON Editor.
Example, you have a property that is an input field named numberOfSneakersOwned that is stored as a string.
When you add this property, the JSON editor will add a line like below
{
"numberOfSneakersOwned": {{numbersOfSneakersOwned}}
}
To change the type to a number, add [format='number'] like below
{
"numberOfSneakersOwned": {{numbersOfSneakersOwned[format='number']}}
}
Here is a list of our current formatting options you can use with variables in our webhooks:
{{numbersOfSneakersOwned[format='number']}}
{{numbersOfSneakersOwned[format='string']}}
{{someProperty[format='boolean']}}
{{sms[format='right,10']}}
{{zip[format='left,3']}}
Limitations of changing types with format listed below...
NO format type support for cart items dynamic variables and default JSON profile properties which are currently listed below.
- product_id
- variation_id
- sku
- price
- ip_organization
- ip_coordinates
- device_tech
Send checkboxes and multi selects as comma separated string
We support the ability for profile properties that have the type checkboxes or multi select to be sent as a comma separated string. Without a format, these types would be sending an array of strings.
To use this feature, add [format='comma'] like below
{
"interests": {{interests[format='comma']}}
}
This would convert interests array of strings to a comma separated string
{
"interests": "nba,shoes,traveling"
}
Using the "comma" format on properties that are not checkboxes or multi select may cause issues. Ensure the property using this format option is a supported type.