Commit 1a6e58aa authored by Mike Jang's avatar Mike Jang

Merge branch...

Merge branch '243796-graphql-add-external-implementation-documentation-for-keyset-cursor-pagination' into 'master'

GraphQL: Add external implementation documentation for keyset / cursor pagination

See merge request gitlab-org/gitlab!45618
parents 4c18dcf5 34826232
...@@ -234,6 +234,23 @@ instead of an `ActiveRecord::Relation`: ...@@ -234,6 +234,23 @@ instead of an `ActiveRecord::Relation`:
<!-- ### External pagination --> <!-- ### External pagination -->
### External pagination
There may be times where you need to return data through the GitLab API that is stored in
another system. In these cases you may have to paginate a third-party's API.
An example of this is with our [Error Tracking](../../operations/error_tracking.md) implementation,
where we proxy [Sentry errors](../../operations/error_tracking.md#sentry-error-tracking) through
the GitLab API. We do this by calling the Sentry API which enforces its own pagination rules.
This means we cannot access the collection within GitLab to perform our own custom pagination.
For consistency, we manually set the pagination cursors based on values returned by the external API, using `Gitlab::Graphql::ExternallyPaginatedArray.new(previous_cursor, next_cursor, *items)`.
You can see an example implementation in the following files:
- [`types/error__tracking/sentry_error_collection_type.rb`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/app/graphql/types/error_tracking/sentry_error_collection_type.rb) which adds an extension to `field :errors`.
- [`resolvers/error_tracking/sentry_errors_resolver.rb`](https://gitlab.com/gitlab-org/gitlab/blob/master/app/graphql/resolvers/error_tracking/sentry_errors_resolver.rb) which returns the data from the resolver.
## Testing ## Testing
Any GraphQL field that supports pagination and sorting should be tested Any GraphQL field that supports pagination and sorting should be tested
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment