From Chain Builder, you can create a chain to download data from Enablon®, such as your greenhouse gas (GHG) emissions for Environmental, Social, and Governance (ESG) reporting.
Prerequisites
To build this chain, you'll use these core connectors:
- HTTP Request connector
- File Utilities connector
- XML connector
- Workiva connector, if you need to use the data in a spreadsheet or Wdata table
Note: All of this chain's commands use the default CloudRunner. No GroundRunner is needed.
To run the chain, you'll need details from Enablon to access the data:
- The Enablon Simple Object Access Protocol (SOAP) Application Programming Interface (API) endpoint to use to download the data
- The ID of the Enablon environment to access
- The user name and password to use to access the environment
Step 1. Create the chain
- From Chains, click Create, and select Create chain.
- Under Setup, enter a name and description to help identify the chain and its intent.
- Under Variables, add variables for the Enablon details required to access the data:
- Endpoint
Tip: For the Endpoint variable, enter a default value of
ExportData
or, to download the data in a 64-bit encoding format,ExportBinaryData
. - Environment
- Username
- Password
- Endpoint
- Click Save.
Step 2. Start with the Runtime Inputs trigger event
To filter the output each time the chain runs, start with a Runtime Inputs event to prompt for the criteria of the data to download.
- Move Runtime Inputs from under Trigger Events to Start.
- Select the Runtime Inputs event, and click Edit.
- Add the inputs to request each time the chain runs:
Display name Type Required? Report period start date DateField Yes Report period end date DateField Yes Campaign TextField or DropdownField: - TextField, for an open text field
- DropdownField, to select from a specific list of options
Yes Entities ArrayField Yes - Click Save.
Step 3. Add an HTTP Request connector POST command
To retrieve the data from the Enablon endpoint, set up an HTTP connector POST command:
- Under BizApps, click HTTP, and move the POST command to the canvas.
- Drag a link from Start to the POST command.
- Select the POST command, and click Edit.
- Under Command properties, select the HTTP connector to use.
- Enter the command's properties:
Property Description User name Select the Username variable under Chain. Password Select the Password variable under Chain. Show response Check this box. URL Select the Endpoint variable under Chain. Content type Enter text/xml
. - In Body text, enter this Extensible Markup Language (XML) syntax:
<soapenv:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:enab="enablon"> <soapenv:Header> <UserInfo xsi:type="wsdl:AuthHeader" xmlns:wsdl="http://enablon/wsdl/"> <EnaHomeSite xsi:type="xsd:string">[Environment]</EnaHomeSite> <EnaUserName xsi:type="xsd:string">[Username]</EnaUserName> <EnaPassword xsi:type="xsd:string">[Password]</EnaPassword> </UserInfo> </soapenv:Header> <soapenv:Body> <enab:ExportData soapenv:encoding:Style="http://schemas.xmlsoap.org/soap/encoding/"> <Table>/sd/Entities/Data</Table> <FolderId>0</FolderId> <Fields>FolderPath|ReportingPeriod|Ref|IndicatorName|ValueNumber|LocalUnit|ValueList</Fields> <Filter>ReportingPeriod in ([ReportPeriodEndDate],[ReportPeriodStartDate]) AND Campaign in([Campaign]) AND Entities=[Entities]</Filter> <CSVSeparator>2</CSVSeparator> <FormatOptions>25</FormatOptions> <FormatType>3</FormatType> <ExportOptions>8192</ExportOptions> </enab:ExportData> </soapenv:Body> </soapenv:Envelope>
- Update the XML syntax with the runtime input and chain variables:
- In the header, replace
[Environment]
,[Username]
, and[Password]
with their respective variables under Chain. - In the body, replace
[ReportPeriodEndDate]
,[ReportPeriodStartDate]
,[Campaign]
, and[Entities]
with their runtime inputs under Trigger.
- In the header, replace
- Click Save.
Step 4. Add File Utilities connector Find and Replace commands
To prepare the downloaded XML data, add File Utilities connector Find and replace commands to fix the angle brackets and pipes.
Tip: To easily differentiate the Find and replace commands, enter names to identify the character each command fixes, such as "Find and replace start angle brackets" or "Find and replace pipes".
- Under BizApps, click File Utilities, and move the Find and replace command to the canvas.
- Drag a link from the POST command to the Find and replace command.
- Select the Find and replace command, and click Edit.
- Under Command properties, select the File Utilities connector to use.
- Enter the command's properties, and click Save:
Property Description Source Select the Response output of the POST command. Find Enter <
.Replace Enter a start angle bracket ( <
).Find syntax Select Exact. - Under BizApps, click File Utilities, and move another Find and replace command to the canvas.
- Drag a link between the Find and replace commands.
- Select the new Find and replace command, and click Edit.
- Under Command properties, select the same File Utilities connector.
- Enter the command's properties, and click Save:
Property Description Source Select the Replaced result output of the Find and replace command. Find Enter >
.Replace Enter a start angle bracket ( >
).Find syntax Select Exact. - Under BizApps, click File Utilities, and move another Find and replace command to the canvas.
- Drag a link between the second and third Find and replace commands.
- Select the third Find and replace command, and click Edit.
- Under Command properties, select the same File Utilities connector.
- Enter the command's properties, and click Save:
Property Description Source Select the Replaced result output of the second Find and replace command. Find Enter &gt;
.Replace Enter a pipe ( |
).Find syntax Select Exact.
Step 5. Add an XML connector Element List to CSV command
To convert the downloaded XML to tabular data, add an XML connector Element list to CSV command:
- Under BizApps, click XML, and move another Element list to CSV command to the canvas.
- Drag a link from the third Find and replace command to the Element list to CSV command.
- Select the Element list to CSV command, and click Edit.
- Under Command properties, select the XML connector to use.
- Enter the command's properties:
Property Description Source Select the Replaced result output of the third Find and replace command. Path to root Enter //Document/Record
.Preview result Check this box. - Under Columns, add the column name and XPath for each element:
Column name XPath Period /ReportingPeriod Indicator /Ref IndName /IndicatorName NumValue /ValueNumber Unit /LocalUnit - In Multi-value delimiter, enter a comma (
,
). - Click Save.
Step 6. Add a File Utilities connector Create File command
To create a comma-separated values (CSV) file from the tabular data, add a File Utilities connector Create file command:
- Under BizApps, click File Utilities, and move the Create file command to the canvas.
- Drag a link from the Element list to CSV command to the Create file command.
- Select the Create file command, and click Edit.
- Under Command properties, select the same File Utilities connector as the Find and replace commands.
- Enter the command's properties, and click Save:
Property Description Text Select the Converted file output of the Element list to CSV command. File path Select the Chain.Workspace variable under Runtime, and append \test.csv
.
Step 7. Add commands to use data in Workiva
To use the CSV data in the Workiva platform, add Workiva connector commands to use the Created file variable output of the Create file command with a spreadsheet or Wdata table. For example, to add the Enablon data as a data set in a Wdata table, add a Run chain event that uses a chain created from the Update datasets in a table template.
Step 8. Publish and run the chain
To enable the chain to run:
- Click Publish.
- Enter any comment about its publication, and click Publish.
To run the chain:
- From Chains, select Edit from the chain's menu.
- Click Chain Settings, enter the variable values, and click Save.
Note: For the Endpoint variable, enter
ExportData
or, to download the data in a 64-bit encoding format,ExportBinaryData
. - Click Execute.
- From Monitor, click Run with inputs, enter the runtime inputs, and click Start.