Format Strings with Templates
Any steps that accept or create strings can also include Automation (InsightConnect) variables. These templates help you format string content for plugins and artifact cards.
Handlebars 101
Automation (InsightConnect)’s templating syntax is based on the Handlebars language. Learn more about Handlebars at https://handlebarsjs.com/guide
Blocks
The Handlebars language structures content in “blocks,” which begin with tags that start with {{#<block type>}} and end with {{/<block type>}}. Type your content between the block tags, and substitute <block type> with the name of the block you intend to use. You can nest blocks within other blocks.
Format Variables Within Handlebars Blocks
All triggers and action steps create JSON-based output. Use a step’s output variables as input for any following steps.
To quickly format previous steps’ output variables, use the format {{[StepName].[variablename]}}, replacing StepName with the name of the step creating the output and replacing variablename with the name you configured for that variable.
Alternatively, you can click on the blue + sign in any variable-enabled string field to search for the desired variable. Variables are sorted according to the step that created it.
If you add any variables with the + sign into the following Handlebars-based templates, remove the curly braces on either side of the variable. A single Handlesbars statement should only have one set of four curly braces. For example, {{#each [StepName].[variable]}} is correct, and {{#each {{[StepName].[variable]}} }} is incorrect.
Conditional Display
If you would like to display only some variable information and not others, use conditional logic and statements to toggle what variable content your artifacts or plugins can publish.
Conditional logic uses conditions to toggle certain behavior between one option or another. In order for Automation (InsightConnect) to choose one option, it must meet a given condition. If the condition isn’t met, then Automation (InsightConnect) selects the second option instead.
In Automation (InsightConnect), use an “if statement” to specify the condition that would lead to the first option displaying. Follow the provided template and sample content to configure a conditional statement that works for your needs.
Template: Conditional Display
{{#if <condition to check for>}}
Content to display if condition is met
{{else}}
Content to display if condition is not met
{{/if}}Example: Conditional Display
The following example checks for a condition based on a step that searches for a provided URL (Check URL.url) in a database. If the step finds the URL in the database, the variable Check URL.wasfound will be set to true—if the URL wasn’t discovered, the value of Check URL.wasfound will be false.
{{#if [Check URL].[wasfound]}}
The url {{[Check URL].url}} was found.
{{else}}
The url {{[Check URL].url}} was not found.
{{/if}}This string template example checks the value of Check URL.wasfound. If the step checks for the URL google.com, the template will display “The URL google.com was found” or “The URL google.com was not found.”
Display Array Content
The Handlebars language allows you to iterate over array-type input variables. Array input and output save collections of data, and any following workflow steps that operate on that data can run actions on the full array.
Accessing Loop Content
Output created by loops are stored in the variable [Loop Name].[$outputs], which is an array of objects. To access data from steps following a loop, you can use the following #each template to extract data for each iteration (object) in the array.
Template: Display Array Content
{{#each <collection of items to check>}}
Content to display for one item of the array
{{/each}}Example: Display Array Content
To illustrate how to display array content, we’ll build upon the example provided for conditional display. Instead of operating on one Check URL.url value, this sample operates on an array of multiple URL strings, which are stored in the variable Check URL.$outputs.
{{#each [Check URL].[array].$outputs}}
  {{#if [Check URL].in_database}}
  The url {{url}} was found.
  {{else}}
  The url {{url}} was not found.
  {{/if}}
{{/each}}For this example, Check URL.$outputs contains the URLs google.com, bing.com, and askjeeves.com. If all three URLs were discovered in the database, the resulting artifact would display.
Display array content from a trigger
If your trigger ingests array-type input, the [TriggerName].[arrayvariable].$outputs format will not work because the $outputs suffix is used for array items added during the workflow.
To display array items from a trigger’s array input, format the string content as follows:
{{#each [TriggerName].[arrayvariable]}}
{{this}}
{{/each}}The this variable refers to the current item in the array.
Display JSON Object Content
You can display all JSON object content in an artifact, or print only specific items by using key names.
Template: Print all JSON Object Items
You can print the list of all items in a JSON object with this template.
{{#each [StepName].[JSON object variable]}}
{{#each .}}
  {{@key}} = {{.}}
{{/each}}
{{/each}}The period . refers to the item values mapped within the JSON object. The {{@key}} = {{.}} statement prints the key reference and corresponding value. For example, the JSON item  { “dog”: “fido”} will display as dog = fido.
Template: Print JSON Object Items by Key Name
You can also print JSON object values by referring to the values by their key name. Add your desired content between the each tags.
{{#each [StepName].[JSON object variable]}}
Your content {{firstkeyname}}
{{nextkeyname}}, more of your content
{{etc keyname}}
{{/each}}To illustrate how to print JSON objects with key name references, consider this sample object:
[ {'name': u'Line 6 amp b 52 400 watt cabinet', 'has_image': True, 'url': u'https://peoria.craigslist.org/msg/d/line-6-ampwatt-cabinet/6305140213.html', 'has_map': True, 'price': u'$400', 'geotag': None, 'where': Peoria, 'id': u'6305140213', 'datetime': u'2017-09-13 20:34'}
{'name': u'Crate Cube 40 GX guitar amp', 'has_image': True, 'url': u'https://springfieldil.craigslist.org/msg/d/crate-cube-40-gx-guitar-amp/6305483242.html', 'has_map': True, 'price': u'$135', 'geotag': None, 'where': Springfield, 'id': u'6305483242', 'datetime': u'2017-09-14 08:12'} ]The string formatting based on the key name template could be:
{{#each [Search For Sale].[sale_posting]}}
{{name}} - {{price}} in {{where}}
{{/each}}The end result of the string formatting for the sample object is:
Line 6 amp b 52 400 watt cabinet - $400 in Peoria
Crate Cube 40 GX guitar amp - $135 in SpringfieldMatch Variables
You can also determine which content to display by comparing strings or integers with Handlebars. Your content only displays if the equal statement finds a successful string match.
Template: Match Variables
{{#equal <variable> <constant>}}
Content to display
{{/equal}}To format the equal statement in your artifact:
- Replace the <variable>placeholder with your desired Automation (InsightConnect) step variable formatted without curly braces, like[Stepname].[variable].
- Replace the <constant>placeholder with the string or integer to compare with the Automation (InsightConnect) variable value. Strings must be formatted in double quotes (”string”), and integers must be formatted without quotes (0).
Example: Match Variables
In the following example, if the value of the “CountPostings.count” variable matches the integer 0, the artifact will display the text “No postings for today.”
{{#equal [Count Postings].[count] 0}}
No postings for today
{{/equal}}Extract Nested Information
If your workflow uses nested arrays (arrays within arrays) or objects, use a nested with block to grab information within the nested structure.
Template: Extract Nested Information
{{#each <parent structure>}}
  {{#with <child structure>]}}
   {{<item to extract>}}
  {{/with}}
{{/each}}Example: Extract Nested Information
Consider this nested JSON object: { "hits": [{ "obj": { "message": "hi" }}] }.
The following Handlebars content will print the value “hi” for the key message within the nested object obj. obj is the value of the parent object’s key hits. { "hits": [{ "obj": { "message": "hi" }}] }.
{{#each [hits]}}
  {{#with [obj]}}
   message is {{message}}
  {{/with}}
{{/each}}Other Formatting Options
Use these options to format your artifact content with Handlebars.
Time Variables
Automation (InsightConnect) can also display time values with Handlebars.
{{$time.now}} : Display the current time in RFC 3339 date format.
For example, 2018-03-14 00:45:49.654049875 +0000 UTC
{{$time.format <time variable> <format string>}} : Format a time variable into a different string format. The time variable can be {{$time.now}} or a previous step variable. Replace the <format string> value with one of the options from the table below according to your needs.
Time Format String Options
| Format String | Description | Example Output | 
|---|---|---|
| ANSIC | The ANSI-C date/time format without time zone | ”Mon Jan 2 15:04:05 2006” | 
| UnixDate | The standard Unix date/time format with string time zone | ”Mon Jan 2 15:04:05 UTC 2006” | 
| RubyDate | The Ruby standard date/time format with numeric time zone offset | ”Mon Jan 02 15:04:05 -0700 2006” | 
| RFC822 | Short RFC822 date/time format with string time zone | ”02 Jan 06 15:04 UTC” | 
| RFC822Z | Short RFC822 date/time with numeric time zone offset | ”02 Jan 06 15:04 -0700” | 
| RFC850 | Long date/time format with weekday name | ”Monday, 02-Jan-06 15:04:05 UTC” | 
| RFC1123 | Long date/time format with short weekday | ”Mon, 02 Jan 2006 15:04:05 UTC” | 
| RFC1123Z | Long date/time format with numeric time zone offset | ”Mon, 02 Jan 2006 15:04:05 -0700” | 
| RFC3339 | Short date/time format with T delimiter and numeric time zone offset | ”2006-01-02T15:04:05Z07:00” | 
| RFC3339Nano | Short date/time format with T delimiter and decimal time | ”2006-01-02T15:04:05.999999999Z07:00” | 
| Kitchen | Short time format with 12h time | ”3:04PM” | 
| Stamp | Short date/time stamp | ”Jan 2 15:04:05” | 
| StampMilli | Short date/time stamp with 3 decimal places of accuracy | ”Jan 2 15:04:05.000” | 
| StampMicro | Short date/time stamp with 6 decimal places of accuracy | ”Jan 2 15:04:05.000000” | 
| StampNano | Short date/time stamp with 9 decimal places of accuracy | ”Jan 2 15:04:05.000000000” | 
For example: {{$time.format ($time.now) "RFC822"}} would display: 02 Jan 06 15:04 UTC
Remove Newlines
If you include your Handlebars statements on separate lines from the rest of your content, Automation (InsightConnect) will capture the new lines when creating the artifact or content. If you want to remove new lines from the variable, add ~ to the beginning of your logic statements. For example:
line1
{{~#if [API Trigger].[myvariable]}}
line2
{{~/if}}
line3will appear as
line1line2line3whereas
line1
{{#if [API Trigger].[myvariable]}}
line2
{{/if}}
line3will appear as
line 1
line 2
line 3Display Length
To show how many items are in an array or how many characters are in a string, use {{$length (["step_name"].[variable])}}. Replace step_name and variable with a step variable from your own workflow. You can also enter a standard non-variable string if needed, for example {{$length "Some Text Here"}}