The Cursor Scroller can be used with an API which expects the client to maintain a cursor (pointer) to the last obtained item. For example, on the first request, it returns items with ID 1-100; for the second request, you must tell the API to start with ID 101.
The following configuration parameters are supported for the
cursor method of pagination:
idKey(required, string) — path to the key which contains the value of the cursor; the path is entered relative to the exported items.
param(required, string) — name of the query string parameter in which the above cursor value should be sent to the API.
increment(optional, integer) — value by which the cursor value will be incremented/decremented; the default value is
reverse(optional, boolean) — when
true, the cursor is reversed; the default value is
In default mode, Generic Extractor examines the response and finds the maximum value in the
property specified in the
idKey. Then it adds
increment to the value and sends it to the
API in a parameter whose name is in the
param value. If the cursor is set to reverse,
the minimum value of the
idKey is taken. The
increment is added to that value, so it should be probably
set to negative when using
The request parameter specified in the
param configuration overwrites the parameter of the same name defined in the
job parameters. Other job parameters are carried over without modification
(see an example).
The pagination ends when the
dataField of the response contains no items. Because of this, each
run with the
cursor scroller produces a similar warning:
Warning: datafield 'items' contains no data!
This is expected behavior. Common stopping conditions also apply.
This section contains two API pagination examples where the Cursor Scroller is used.
Let’s say you have an API which has an endpoint
/users returning the following response:
For the next page of results, the API requires you to send a request to
/users?continueAfter=456. The following
configuration handles the case:
Notice that the
idKey parameter is relative to the extracted array of items (
fields.id and not
See example [EX060].
Some APIs return items starting with the newest item and therefore need to be queried for offset in
reverse order. Let’s say a request to
/users?startWith=last will produce:
To retrieve the next set of results, send a request to
GET /users?startWith=344 — i.e. with the
ID lower than the lowest one already retrieved. The following configuration does exactly that:
The important part is
"reverse": true which causes Generic Extractor to look for the lowest value of the
property specified in
idKey (user id). Another important part —
"increment": -1 causes ID to be lowered
by 1 between the requests. Also notice that the initial value of the API parameter
startWith is specified
jobs.params configuration and it is overridden by the scroller in the subsequent requests.
See example [EX061].