For Each Loop task
The For Each Loop task lets you make repeated calls to a sub-integration from your current (main) integration. The task iterates over the configured array variable and calls the sub-integration for each element in the array. The number of times the sub-integration is called is equal to the size of the array variable.
The API Trigger ID and the Integration name identifies the sub-integration you want to run.
The task also lets you collect the response from each sub-integration run and store the value in your current integration for use in downstream tasks. You can use any of the following approach to collect the responses:
- Collate the response of each run in an array variable, where each element of the array has the
  response from one particular run. To collate the responses, configure
  the Collect values from sub-integration output(s)property.
- Aggregate the responses of all the runs in a single variable. To aggregate the responses, configure
  the Response parameter override mappingproperty.
Before you begin
- Ensure that you have attached a user-managed service account to your integration. If your integration does not have user-managed service account configured, then by default the default service account  (service-PROJECT_NUMBER@gcp-sa-integrations.iam.gserviceaccount.com) is used for authentication.
- Ensure that your service account has the Application Integration Invoker IAM role. For information about granting roles to a service account, see Manage access to service accounts.
Configuration properties
The following table describes the configuration properties of the For Each Loop task.
| Property | Data type | Description | 
| API Trigger ID | String | Trigger ID of the sub-integration to run. This value is available in the Trigger ID field of the API Trigger in the sub-integration. | 
| Integration name | String | Name of the sub-integration to run. | 
| List to iterate | An array of type Boolean, String, Integer, Double, or JSON. | List of values for which the sub-integration should run. The
     sub-integration runs for each value in the list, one after the other. You can pass the iterated value to the sub-integration by setting the Iteration element sub-integration mapping property. In this property, specify the variable in the sub-integration to which the iterated value must be mapped. | 
| Iteration element sub-integration mapping | N/A | Variable in the sub-integration for which the current iterated element must be assigned. | 
| Map to additional sub-integration input(s) | N/A | Additional values to pass from the current integration to the sub-integration. 
        The values of this property are in the form of key-value pairs, where the key is a variable
      in the current integration, and the value is the corresponding input variable in the
      sub-integration. For example, suppose
  your main integration has the  | 
| Collect values from sub-integration output(s) | N/A | Collate the results of the sub-integration runs. Every time the sub-integration runs,
      you can store the output of the sub-integration in an array variable of the current integration.
        Select the sub-integration's output variable from the Sub-integration output to collect from
   drop-down and the array variable in current integration from the
        Integration variable to collect into drop-down. Each element of the array has the response from a
        particular sub-integration run. For example, if the array variable is  | 
| Response parameter override mapping | N/A | Read the output variable of a sub-integration run and store it in a variable of
    the current integration. Select the sub-integration's output variable from the Sub-integration output to map from drop-down, and select the corresponding variable in the current integration from the Integration variable to override drop-down. You can send the overridden variable in the current integration to the next sub-integration run by mapping the variable in the Map to additional sub-integration input(s) property. As a result, you can cumulatively aggregate the responses from the sub-integration runs. | 
| Loop metadata | JSON array | The output variable that has the execution details of the sub-integrations like sub-integration
     execution ID, errors messages, and variable values passed during execution. Loop metadata contains variables including the following output variables: current_iteration_count,sub_integration_execution_ids,failure_location,current_element,iteration_element, andfailure_message. | 
Examples
The following sections provide detailed examples of how to configure and use the For Each Loop task for specific scenarios. These examples illustrate the configuration steps for different use cases:
- Iterate and pass each element
- Collect sub-integration outputs
- Aggregate results with response override
- Pass additional inputs
Iterate and pass each element
Assume you have a main integration with an array variable named productIds containing values like ["P1", "P2", "P3"]. To call a sub-integration named GetProductDetails for each product ID, configure the For Each Loop task as follows:
- Set List to iterate to productIds.
- Set Iteration element sub-integration mapping to map the current element of productIdsto a variable inGetProductDetails, for example,subIntProductId.
Each execution of GetProductDetails then receives one product ID from productIds.
Collect sub-integration outputs
As in the previous example, assume GetProductDetails returns a JSON object in an output variable called productInfo.
To collect all productInfo outputs from each sub-integration execution and store them as elements in an array variable within the main integration:
- Configure Collect values from sub-integration output(s).
- Select productInfofrom Sub-integration output to collect from.
- Select an array variable in the main integration, for example, allProductDetails, from Integration variable to collect into.
After the loop completes, allProductDetails is an array where each element is the productInfo JSON from one sub-integration execution.
Aggregate results with response override
Assume you have a main integration that calls a sub-integration (for example, GetProductDetails) for each item in a list, and you want to calculate the total price of all items. To sum up a numeric value returned by each sub-integration execution:
- Ensure the sub-integration returns a value in an output variable itemPrice.
- Initialize the totalPricevariable to0in the main integration.
- Configure Response parameter override mapping:
        - Map itemPrice(from sub-integration) tototalPrice(in main integration).
 
- Map 
- In the Map to additional sub-integration input(s) section:
        - Map totalPrice(from main integration) to an input variable in the sub-integration, for example,currentTotal.
 
- Map 
- In the sub-integration's logic, add the current item's price to the currentTotalreceived from the main integration. Then, return this new sum in the output variable nameditemPrice. This process creates a cumulative aggregation.
Pass additional inputs
If your sub-integration GetProductDetails needs a currency code from the main integration, then:
- In the Map to additional sub-integration input(s) section:
        - Map the main integration variable currencyCodeto the sub-integration input variablesubIntCurrency.
 
- Map the main integration variable 
- This currencyCodeis passed to every execution of the sub-integration.
Explore the following sample integrations for practical, step-by-step guides and executable examples of the concepts discussed in the preceding sections:
Best practices
For information about the usage limits that apply to the For Each Loop task, see Usage limits.
Error handling strategy
An error handling strategy for a task specifies the action to take if the task fails due to a temporary error. For information about how to use an error handling strategy, and to know about the different types of error handling strategies, see Error handling strategies.
Quotas and limits
For information about quotas and limits, see Quotas and limits.
What's next
- Learn about all tasks and triggers.
- Learn how to test and publish an integration.
- Learn about error handling.
- Learn about integration execution logs.