Event polling has two primary uses:
- Paging through historical events.If you need to backfill a webhook subscription or reprocess missed events, we strongly recommend using our event replay functionality instead. This reduces the complexity of your integration; the SEEK API will take care of requeuing each event in scope, and your webhook endpoint will process a replayed event as it would any other event.If you want to interactively explore historical events you can use the Developer Dashboard’s events page .
- Event delivery for partners without the capability to consume webhooks.
Both flows use the
events
query for cursor-based pagination through events.The
events
query supports filtering on scheme ID, event types and an optional date range.
You can implement more sophisticated event categorisation or filtering within your polling software.
For example, you might select the CandidateProfile.associatedPositionProfile
from a CandidateApplicationCreated
event to identify the associated position and hirer.To avoid wasted resources from repeatedly polling each hirer, filtering events by hirer ID is intentionally unsupported.
As an alternative you can use webhooks to deliver events to hirer-specific HTTPS endpoints.
If you use webhook subscriptions,
we strongly recommend using our event replay functionality instead.
This section remains as a reference for integrations that use polling-based event delivery.
This flow is based on paging through events within a specific time range:
- For processing missed or failed events you can specify the
afterDateTime
andbeforeDateTime
of the affected period. - For backfilling events for a webhook subscription you can specify just the
beforeDateTime
of when the subscription was created.
You then repeatedly use the
events
query with the determined afterDateTime
and beforeDateTime
arguments.
The initial query should pass after: null
to get the first page.For example, this queries the first page of 25
CandidateApplicationCreated
events between April 10th and 20th 2020:query (
$after: String
$filter: EventsFilterInput!
$first: Int!
$schemeId: String!
) {
events(after: $after, filter: $filter, first: $first, schemeId: $schemeId) {
edges {
node {
typeCode
... on CandidateApplicationCreatedEvent {
candidate {
person {
name {
formattedName
}
}
}
candidateApplicationProfile {
associatedPositionProfile {
positionUri
}
}
}
}
}
pageInfo {
hasNextPage
endCursor
}
}
}
For subsequent queries you pass the previous page’s
endCursor
as the after
argument.
Once hasNextPage
is false
there are no more events in the time range and the process is complete.Events will remain for 90 days after they occur.
Your software must store any data that it needs to access after the 90 day period.
In this flow the
events
query is used with the previous poll’s endCursor
as its after
argument.
The cursor is persisted by your software to resume event polling from the last processed event.
If it’s difficult to persist the cursor you can instead use webhooks to receive events statelessly.For accurate paging only the
after
argument should be used;
you should not specify an afterDateTime
or beforeDateTime
.
This ensures that polling will resume from the last successful poll in the event of a failure.For example, this queries for a page of 25
CandidateApplicationCreated
events since the previous cursor:query (
$after: String!
$filter: EventsFilterInput!
$first: Int!
$schemeId: String!
) {
events(after: $after, filter: $filter, first: $first, schemeId: $schemeId) {
edges {
node {
typeCode
... on CandidateApplicationCreatedEvent {
candidate {
person {
name {
formattedName
}
}
}
candidateApplicationProfile {
associatedPositionProfile {
positionUri
}
}
}
}
}
pageInfo {
hasNextPage
endCursor
}
}
}
To process all new events the
events
query should be repeated until hasNextPage
is false
.Once the last page of events has been reached you should not poll again for at least 15 minutes.
If you’re polling multiple event streams you must not exceed one
events
query per minute across your entire SEEK API integration.
This is a global limit applied across all of your servers, hirers and webhook subscriptions.If near real-time event delivery is required then webhooks can be used instead.
See “why webhooks” for an explanation of why frequent polling is harmful.
The
events
query can be used in tandem with filter.subscriptionId
to obtain an ad-hoc historical view of the events associated with a particular subscription.
This can help you to discover that historical events are missing or unprocessed,
which you can subsequently remediate by triggering a replay.
We recommend the Developer Dashboard’s webhooks page for ad-hoc troubleshooting of this nature.Polling implementations are approved on a case-by-case basis and are mandated to operate at a partner level.
Your production environment must not implement event delivery by polling subscription-scoped event streams.
This limitation ensures that the SEEK API can maintain its quality of service and operating costs as partner usage and webhook subscriptions scale over time.