Report events
Use the /events
endpoint to report user interactions and activity in on a marketplace:
- Impressions — a user viewed an asset.
- Clicks — a user clicked on an asset.
- Purchases — a user created an order.
Interactions require either a resolvedBidId
from the /v2/auctions
response or an entity
that describes
the entity to attribute.
Authorizations
Bearer authentication header of the form Bearer <token>
, where <token>
is your auth token.
Body
The marketplace's unique ID for the click. This field ensures the event reporting is idempotent in case there is a network issue and the request is retried. If there is no click model on the marketplace side, generate a unique string that does not change if the event is resent.
1
RFC3339 formatted timestamp including UTC offset.
The opaque user ID is an anonymized unique identifier that maps to the original user ID without revealing the original value. This identifier allows Topsort to correlate user activity between auctions and user interactions, independent of the user's logged-in status. For apps or sites where users might interact while logged out, we recommend generating a random identifier (UUIDv7) on the first load, storing it on local storage (cookie, local storage, etc), and letting it live for at least a year. Otherwise, if your users are always logged in for interactions, you may use a hash of your customer ID. Correct purchase attribution requires long-lived opaque user IDs consistent between auction and event requests.
If the marketplace wants to attribute a click to an additional entity, they can use the additionalAttribution
field. When using this field, the resolvedBidId
must also exist in the event body.
Entity
is meant for reporting organic events, not sponsored or promoted products. It refers to the object involved in the organic interaction. But, in most cases, you won't need to fill in this object. Be aware that if resolvedBidId
has any value, entity
will be disregarded.
URL path of the page triggering the event.
For web apps, this can be obtained in JS using window.location.pathname
.
For mobile apps, use the deep link for the current view, if available.
Otherwise, encode the view from which the event occurred in your app as a path-like string (e.g. /root/categories/:categoryId
).
1
An array of IDs of the categories associated to the page in which this event occurred, if applicable. These IDs must match the IDs provided through the catalog service.
For paginated pages, this should indicate which page number triggered the event.
x > 1
For paginated pages this should indicate how many items are in each result page.
x > 1
For components with multiple items (i.e. search results, similar products, etc), this should indicate the index of a given item within that list.
x > 1
The ID of the product associated to the page in which this event occurred, if applicable. This ID must match the ID provided through the catalog service.
1
The search string provided by the user in the page where this event occurred, if applicable. This search string must match the searchQuery field that was provided in the auction request (if provided).
1
If the click is over an ad promotion, this is the resolvedBidId
field received from the /auctions
request. In most situations, especially when reporting a sponsored interaction, you'll want to fill in this field.
The marketplace's unique ID for the impression. This field ensures the event reporting is idempotent in case there is a network issue and the request is retried. If there is no impression model on the marketplace side, generate a unique string that does not change if the event is resent.
1
RFC3339 formatted timestamp including UTC offset.
The opaque user ID is an anonymized unique identifier that maps to the original user ID without revealing the original value. This identifier allows Topsort to correlate user activity between auctions and user interactions, independent of the user's logged-in status. For apps or sites where users might interact while logged out, we recommend generating a random identifier (UUIDv7) on the first load, storing it on local storage (cookie, local storage, etc), and letting it live for at least a year. Otherwise, if your users are always logged in for interactions, you may use a hash of your customer ID. Correct purchase attribution requires long-lived opaque user IDs consistent between auction and event requests.
If the marketplace wants to attribute an impression to an additional entity, they can use the additionalAttribution
field. When using this field, the resolvedBidId
must also exist in the event body.
Entity
is meant for reporting organic events, not sponsored or promoted products. It refers to the object involved in the organic interaction. But, in most cases, you won't need to fill in this object. Be aware that if resolvedBidId
has any value, entity
will be disregarded.
URL path of the page triggering the event.
For web apps, this can be obtained in JS using window.location.pathname
.
For mobile apps, use the deep link for the current view, if available.
Otherwise, encode the view from which the event occurred in your app as a path-like string (e.g. /root/categories/:categoryId
).
1
An array of IDs of the categories associated to the page in which this event occurred, if applicable. These IDs must match the IDs provided through the catalog service.
For paginated pages, this should indicate which page number triggered the event.
x > 1
For paginated pages this should indicate how many items are in each result page.
x > 1
For components with multiple items (i.e. search results, similar products, etc), this should indicate the index of a given item within that list.
x > 1
The ID of the product associated to the page in which this event occurred, if applicable. This ID must match the ID provided through the catalog service.
1
The search string provided by the user in the page where this event occurred, if applicable. This search string must match the searchQuery field that was provided in the auction request (if provided).
1
If the impression is over an ad promotion, this is the resolvedBidId
field received from the /auctions
request. In most situations, especially when reporting a sponsored interaction, you'll want to fill in this field.
The marketplace unique ID for the order. This field ensures the event reporting is idempotent in case there is a network issue and the request is retried. If there is no unique ID for orders on the marketplace side, generate a unique string that does not change if the event needs to be resent.
1
Items purchased.
The marketplace ID of the product being purchased.
1
The price of a single item in the marketplace currency.
x > 0
Count of products purchased.
x > 1
The vendor ID of the product being purchased. This field is optional and should be filled in if a product is sold by multiple vendors.
1
RFC3339 formatted timestamp, including UTC offset, of the instant in which the order was placed. Please note that purchases will NOT be attributed to an auction that happened after.
The opaque user ID is an anonymized unique identifier that maps to the original user ID without revealing the original value. This identifier allows Topsort to correlate user activity between auctions and user interactions, independent of the user's logged-in status. For apps or sites where users might interact while logged out, we recommend generating a random identifier (UUIDv7) on the first load, storing it on local storage (cookie, local storage, etc), and letting it live for at least a year. Otherwise, if your users are always logged in for interactions, you may use a hash of your customer ID. Correct purchase attribution requires long-lived opaque user IDs consistent between auction and event requests.