This endpoint alerts Prebid Server to process the event and informing the analytics adapter.
Query Parameter | Required? | Description |
---|---|---|
a | y | Account ID |
t | y | Type of the event. Allowed values: win or imp |
b | y | Bid ID, expected to be unique so this event can be joined to the auction analytics. |
bidder | y | Bidder code |
f | n | Format of the PBS response. Values: b is blank, just return HTTP 200 with an empty body. i is image, return HTTP 200 with a blank PNG body |
ts | n | Auction timestamp |
x | n | Disables or enables analytics. Allowed values: 1 to enable analytics or 0 to disable. 1 is default. |
GET https://prebid.site.com/event?t=win&b=1234567890&bidder=rubicon&f=i
POST /vtrack
This is an endpoint similar to the Prebid Cache /cache endpoint, but PBS adds an Impression
tag to the supplied VAST.
It’s implemented in Prebid Server and not Prebid Cache in order to keep the latter simple.
This endpoint was developed for the use case where client-side adapters return VAST and the publisher’s Prebid Server is doing analytics for video impressions. Originally this was the only reliable way to measure imps for video.
This is the Prebid.js setConfig({cache}) call:
pbjs.setConfig({
cache: {
url: "https://PBS_HOST/vtrack?a=ACCOUNT",
vasttrack: true
}
});
Adds one or more blocks of XML to Prebid Cache after adding an Impression
object to one or more supplied VAST creatives.
<Impression>
tags, don’t modify.<Impression>
tag after the last existing <Impression>
tag.The PBS <Impression>
tag looks like:
<Impression>
<![CDATA[https://PBS_HOST/event?t=imp&b=BIDID&a=ACCOUNT&aid=AUCTIONID&ts=TIMESTAMP&bidder=BIDDER&f=b]]>
</Impression>
Parameter | Location | Type | Scope | Description | Default |
a | query string | string | required | account ID | none |
bidid | POST | string | required | bidId is copied to the /event URL in the ‘b’ param | none |
bidder | POST | string | required | copied to the /event URL in the ‘bidder’ param | none |
type | POST | string | required | must be “xml” | none |
value | POST | string | required | the VAST XML body | none |
aid | POST | string | required | auction ID is copied to the /event URL in the ‘aid’ param | none |
timestamp | POST | string | required | copied to the /event URL in the ‘ts’ param | none |
ttlseconds | POST | string | required | overrides the default number of seconds to keep in PBC | none |
POST URL:
https://PBS_HOST/vtrack?a=1001
POST body:
{"puts":[{
"bidid": "11111",
"aid": "22222",
"bidder": "bidderA",
"timestamp": 123456789,
"type":"xml",
"value":"<?xml version=\"1.0\" encoding=\"UTF-8\"?><VAST version=\"4.0\"> ... </VAST>",
"ttlseconds":3600
},{
"bidid": "33333",
"aid": "44444",
"bidder": "bidderB",
"timestamp": 123456789,
"type":"xml",
"value":"<?xml version=\"1.0\" encoding=\"UTF-8\"?><VAST version=\"4.0\"> ... </VAST>",
"ttlseconds":3600
}]}
The response to the client is JSON containing the cache UUIDs that can be used to retrieve the item:
{
"responses": [
{"uuid": "279971e4-70f0-4b18-bd65-5c6e7aa75d40"},
{"uuid": "147c9934-894b-4c1f-9a32-e7bb9cd15376"}
]
}
POST
malformed XML, they’ll GET
a bad response too.