Iterator lets you loop through an array of records and perform actions on each one. It’s essential for workflows that need to process multiple records returned by Search Records or received via webhooks.
Iterator is currently in beta. Activate it under Settings → Releases → Lab.
When to Use Iterator
| Scenario | Příklad |
|---|
| Process search results | Send email to each person found |
| Handle webhook arrays | Create records for each item in order |
| Bulk updates | Update multiple records with calculated values |
| Notifications | Alert multiple people about an event |
Understanding Iterator
Iterator expects an array as input. It then:
- Takes the first item from the array
- Runs all actions inside the iterator with that item
- Moves to the next item
- Repeats until all items are processed
Basic Setup
Example: Email Everyone in Search Results
Goal: Find all contacts in a specific company and send each one a personalized email.
Step 1: Search for Records
- Add Search Records action
- Object: People
- Filter: Company equals “Acme Inc”
- This returns an array of people
Step 2: Check Results Exist
- Add Filter action
- Condition:
{{searchRecords.length}} is greater than 0
- This prevents Iterator errors on empty results
Step 3: Add Iterator
- Add Iterator action
- Array input: Select
{{searchRecords}}
- This creates a loop
Step 4: Add Actions Inside Iterator
Actions placed after Iterator run for each item:
- Add Send Email action (inside iterator)
- To:
{{iterator.currentItem.email}}
- Subject: Hello
{{iterator.currentItem.firstName}}!
- Body: Personalized message using current item fields
Výsledek
If Search Records returns 5 people, the Iterator:
- Sends email to person 1
- Sends email to person 2
- … continues for all 5
Accessing Current Item Data
Inside Iterator, use {{iterator.currentItem}} to access the current record:
| Variable | Popis |
|---|
{{iterator.currentItem}} | The entire current record object |
{{iterator.currentItem.id}} | Record ID |
{{iterator.currentItem.email}} | Email field |
{{iterator.currentItem.company.name}} | Related company name |
{{iterator.index}} | Current position in array (0-based) |
Common Patterns
Update Multiple Records
Goal: Mark all overdue tasks as “Late”
1. Search Records (Tasks, Due Date < Today, Status ≠ Completed)
2. Filter (length > 0)
3. Iterator (searchRecords)
└── Update Record
- Object: Tasks
- Record: {{iterator.currentItem.id}}
- Status: Late
Create Records from Array
Goal: Webhook receives order with multiple items, create a record for each
1. Webhook Trigger (receives items array)
2. Filter (items.length > 0)
3. Iterator (trigger.body.items)
└── Create Record
- Object: Order Items
- Name: {{iterator.currentItem.name}}
- Quantity: {{iterator.currentItem.qty}}
- Related Order: {{trigger.body.orderId}}
Conditional Processing Inside Loop
Goal: Only send email to contacts with valid emails
1. Search Records (People)
2. Iterator (searchRecords)
└── Filter (currentItem.email is not empty)
└── Send Email
- To: {{iterator.currentItem.email}}
Řešení potíží
”Iterator expects an array”
Cause: You passed a single record instead of an array.
Fix: Make sure you’re passing the result of Search Records or an array field, not a single record.
✅ Correct: {{searchRecords}}
❌ Wrong: {{searchRecords[0]}}
Iterator Doesn’t Run
Cause: The array is empty.
Fix: Add a Filter before Iterator to check array length:
Filter: {{searchRecords.length}} > 0
Actions Run Too Many Times
Cause: Search Records returned more records than expected.
Fix:
- Add more specific filters to Search Records
- Set a limit on Search Records (max 200)
- Add Filter inside Iterator for additional conditions
- Credit usage: Each iteration consumes credits for its actions
- Time: Large arrays take longer to process
- Limits: Consider batching very large operations
- Rate limits: External API calls may hit rate limits with many iterations
Osvědčené postupy
- Always check array length before Iterator to avoid errors
- Add filters inside loops when not all items need processing
- Rename your Iterator step to describe what it’s looping through
- Test with small arrays before processing large datasets
- Monitor workflow runs to ensure iterations complete as expected