mirror of
https://github.com/prebid/openrtb.git
synced 2026-06-15 22:46:34 +03:00
4574bb1724
http://www.iab.com/wp-content/uploads/2016/03/OpenRTB-API-Specification-Version-2-5-FINAL.pdf Squashed commit of the following: commit 40ffaaa76654096ff0a91101421cc36d54ef5968 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 25 12:01:12 2017 +0300 README: slight cosmetics commit 5eb0358060f355dd120f66912de1e1b93f0f8772 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 25 12:00:09 2017 +0300 README: preparing for release commit d62bda4a2d03462ed2b65a2f2600d13c88a43009 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 25 11:59:23 2017 +0300 README: review done commit 7ba05ea615088fd6f284f1a9964291600bfa0b5c Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 25 11:57:23 2017 +0300 Review: added missing Audio.stitched property commit be722248b554647522ce460fca2059d34def1dd8 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 16:15:35 2017 +0300 Travis: actually, better stick with 1.9 betas commit d0b0c16a4539cc3bcc2bcbfd8946820788f05023 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 16:14:16 2017 +0300 Travis: master builds till 1.9 is out commit 62635330272d14300a4240de984c45337680af65 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 16:11:07 2017 +0300 Travis: try Go 1.9beta1 commit 23e97c18636669930da5dbfe516faf29ed3a70a8 Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 16:06:18 2017 +0300 Travis commit d5c7d013c510ce3220a8ba8cd0d355ec5765491d Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 15:57:08 2017 +0300 README: v4.0.0 release date commit 14d8158820032b11822f3b2cd981c16f5ccf2dfa Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 15:55:55 2017 +0300 Copied examples from OpenRTB 2.5, reformatted commit e1fc9ebdc8a44d93b5aa48f7e61a7c9fdcdcc3dd Author: Max Cherry <mxmCherry@gmail.com> Date: Sun Jun 18 15:30:22 2017 +0300 README - TODOs commit 0d014dea1020f02db82488a848bdbbf8fadcdc52 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:45:01 2017 +0300 README commit 0d43a00d827670d39d83dfdab556a4153dfba1bb Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:43:15 2017 +0300 More README cosmetics commit ce476e32eff212079e3732a5ec316beb7fe9790d Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:42:38 2017 +0300 README cosmetics commit 8a78e95b19f31be264222e917c5672a8740d6475 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:41:56 2017 +0300 Minor renames commit de717476525c2f91cdd7bcd11c292161f605c28d Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:41:33 2017 +0300 Minor comment fix commit dc35a1d7bac2c8c26bf1e3d04c898ba7cab2ba96 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:41:08 2017 +0300 No more OpenRTB 2.3 references commit 38de47098f2a57a93015ca71264afaa02d11d64b Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:39:28 2017 +0300 More README improvs, switch everything to OpenRTB 2.5 commit a739f31497a24467900af2980859c7c6ebcdd457 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:36:11 2017 +0300 AT - use int64; rewrite README - stricter numeric types usage + drop gopkg.in, recommend package manager commit 56adc1a89d74ccf30df1acea40b298395cd10dbf Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:10:57 2017 +0300 AuctionType - uint64, can be > 500 commit da45c3e8995152d06e777ed8bfc3ef83493633a6 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:04:00 2017 +0300 README: more TODOs commit 931a2b07a693104a3387d6558d56ef996bb82dba Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 17:00:41 2017 +0300 Make sure everything time-related is int64 commit 720c1ce0b5aa48af58c7306c9f7369d60a2865fc Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:46:12 2017 +0300 README: more TODOs - copy more recent tests commit b658fab7365772f2ba3a9ee55ba1616f842732b1 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:44:56 2017 +0300 More TODO commit e5185fa5dc6958cbc5f49d5d9bb61b568da5e1f4 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:43:10 2017 +0300 Reviewed time/duration attributes - to use int64 commit cbb560af3063d10a95b5a26230b26ee25918dcfd Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:37:08 2017 +0300 README: Current TODO commit b7d3f701884892a3e667b3f8c26ca7e2fbeb46bf Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:35:54 2017 +0300 OpenRTB 2.5: Video commit 8d4824b8b8005fe8d67133493dd0b393a7416945 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:26:10 2017 +0300 OpenRTB 2.5: Native commit d40367062fe4f4009bea0697dc2a77a7549b03f4 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:23:51 2017 +0300 OpenRTB 2.5: Banner commit 18962c3c1ebdfc604ae564808ef4141d67fd90ed Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:16:42 2017 +0300 OpenRTB 2.5: Content commit 58a840d97f7e16a447c065b5b7465367459baf0f Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:07:35 2017 +0300 OpenRTB 2.5: Device commit 4a072229b874a93922eabfd003148b6186c2f1d4 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 14:00:51 2017 +0300 OpenRTB 2.5: Geo commit 41d50bc6d2b760daecdb2296ad83bf4750a39ca6 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 13:55:28 2017 +0300 OpenRTB 2.5: Bid commit f20f2a038580abe7a47d0285430140147af9bc38 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 13:41:50 2017 +0300 OpenRTB 2.5: SeatBid commit cfd46a38a7f330853fd07e5fe5bf87c8aedc82f2 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 13:40:40 2017 +0300 OpenRTB 2.5: BidResponse commit 8c165bb20ba9ff4bf237d5cf89a74db05495378a Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 13:38:44 2017 +0300 OpenRTB 2.5: Segment commit 610a4ee4a799934bba1d5678b3acebfae6390cd2 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 13:37:44 2017 +0300 OpenRTB 2.5: Data commit ac37bd4310a12c6e8311a62591cd8059c55e6390 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:47:52 2017 +0300 OpenRTB 2.5: User commit 8a63daa5d6caea5677b7df304f40fd83c073bc9d Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:44:06 2017 +0300 OpenRTB 2.5: Producer commit 8ad8a1880b970044d3312efa0482b9136fab2abf Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:42:54 2017 +0300 OpenRTB 2.5: Publisher commit 59c859c7249238c56a571183376aadd1adbe8394 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:41:39 2017 +0300 OpenRTB 2.5: App commit 14756ddf66fd0fc42d89ddaa521cd6054c39bd21 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:39:10 2017 +0300 OpenRTB 2.5: Site commit 9bbb35253de1d1df21165b8d320c2bebfbc01542 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:36:25 2017 +0300 OpenRTB 2.5: Deal commit 8f88319a83b472c92f3ddc13fa2dabc9c7319c4c Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:33:41 2017 +0300 OpenRTB 2.5: PMP commit 3be39a13e1c480b1ca1462a526d9e041631773a9 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:31:43 2017 +0300 OpenRTB 2.5: Imp, Audio commit 36c9487ad5255dbd027e10b7379663e643b2b50c Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:12:32 2017 +0300 Added OpenRTB 2.5 Metric and Format objects commit e1205cf8701e91c782e3397e8f780be872544780 Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:04:25 2017 +0300 README update commit 325778b755bc9e3ba084a726dae5e9c622c1f2fc Author: Max Cherry <mxmCherry@gmail.com> Date: Sat Jun 17 12:03:33 2017 +0300 Started working on OpenRTB 2.5 compliance - BidRequest, Source, Regs updated
182 lines
5.1 KiB
Go
182 lines
5.1 KiB
Go
package openrtb
|
|
|
|
// 3.2.4 Object: Imp
|
|
//
|
|
// This object describes an ad placement or impression being auctioned. A single bid request can include
|
|
// multiple Imp objects, a use case for which might be an exchange that supports selling all ad positions on
|
|
// a given page. Each Imp object has a required ID so that bids can reference them individually.
|
|
//
|
|
// The presence of Banner (Section 3.2.6), Video (Section 3.2.7), and/or Native (Section 3.2.9) objects
|
|
// subordinate to the Imp object indicates the type of impression being offered. The publisher can choose
|
|
// one such type which is the typical case or mix them at their discretion. However, any given bid for the
|
|
// impression must conform to one of the offered types.
|
|
type Imp struct {
|
|
|
|
// Attribute:
|
|
// id
|
|
// Type:
|
|
// string; required
|
|
// Description:
|
|
// A unique identifier for this impression within the context of
|
|
// the bid request (typically, starts with 1 and increments.
|
|
ID string `json:"id"`
|
|
|
|
// Attribute:
|
|
// metric
|
|
// Type:
|
|
// object array
|
|
// Description:
|
|
// An array of Metric object (Section 3.2.5).
|
|
Metric []Metric `json:"metric,omitempty"`
|
|
|
|
// Attribute:
|
|
// banner
|
|
// Type:
|
|
// object
|
|
// Description:
|
|
// A Banner object (Section 3.2.6); required if this impression is
|
|
// offered as a banner ad opportunity.
|
|
Banner *Banner `json:"banner,omitempty"`
|
|
|
|
// Attribute:
|
|
// video
|
|
// Type:
|
|
// object
|
|
// Description:
|
|
// A Video object (Section 3.2.7); required if this impression is
|
|
// offered as a video ad opportunity.
|
|
Video *Video `json:"video,omitempty"`
|
|
|
|
// Attribute:
|
|
// audio
|
|
// Type:
|
|
// object
|
|
// Description:
|
|
// An Audio object (Section 3.2.8); required if this impression is
|
|
// offered as an audio ad opportunity.
|
|
Audio *Audio `json:"audio,omitempty"`
|
|
|
|
// Attribute:
|
|
// native
|
|
// Type:
|
|
// object
|
|
// Description:
|
|
// A Native object (Section 3.2.9); required if this impression is
|
|
// offered as a native ad opportunity.
|
|
Native *Native `json:"native,omitempty"`
|
|
|
|
// Attribute:
|
|
// pmp
|
|
// Type:
|
|
// object
|
|
// Description:
|
|
// A Pmp object (Section 3.2.11) containing any private
|
|
// marketplace deals in effect for this impression.
|
|
PMP *PMP `json:"pmp,omitempty"`
|
|
|
|
// Attribute:
|
|
// displaymanager
|
|
// Type:
|
|
// string
|
|
// Description:
|
|
// Name of ad mediation partner, SDK technology, or player
|
|
// responsible for rendering ad (typically video or mobile). Used
|
|
// by some ad servers to customize ad code by partner.
|
|
// Recommended for video and/or apps.
|
|
DisplayManager string `json:"displaymanager,omitempty"`
|
|
|
|
// Attribute:
|
|
// displaymanagerver
|
|
// Type:
|
|
// string
|
|
// Description:
|
|
// Version of ad mediation partner, SDK technology, or player
|
|
// responsible for rendering ad (typically video or mobile). Used
|
|
// by some ad servers to customize ad code by partner.
|
|
// Recommended for video and/or apps.
|
|
DisplayManagerVer string `json:"displaymanagerver,omitempty"`
|
|
|
|
// Attribute:
|
|
// instl
|
|
// Type:
|
|
// int; default 0
|
|
// Description:
|
|
// 1 = the ad is interstitial or full screen, 0 = not interstitial.
|
|
Instl int8 `json:"instl,omitempty"`
|
|
|
|
// Attribute:
|
|
// tagid
|
|
// Type:
|
|
// string
|
|
// Description:
|
|
// Identifier for specific ad placement or ad tag that was used to
|
|
// initiate the auction. This can be useful for debugging of any
|
|
// issues, or for optimization by the buyer.
|
|
TagID string `json:"tagid,omitempty"`
|
|
|
|
// Attribute:
|
|
// bidfloor
|
|
// Type:
|
|
// float; default 0
|
|
// Description:
|
|
// Minimum bid for this impression expressed in CPM.
|
|
BidFloor float64 `json:"bidfloor,omitempty"`
|
|
|
|
// Attribute:
|
|
// bidfloorcur
|
|
// Type:
|
|
// string; default “USD”
|
|
// Description:
|
|
// Currency specified using ISO-4217 alpha codes. This may be
|
|
// different from bid currency returned by bidder if this is
|
|
// allowed by the exchange.
|
|
BidFloorCur string `json:"bidfloorcur,omitempty"`
|
|
|
|
// Attribute:
|
|
// clickbrowser
|
|
// Type:
|
|
// integer
|
|
// Description:
|
|
// Indicates the type of browser opened upon clicking the
|
|
// creative in an app, where 0 = embedded, 1 = native. Note that
|
|
// the Safari View Controller in iOS 9.x devices is considered a
|
|
// native browser for purposes of this attribute.
|
|
ClickBrowser int8 `json:"clickbrowser,omitempty"`
|
|
|
|
// Attribute:
|
|
// secure
|
|
// Type:
|
|
// integer
|
|
// Description:
|
|
// Flag to indicate if the impression requires secure HTTPS URL
|
|
// creative assets and markup, where 0 = non-secure, 1 = secure.
|
|
// If omitted, the secure state is unknown, but non-secure HTTP
|
|
// support can be assumed.
|
|
Secure int8 `json:"secure,omitempty"`
|
|
|
|
// Attribute:
|
|
// iframebuster
|
|
// Type:
|
|
// string array
|
|
// Description:
|
|
// Array of exchange-specific names of supported iframe busters.
|
|
IframeBuster []string `json:"iframebuster,omitempty"`
|
|
|
|
// Attribute:
|
|
// exp
|
|
// Type:
|
|
// integer
|
|
// Description:
|
|
// Advisory as to the number of seconds that may elapse
|
|
// between the auction and the actual impression.
|
|
Exp int64 `json:"exp,omitempty"`
|
|
|
|
// Attribute:
|
|
// ext
|
|
// Type:
|
|
// object
|
|
// Description:
|
|
// Placeholder for exchange-specific extensions to OpenRTB.
|
|
Ext RawJSON `json:"ext,omitempty"`
|
|
}
|