/
UAC Utility: For-Each-Input Loop

UAC Utility: For-Each-Input Loop

Disclaimer

Your use of this download is governed by Stonebranch’s Terms of Use, which are available at  Stonebranch Integration Hub - Terms of Use.

Overview

This integration is designed to automate the processing of input data by reading it from a flat file in Windows/Linux or a UAC script data repository. The core functionality revolves around a for-each loop, which iterates through the input data, parsing it using a predefined delimiter (such as a comma, pipe, or any one or two characters).

The parsed data segments are extracted and provided further to UAC tasks or workflows during each iteration. This allows for modular processing, where each task can handle a specific aspect of the data, enabling efficient and organized execution of complex workflows.

Note

Starting from version 1.0.2, the Universal Template will support a Universal Controller with the Task Field Resolution Required system property enabled. Ensure that the configuration is completed as outlined in the Configure Universal Task section.

Version Information

Template Name Version
For-Each-Input Loop1.1.0

Refer to Changelog for version history information.

Software Requirements

This integration requires a Universal Agent and a Python runtime to execute the Universal Task.

Software Requirements for Universal Template and Universal Task

Requires Python 3.7.6 or higher. Tested with the Universal Agent bundled Python distribution.

Software Requirements for Universal Agent

Both Windows and Linux agents are supported.

  • Universal Agent for Windows x64 Version 7.1.0.0 and later with Python options installed.
  • Universal Agent for Linux Version 7.1.0.0 and later with Python options installed.
  • Python modules required:

    • requests

Software Requirements for Universal Controller

Universal Controller Version 7.1.0.0 and later.

Network and Connectivity Requirements

Key Features

This Universal Extension provides the following key features:

  • Actions
    • Read input from a Windows or Linux flat file.
    • Read input from UAC script type data.
    • Parse each line of input via any single or two characters.
    • Launch UAC task or workflow for every line of the parsed input via REST API.
    • Option to wait and launch UAC tasks or workflows based on the previous execution's completion.
    • Capability to launch UAC tasks or workflows either sequentially or in parallel and monitor executions of launched task instances.
    • Restart the for-each loop task from the failed line of input or customize the input lines accordingly in the UAC script data.
    • Option to abort for For-Each-Input Loop task execution when one of the launched child tasks or workflows fails.
  • Authentication
    • Authentication through HTTP(S)
  • Input/Output
    • Capability to read input from a flat file in Windows or Linux Operating system
    • Can Accept from UAC script data 
    • It can also accept input from UAC script data that points to a variable potentially the data coming from predecessors Taks
    • Print the summary of Tasks instances launched for the input data and their status
  • Other
    • It's a UAC utility that helps to iterate through the input data and process it by launching a UAC task or workflow via REST-API

Import Universal Template

To use the Universal Template, you first must perform the following steps.

  1. This Universal Task requires the Resolvable Credentials feature. Check that the Resolvable Credentials Permitted system property has been set to true.

  2. To import the Universal Template into your Controller, follow these instructions.

  3. When the files have been imported successfully, refresh the Universal Templates list; the Universal Template will appear on the list.

Modifications of this integration, applied by users or customers, before or after import, might affect the supportability of this integration. For more information refer to Integration Modifications.

Configure Universal Task

Prerequisites for Creating a Task with This Template:

  1. Create a script named DUMMY of type Data. The script's content can remain empty.

These configurations are mandatory starting from version 1.0.2, as the Universal Template has been adapted to support the Universal Controller when the Task Field Resolution Required system property is enabled.

For a new Universal Task, create a new task, and enter the required input fields.

Input Fields

The For-Each-Input Loop task contains the following Input fields

FieldInput typeDefault valueTypeDescription
Select a FunctionRequiredTrigger by Script InputChoice

The action performed upon the task execution.

Valid values are:

  • Trigger by Script Input

  • Trigger by reading Target File

UAC Base URLRequired
TextProvide the universal controller base URL. Eg.-https://xxxxxxx.stonebranchdev.cloud/
UAC CredentialsRequired-CredentialsCredentials for "Basic" Authorization Type. The Credentials definition should be as follows.
  • Universal Controller User as "Runtime User".
  • Universal Controller User Password as "Runtime Password".
User Defined InputRequiredDUMMYScript

Select or Create a UAC Script type of data that can be provided as input.

Required when the field: Select a Function is selected with "Trigger by Script Input" 

Specify Script name by VariableOptionalFalseBooleanThe flag that determines whether the UAC Script type of data provided as a variable
Script Name by VariableOptional

DUMMY

Text

Provide the UAC Variable that points to the UAC Script of type data 

Required when the field "Specify Script name by Variable" is set to True

Specify the Input FileOptional-Text

