Skip to content

bramkn/n8n-nodes-iterator

Repository files navigation

Banner image

n8n-nodes-iterator

The iterator node can be used for paging HTTP requests. There is 2 main options for this.

Developer

Hi,

My name is Bram and I am the developer of this node. I am an independant consultant and expert partner of n8n. My nodes are free to use for everyone, but please consider donating when you use my nodes. This helps me to build and maintain nodes for everyone to use.

If you are looking for some outside help with n8n, I can of course also offer my services.

  • Node Development
  • Workflow Development
  • Mentoring
  • Support

Please contact me @ bram@knitco.nl if you want to make use of my services.

For questions or issues with nodes, please open an issue on Github.

Usage

The node can be a fit funky to setup some times, this because of the flexibility of it. If you cannot figure it out or have questions please open a topic on the n8n community for help.

Reference Next

This can be used if the API has a response which also tells you what the next page is. It can also be used with APIs which only give a "next cursor" for example, you will simply need to use that as part of the string in an expression.

Next

You can use the "currentReference" as the value in the HTTP node. So in this case it is the full URL. currentRef

This will automatically be filled with the correct value, when you setup the Iterator node correctly. The Reference Start is the first page it needs to retrieve.

setupNext

An expression is used in the Reference Next, to get the next page for every iteration: httpNext

When there is no next page left it will end the loop.

Auto Increment

The auto increment is for manual iteration through the different pages. This is usually simply a page number so from 1,2,3 etc. But it can also be an offset that needs to be set.

  • If it is normal pages, set the increment size to 1 to retrieve all pages.
  • If the API is using an offset set it to the size of the page to let it loop through all pages.

increment

The "Expected Item Count" is used to make sure it will stop at some point. This is the page size you need to fill in here. Whenever you are getting les records than the pagesize it will end the loop. The default value is 50, so if no value is set it will stop when less than 50 are returned.

The HTTP node will look something like this for this example:

incrementHTTP

currentIncrement

General options and (hidden)features

options

  • Option Combine: This boolean will determine if the iterated output will be combined in the end.

  • Option Limit: The limit will limit the amount of records returned in the end. This is especially useful when the Combine boolean is set to true.

  • Option Is There Another Page: This is a boolean which can be set to end the loop when ever you need it to. This can be set with an expression to have complete control over the ending of the loop. Can also be used if an API does not have the next reference but does have a flag telling you it the last page, or if you want to use the count of all record to let it decide when to stop.

  • only 1 item is send into the loop to make sure you are not accidentally querying an API multiple times with the same request. This will always be the last item. When the Loop ends, the Done path will contain the items of the last iteration or the combined set of items.

Installation

Follow the installation guide in the n8n community nodes documentation.

Compatibility

This node was developed and tested in version 0.193.3.

Resources

License

MIT

About

No description, website, or topics provided.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published