📖Pagination v1 (Old)
👋 Just a quick note before we begin
In the process of creating Saloon's next major version, version three, a new pagination plugin was developed. The new pagination plugin has been redesigned to be more convenient for developers, and easier to implement and maintain. If you have not used Saloon's pagination feature before, it is recommended that you begin with the Pagination v2 (Plugin) rather than the built-in pagination. The built-in pagination has been removed from v3, so it is advisable to switch to the plugin version to avoid further upgrades when migrating to Saloon v3.
If you are currently using version two's pagination, it is recommended to follow the new documentation and rebuild your paginators. Click here to get started.
Introduction
Most APIs you will integrate with will implement some sort of pagination for their records. Traditionally, traversing through many pages of results can be time-consuming and slow to build. Saloon helps to solve this problem with its pre-build paginators that can be used to iterate through hundreds of pages of results in a fast, beautiful way.
Saloon's paginators provide many ways to iterate over responses and even iterate through the results within a response, like the example above. This is incredible because you can retrieve all of the results at once instead of having to write logic to build up an array of results.
Saloon uses a custom-built iterator behind the scenes so memory usage is low and it's incredibly fast to iterate through hundreds of pages, especially when you combine it with asynchronous requests/pooling.
You can see the above example fully in the Saloon Spotify Example Repository
Saloon's pagination currently only works with JSON APIs
Supported Pagination Methods
Saloon has support for the three most common types of pagination. You should use the one that is used by the API you are integrating with. You can typically determine this from the query parameters that are provided.
Paged Pagination (?page=1)
Limit / Offset Pagination (?limit=100&offset=0)
Cursor Pagination (?cursor=string)
Getting Started
Before you get started, make sure that the request you are going to paginate through works as expected. Make the request like you normally would and read the JSON response output. Take note of the pagination properties like the "next_page_url", the "results" count, and the "limit" and "offset" variables. You will need these to configure the paginator. It's recommended you use a tool like Postman or Saloon in a test to see what the response looks like.
Once you have recorded an example response, go to your connector and add the HasPagination
interface. Next, you should define the paginate
method which accepts a Request
and additional arguments.
Next, you need to configure a paginator to use. By default, each paginator has its own assumptions for query parameters and response body arguments for the data. You should customise those to suit the API you are integrating with.
The PagedPaginator requires you to define the request and the per-page/limit. This is required to calculate how many pages the Paginator needs to iterate through. For example, the API may only allow me to paginate over a maximum of 50 results.
Defaults
The PagedPaginator
has assumed the following items are present in your API:
The per-page query parameter is called
limit
The page query parameter is called
page
The next page URL is called
next_page_url
in the response.The results count is called
total
The first page is zero
Configuring the PagedPaginator
To configure the PagedPaginator
you can use the following methods
Iterating over responses and results
Now you have tested your request and configured the paginator, you're ready to give it for a spin! Saloon's paginators have many different ways to iterate over the results. The simplest way is using a foreach loop, however, you can use Laravel's Collections which helps you map and filter results really easily.
Foreach Loop
This is the simplest way to iterate over results. When you pass the paginator inside of a for-loop you will get each response.
Collection
The collect
method requires Laravel's illuminate/collections
package.
Similar to a for-loop, you can use a collection to wrap around the results.
By default, Saloon's collect method will return a LazyCollection to be as memory efficient as possible. You may choose to use the lazy: false
argument.
You may choose to iterate over the results inside of the collection instead of the responses. If you would like to do this, provide the JSON key of the results...
When you provide a key to the collect
method, Saloon will automatically collapse the collection. This means it reduces it to individual items. If this causes unexpected behaviour, you can disable collapsing with collapse: false
.
JSON method
The JSON method allows you to iterate over the internal results of the paginator, like iterating over each of the tracks in the Spotify request. Just pass in the JSON property of the results.
Asynchronous requests and pooling
Saloon also supports asynchronous requests and request concurrency/pooling with paginators. This is really exciting because you can make hundreds of API calls in a fraction of the time compared to sending normally. If you are unsure of how Saloon handles request concurrency, read here.
To use asynchronous requests/pooling, Saloon requires the API to return the "count" or "results" of the API. This is because asynchronous requests are not sent right away, Saloon does not know when to stop sending requests.
Asynchronous Requests
You may send requests asynchronously with the paginator by using the async
method. When this is enabled, every response will be an instance of PromiseInterface
.
Request Concurrency/Pooling
You may also use pools with the paginator. This allows you to send requests concurrently. You should provide the concurrency integer and the response handler.
Click here to read more about request concurrency/pools.
Last updated