Provide the Input File Name included with path either from a Windows or a Linux OS

 Required when the field: Select a Function is selected with "Trigger by reading Target File" 

Specify Delimiter to Parse InputOptionalFalseBooleanEnable it when it required to parse the input data with a single or two-character delimiter
Variable DelimiterOptional-TextSpecify the delimiter value by which the extracted line of input is to be parsed E.g. Comma or Pipe or ## or any single or double character
First Row as HeaderOptionalFalseBoolean

Enable this field if the First row in the input file or script needs to be considered as a header.

If the first line in data is considered as Header, every UAC task launch will have the corresponding header (column name) as a variable name 

UAC Task to triggerRequired-TextSpecify the UAC Task Name or Workflow that needs to be triggered for every input line read
Parallel Job launchOptionalFalseBoolean

Check this field if the UAC Task needs to be launched in Parallel for every line of Input that is been read

By default, the UAC Task is launched Sequentially  & monitored for every line of input read 

Abort Execution When a triggered Job FailsOptionalFalseBooleanEnable this field if the Parent "For-Each-Input Loop" task needs to fail when one of the launched child UAC Task fails
Restart from FailureOptionalFalseBooleanEnable the field when the Parent "For-Each-Input Loop" task needs to be restarted and input lines to be corrected in UAC Script of type data
Restart Execution InputOptionalDUMMYScriptProvides the restart input in the UAC script of type data
Launch PriorityOptional10TextSpecify the Virtual Resource priority of the launched Task

Task Examples

Task Output

  • Trigger For-Each-Input-Loop Task by reading a Flat File


UAC Task launched with Variables :


  • Trigger For-Each-Input-Loop Task by reading the UAC Script of type data


  • Trigger For-Each-Input-Loop Task by reading the UAC script with input variables from the predecessor task


  • Task execution output: For-Each-Input-Loop


  • Example Workflow: Process Files in Loop

  • Example Workflow: Process Servicenow Infra Create RITM request in a loop


  • Example Workflow: Handling SAP Transport request from Azure DevOps in a loop

Exit Codes

The exit codes for these Universal Templates are described below.

Exit CodeStatus Classification CodeStatus Classification DescriptionStatus Description
0SUCCESSSuccessful ExecutionSUCCESS: Successful Task execution
2FAILEDFailed ExecutionFAILURE: Input list is empty
5FAILEDFailed ExecutionFAILURE: Issues while monitoring the UAC-launched Task
10FAILEDFailed ExecutionFAILURE: Exception while launching the UAC Task or Workflow
99FAILEDFailed ExecutionFAILURE: Error Launching the UAC Task ( Response Code not 200 )
100FAILEDFailed ExecutionFAILURE: when one of the launched tasks failed

STDOUT and STDERR

STDOUT and STDERR provide additional information to the User. The populated content can be changed in future versions of this extension without notice. Backward compatibility is not guaranteed.

Document References

This document references the following documents.

Document LinkDescription
Universal TemplatesUser documentation for creating, working with and understanding Universal Templates and Integrations.
Universal TasksUser documentation for creating Universal Tasks in the Universal Controller user interface.
CredentialsUser documentation for creating and working with credentials.
Resolvable Credentials Permitted PropertyUser documentation for Resolvable Credentials Permitted Property.

Integration Modifications

Modifications applied by users or customers, before or after import, might affect the supportability of this integration. The following modifications are discouraged to retain the support level as applied for this integration.

  • Python code modifications should not be done.
  • Template Modifications
    • General Section
      • "Name", "Extension", "Variable Prefix", "Icon" should not be changed.
    • Universal Template Details Section
      • "Template Type", "Agent Type", "Send Extension Variables", "Always Cancel on Force Finish" should not be changed.
    • Result Processing Defaults Section
      • Success and Failure Exit codes should not be changed.
      • Success and Failure Output processing should not be changed.
    • Fields Restriction Section
      The setup of the template does not impose any restrictions, However with respect to "Exit Code Processing Fields" section.
      1. Success/Failure exit codes need to be respected.
      2. In principle, as STDERR and STDOUT outputs can change in follow-up releases of this integration, they should not be considered as a reliable source for determining success or failure of a task.

Users and customers are encouraged to report defects, or feature requests at Stonebranch Support Desk.


Changelog


ut-cs-for-each-input-loop-1.1.0 (2025-01-16)

Enhancements

  • Supports a Controller with the "Task Field Resolution Required" system property enabled
  • Virtual Resource priority can be specified for the launched Task

ut-cs-for-each-input-loop-1.0.1 (2024-08-01)

Fixes

  • Exits with RC 2 when the input list is empty

ut-cs-for-each-input-loop-1.0.0 (2024-05-29)

Initial Version