Applies to
Reference data in the workflow
There are a few locations where data gets stored in Bridge:
Reference data from the runtime
The runtime is where trigger data from an integration is stored. The reference for the runtime data is {{runtime}}.
There are a number of data pieces stored within the runtime you may want to reference. When you are referencing these items, you should specify the name of the individual item.
For example, if a sheet in Smartsheet is the trigger for a workflow, you'll most likely need to reference the ID of the row involved. The reference could look like this: {{runtime.event.rowId}}.
The exact structure and naming convention is different depending on the trigger and event type.
To make sure you are using the right reference:
- In the Run Log, hover over a trigger object.
- Select .
- In the list that appears, select Copy Data Reference.
Reference data from a state
Referencing a state is most often done when data has been passed from a parent workflow. The format of the reference is {{states.state name.value}}.
If you want to reference data from a module below a state, the state still plays a part. In this case, the structure of the reference would be {{states.state name.integration or utility name.module name}}.
If a module can output multiple data values, add the path for this specific data in your data reference (similar to how you reference individual pieces of runtime data).
For example, the Smartsheet: Get Row module by default returns the data in the image below.
To reference the value entered in the Address cell on the row, the reference would be:
{{states.GetRow.smartsheet.get_row.row.cells.Address.value}}.
Reference data from a child workflow
You can reference data from a child workflow within the parent workflow. To do that, your data reference could look like this:
- states.{{state that runs the child}}.child.{{state in child}}.value.; or
- states.{{state that runs the child}}.child.{{state in child}}.integration or utility.module.
Options for empty data references
When the next step of your workflow depends on a specific value, which may or may not exist, you can use vertical bars (||) to handle two scenarios.
For example, you want to use the value in a Smartsheet cell to determine which path of a junction the workflow goes down. But you can't be certain the cell will always contain a value.
If the cell is empty, the workflow will be stopped when it gets to the junction. You can add vertical bars (||) at the end of your data reference to avoid this. If that value has data, the workflow will use the reference to the left of the bars. If data doesn’t exist in that cell, the workflow will use what is on the right of the bars.
Take a look at the two possible scenarios in this reference:
{{states.GetRow.smartsheet.get_row.row.cells.Address.value||116 George Street, Edinburgh, UK}}
- The workflow will first try to use the address from the row it got earlier: GetRow.smartsheet.get_row.row.cells.Address.value.
- However, if that cell is blank, it will then move on to use the address specified after the vertical bars: 116 George Street, Edinburgh, UK.
Tips in using vertical bars
You can use:
- another data reference after the vertical bars rather than a typed value, or
- multiple vertical bars to handle several different possible scenarios.
Mix text and data references
In most modules, you can combine written text and data references. You can type out the parts of the email that should always be the same and use data references for the parts that might not always be the same, such as the name of a recipient or a date.
If you built the weather workflow in the Start a blank workflow for US Weather Service article, you might have noticed that the URL used in the API call to the US Weather Service contained two data references.