prebid.js 7.52.0 → 7.53.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (214) hide show
  1. package/dist/1plusXRtdProvider.js +1 -1
  2. package/dist/33acrossBidAdapter.js +1 -1
  3. package/dist/33acrossIdSystem.js +1 -1
  4. package/dist/adagioBidAdapter.js +1 -1
  5. package/dist/adbookpspBidAdapter.js +1 -1
  6. package/dist/adgenerationBidAdapter.js +1 -1
  7. package/dist/adkernelBidAdapter.js +1 -1
  8. package/dist/adqueryBidAdapter.js +1 -1
  9. package/dist/adrelevantisBidAdapter.js +1 -1
  10. package/dist/adtrgtmeBidAdapter.js +1 -1
  11. package/dist/adxcgBidAdapter.js +1 -1
  12. package/dist/adyoulikeBidAdapter.js +1 -1
  13. package/dist/airgridRtdProvider.js +1 -1
  14. package/dist/ajaBidAdapter.js +1 -1
  15. package/dist/amxBidAdapter.js +1 -1
  16. package/dist/amxIdSystem.js +1 -1
  17. package/dist/appierAnalyticsAdapter.js +1 -1
  18. package/dist/appnexusBidAdapter.js +1 -1
  19. package/dist/asoBidAdapter.js +1 -1
  20. package/dist/axonixBidAdapter.js +1 -1
  21. package/dist/beopBidAdapter.js +1 -1
  22. package/dist/bidglassBidAdapter.js +1 -1
  23. package/dist/big-richmediaBidAdapter.js +1 -1
  24. package/dist/bridgewellBidAdapter.js +1 -1
  25. package/dist/brightMountainMediaBidAdapter.js +1 -1
  26. package/dist/carodaBidAdapter.js +1 -1
  27. package/dist/chtnwBidAdapter.js +1 -1
  28. package/dist/conceptxBidAdapter.js +1 -0
  29. package/dist/concertBidAdapter.js +1 -1
  30. package/dist/connectadBidAdapter.js +1 -1
  31. package/dist/consumableBidAdapter.js +1 -1
  32. package/dist/conversantAnalyticsAdapter.js +1 -1
  33. package/dist/conversantBidAdapter.js +1 -1
  34. package/dist/craftBidAdapter.js +1 -1
  35. package/dist/criteoBidAdapter.js +1 -1
  36. package/dist/cwireBidAdapter.js +1 -1
  37. package/dist/dspxBidAdapter.js +1 -1
  38. package/dist/eplanningBidAdapter.js +1 -1
  39. package/dist/eskimiBidAdapter.js +1 -1
  40. package/dist/euidIdSystem.js +1 -0
  41. package/dist/feedadBidAdapter.js +1 -1
  42. package/dist/finativeBidAdapter.js +1 -1
  43. package/dist/freepassIdSystem.js +1 -0
  44. package/dist/freewheel-sspBidAdapter.js +1 -1
  45. package/dist/glimpseBidAdapter.js +1 -1
  46. package/dist/gmosspBidAdapter.js +1 -1
  47. package/dist/goldbachBidAdapter.js +1 -1
  48. package/dist/greenbidsAnalyticsAdapter.js +1 -1
  49. package/dist/greenbidsRtdProvider.js +1 -1
  50. package/dist/gridBidAdapter.js +1 -1
  51. package/dist/gumgumBidAdapter.js +1 -1
  52. package/dist/h12mediaBidAdapter.js +1 -1
  53. package/dist/id5IdSystem.js +1 -1
  54. package/dist/improvedigitalBidAdapter.js +1 -1
  55. package/dist/inmarBidAdapter.js +1 -1
  56. package/dist/insticatorBidAdapter.js +1 -1
  57. package/dist/ixBidAdapter.js +1 -1
  58. package/dist/justpremiumBidAdapter.js +1 -1
  59. package/dist/kargoBidAdapter.js +1 -1
  60. package/dist/konduitAnalyticsAdapter.js +1 -1
  61. package/dist/kueezBidAdapter.js +1 -1
  62. package/dist/kueezRtbBidAdapter.js +1 -1
  63. package/dist/kulturemediaBidAdapter.js +1 -1
  64. package/dist/lassoBidAdapter.js +1 -1
  65. package/dist/lifestreetBidAdapter.js +1 -1
  66. package/dist/limelightDigitalBidAdapter.js +1 -1
  67. package/dist/liveyieldAnalyticsAdapter.js +1 -1
  68. package/dist/logicadBidAdapter.js +1 -1
  69. package/dist/loglyliftBidAdapter.js +1 -1
  70. package/dist/magniteAnalyticsAdapter.js +1 -1
  71. package/dist/malltvAnalyticsAdapter.js +1 -1
  72. package/dist/marsmediaBidAdapter.js +1 -1
  73. package/dist/mediafuseBidAdapter.js +1 -1
  74. package/dist/mediasquareBidAdapter.js +1 -1
  75. package/dist/mgidBidAdapter.js +1 -1
  76. package/dist/minutemediaBidAdapter.js +1 -1
  77. package/dist/minutemediaplusBidAdapter.js +1 -1
  78. package/dist/nexx360BidAdapter.js +1 -1
  79. package/dist/not-for-prod/prebid.js +146 -142
  80. package/dist/oguryBidAdapter.js +1 -1
  81. package/dist/onetagBidAdapter.js +1 -1
  82. package/dist/ooloAnalyticsAdapter.js +1 -1
  83. package/dist/optidigitalBidAdapter.js +1 -1
  84. package/dist/outbrainBidAdapter.js +1 -1
  85. package/dist/pairIdSystem.js +1 -1
  86. package/dist/parrableIdSystem.js +1 -1
  87. package/dist/pixfutureBidAdapter.js +1 -1
  88. package/dist/prebid-core.js +1 -1
  89. package/dist/proxistoreBidAdapter.js +1 -1
  90. package/dist/publinkIdSystem.js +1 -1
  91. package/dist/pubmaticBidAdapter.js +1 -1
  92. package/dist/pubwiseAnalyticsAdapter.js +1 -1
  93. package/dist/pxyzBidAdapter.js +1 -1
  94. package/dist/quantcastBidAdapter.js +1 -1
  95. package/dist/readpeakBidAdapter.js +1 -1
  96. package/dist/relaidoBidAdapter.js +1 -1
  97. package/dist/retailspotBidAdapter.js +1 -1
  98. package/dist/rhythmoneBidAdapter.js +1 -1
  99. package/dist/richaudienceBidAdapter.js +1 -1
  100. package/dist/riseBidAdapter.js +1 -1
  101. package/dist/rubiconAnalyticsAdapter.js +1 -1
  102. package/dist/rubiconBidAdapter.js +1 -1
  103. package/dist/schain.js +1 -1
  104. package/dist/seedingAllianceBidAdapter.js +1 -1
  105. package/dist/seedtagBidAdapter.js +1 -1
  106. package/dist/sharethroughAnalyticsAdapter.js +1 -1
  107. package/dist/sharethroughBidAdapter.js +1 -1
  108. package/dist/shinezBidAdapter.js +1 -1
  109. package/dist/sirdataRtdProvider.js +1 -1
  110. package/dist/smaatoBidAdapter.js +1 -1
  111. package/dist/smartadserverBidAdapter.js +1 -1
  112. package/dist/smartxBidAdapter.js +1 -1
  113. package/dist/smilewantedBidAdapter.js +1 -1
  114. package/dist/sonobiBidAdapter.js +1 -1
  115. package/dist/sovrnAnalyticsAdapter.js +1 -1
  116. package/dist/sovrnBidAdapter.js +1 -1
  117. package/dist/sspBCBidAdapter.js +1 -1
  118. package/dist/stroeerCoreBidAdapter.js +1 -1
  119. package/dist/stvBidAdapter.js +1 -1
  120. package/dist/sublimeBidAdapter.js +1 -1
  121. package/dist/synacormediaBidAdapter.js +1 -1
  122. package/dist/targetVideoBidAdapter.js +1 -1
  123. package/dist/teadsBidAdapter.js +1 -1
  124. package/dist/trionBidAdapter.js +1 -1
  125. package/dist/tripleliftBidAdapter.js +1 -1
  126. package/dist/ttdBidAdapter.js +1 -1
  127. package/dist/ucfunnelAnalyticsAdapter.js +1 -1
  128. package/dist/uid2IdSystem.js +1 -1
  129. package/dist/uid2IdSystem_shared.js +1 -0
  130. package/dist/underdogmediaBidAdapter.js +1 -1
  131. package/dist/undertoneBidAdapter.js +1 -1
  132. package/dist/userId.js +1 -1
  133. package/dist/vidazooBidAdapter.js +1 -1
  134. package/dist/videobyteBidAdapter.js +1 -1
  135. package/dist/viouslyBidAdapter.js +1 -1
  136. package/dist/visxBidAdapter.js +1 -1
  137. package/dist/vuukleBidAdapter.js +1 -1
  138. package/dist/weboramaRtdProvider.js +1 -1
  139. package/dist/widespaceBidAdapter.js +1 -1
  140. package/dist/winrBidAdapter.js +1 -1
  141. package/dist/yahoosspBidAdapter.js +1 -1
  142. package/dist/yieldlabBidAdapter.js +1 -1
  143. package/dist/yieldmoBidAdapter.js +1 -1
  144. package/dist/yieldoneAnalyticsAdapter.js +1 -1
  145. package/dist/zeta_global_sspBidAdapter.js +1 -1
  146. package/integrationExamples/gpt/userId_example.html +20 -6
  147. package/modules/.submodules.json +3 -1
  148. package/modules/1plusXRtdProvider.js +31 -60
  149. package/modules/adagioBidAdapter.js +86 -24
  150. package/modules/adkernelBidAdapter.js +2 -2
  151. package/modules/airgridRtdProvider.js +11 -12
  152. package/modules/asoBidAdapter.js +2 -1
  153. package/modules/beopBidAdapter.js +6 -0
  154. package/modules/conceptxBidAdapter.js +70 -0
  155. package/modules/conceptxBidAdapter.md +36 -0
  156. package/modules/criteoBidAdapter.js +9 -2
  157. package/modules/eskimiBidAdapter.js +171 -41
  158. package/modules/eskimiBidAdapter.md +35 -16
  159. package/modules/euidIdSystem.js +121 -0
  160. package/modules/euidIdSystem.md +131 -0
  161. package/modules/freepassIdSystem.js +61 -0
  162. package/modules/freepassIdSystem.md +47 -0
  163. package/modules/greenbidsAnalyticsAdapter.js +1 -1
  164. package/modules/id5IdSystem.js +3 -5
  165. package/modules/ixBidAdapter.js +12 -1
  166. package/modules/limelightDigitalBidAdapter.js +1 -1
  167. package/modules/logicadBidAdapter.js +14 -1
  168. package/modules/mediasquareBidAdapter.js +13 -5
  169. package/modules/nexx360BidAdapter.js +1 -0
  170. package/modules/pairIdSystem.js +10 -5
  171. package/modules/proxistoreBidAdapter.js +11 -14
  172. package/modules/richaudienceBidAdapter.js +10 -1
  173. package/modules/riseBidAdapter.js +1 -1
  174. package/modules/schain.js +2 -2
  175. package/modules/sirdataRtdProvider.js +73 -146
  176. package/modules/sovrnBidAdapter.js +4 -1
  177. package/modules/stroeerCoreBidAdapter.js +55 -6
  178. package/modules/uid2IdSystem.js +27 -210
  179. package/modules/uid2IdSystem.md +104 -23
  180. package/modules/uid2IdSystem_shared.js +232 -0
  181. package/modules/userId/eids.js +8 -0
  182. package/modules/userId/userId.md +2 -1
  183. package/modules/viouslyBidAdapter.js +2 -2
  184. package/modules/weboramaRtdProvider.js +25 -95
  185. package/modules/weboramaRtdProvider.md +4 -4
  186. package/modules/yieldlabBidAdapter.js +23 -14
  187. package/modules/zeta_global_sspBidAdapter.js +27 -22
  188. package/package.json +1 -1
  189. package/src/adloader.js +1 -0
  190. package/test/spec/modules/1plusXRtdProvider_spec.js +98 -149
  191. package/test/spec/modules/adagioBidAdapter_spec.js +46 -17
  192. package/test/spec/modules/airgridRtdProvider_spec.js +2 -0
  193. package/test/spec/modules/beopBidAdapter_spec.js +24 -0
  194. package/test/spec/modules/conceptxBidAdapter_spec.js +136 -0
  195. package/test/spec/modules/criteoBidAdapter_spec.js +1 -1
  196. package/test/spec/modules/eids_spec.js +15 -0
  197. package/test/spec/modules/eskimiBidAdapter_spec.js +264 -112
  198. package/test/spec/modules/euidIdSystem_spec.js +130 -0
  199. package/test/spec/modules/freepassIdSystem_spec.js +186 -0
  200. package/test/spec/modules/id5IdSystem_spec.js +10 -3
  201. package/test/spec/modules/ixBidAdapter_spec.js +30 -0
  202. package/test/spec/modules/logicadBidAdapter_spec.js +122 -2
  203. package/test/spec/modules/mediasquareBidAdapter_spec.js +4 -0
  204. package/test/spec/modules/richaudienceBidAdapter_spec.js +44 -0
  205. package/test/spec/modules/schain_spec.js +9 -0
  206. package/test/spec/modules/sirdataRtdProvider_spec.js +110 -17
  207. package/test/spec/modules/sovrnBidAdapter_spec.js +13 -0
  208. package/test/spec/modules/stroeerCoreBidAdapter_spec.js +151 -6
  209. package/test/spec/modules/uid2IdSystem_helpers.js +70 -0
  210. package/test/spec/modules/uid2IdSystem_spec.js +131 -86
  211. package/test/spec/modules/userId_spec.js +16 -12
  212. package/test/spec/modules/weboramaRtdProvider_spec.js +331 -205
  213. package/test/spec/modules/yieldlabBidAdapter_spec.js +42 -2
  214. package/test/spec/modules/zeta_global_sspBidAdapter_spec.js +200 -4
@@ -0,0 +1,36 @@
1
+ # Overview
2
+
3
+ ```
4
+ Module Name: ConceptX Bidder Adapter
5
+ Module Type: Bidder Adapter
6
+ Maintainer: info@concept.dk
7
+ ```
8
+
9
+ # Description
10
+
11
+ ConceptX Bidder Adapter for Prebid.js.
12
+ Only Banner format is supported.
13
+
14
+ # Test Parameters
15
+ ```
16
+ var adUnits = [
17
+ {
18
+ code: "test-div",
19
+ mediaTypes: {
20
+ banner: {
21
+ sizes: [[980, 180]]
22
+ }
23
+ },
24
+ bids: [
25
+ {
26
+ bidder: "conceptx",
27
+ params: {
28
+ site: "example",
29
+ adunit: "some-id-3",
30
+ }
31
+ },
32
+ ]
33
+ },
34
+
35
+ ];
36
+ ```
@@ -28,7 +28,7 @@ const LOG_PREFIX = 'Criteo: ';
28
28
  Unminified source code can be found in the privately shared repo: https://github.com/Prebid-org/prebid-js-external-js-criteo/blob/master/dist/prod.js
29
29
  */
30
30
  const FAST_BID_VERSION_PLACEHOLDER = '%FAST_BID_VERSION%';
31
- export const FAST_BID_VERSION_CURRENT = 135;
31
+ export const FAST_BID_VERSION_CURRENT = 136;
32
32
  const FAST_BID_VERSION_LATEST = 'latest';
33
33
  const FAST_BID_VERSION_NONE = 'none';
34
34
  const PUBLISHER_TAG_URL_TEMPLATE = 'https://static.criteo.net/js/ld/publishertag.prebid' + FAST_BID_VERSION_PLACEHOLDER + '.js';
@@ -177,7 +177,14 @@ export const spec = {
177
177
 
178
178
  if (publisherTagAvailable()) {
179
179
  // eslint-disable-next-line no-undef
180
- const adapter = new Criteo.PubTag.Adapters.Prebid(PROFILE_ID_PUBLISHERTAG, ADAPTER_VERSION, bidRequests, bidderRequest, '$prebid.version$');
180
+ const adapter = new Criteo.PubTag.Adapters.Prebid(
181
+ PROFILE_ID_PUBLISHERTAG,
182
+ ADAPTER_VERSION,
183
+ bidRequests,
184
+ bidderRequest,
185
+ '$prebid.version$',
186
+ { createOutstreamVideoRenderer: createOutstreamVideoRenderer }
187
+ );
181
188
  url = adapter.buildCdbUrl();
182
189
  data = adapter.buildCdbRequest();
183
190
  } else {
@@ -1,7 +1,7 @@
1
- import {registerBidder} from '../src/adapters/bidderFactory.js';
2
- import {BANNER} from '../src/mediaTypes.js';
1
+ import { ortbConverter } from '../libraries/ortbConverter/converter.js';
2
+ import { registerBidder } from '../src/adapters/bidderFactory.js';
3
+ import { BANNER, VIDEO } from '../src/mediaTypes.js';
3
4
  import * as utils from '../src/utils.js';
4
- import {ortbConverter} from '../libraries/ortbConverter/converter.js'
5
5
 
6
6
  const BIDDER_CODE = 'eskimi';
7
7
  // const ENDPOINT = 'https://hb.eskimi.com/bids'
@@ -12,43 +12,35 @@ const DEFAULT_CURRENCY = 'USD';
12
12
  const DEFAULT_NET_REVENUE = true;
13
13
  const GVLID = 814;
14
14
 
15
+ const VIDEO_ORTB_PARAMS = [
16
+ 'mimes',
17
+ 'minduration',
18
+ 'maxduration',
19
+ 'placement',
20
+ 'protocols',
21
+ 'startdelay',
22
+ 'skip',
23
+ 'skipafter',
24
+ 'minbitrate',
25
+ 'maxbitrate',
26
+ 'delivery',
27
+ 'playbackmethod',
28
+ 'api',
29
+ 'linearity',
30
+ 'battr'
31
+ ];
32
+
33
+ const BANNER_ORTB_PARAMS = [
34
+ 'battr'
35
+ ]
36
+
15
37
  export const spec = {
16
38
  code: BIDDER_CODE,
17
39
  gvlid: GVLID,
18
- supportedMediaTypes: [BANNER],
19
-
20
- isBidRequestValid: function (bid) {
21
- return !!bid.params.placementId;
22
- },
23
-
24
- buildRequests(bidRequests, bidderRequest) {
25
- const data = converter.toORTB({bidRequests, bidderRequest})
26
-
27
- let bid = bidRequests.find((b) => b.params.placementId)
28
- if (!data.site) data.site = {}
29
- data.site.ext = {placementId: bid.params.placementId}
30
-
31
- if (bidderRequest.gdprConsent) {
32
- if (!data.user) data.user = {};
33
- if (!data.user.ext) data.user.ext = {};
34
- if (!data.regs) data.regs = {};
35
- if (!data.regs.ext) data.regs.ext = {};
36
- data.user.ext.consent = bidderRequest.gdprConsent.consentString;
37
- data.regs.ext.gdpr = bidderRequest.gdprConsent.gdprApplies ? 1 : 0;
38
- }
39
-
40
- return [{
41
- method: 'POST',
42
- url: ENDPOINT,
43
- data,
44
- options: {contentType: 'application/json;charset=UTF-8', withCredentials: false}
45
- }]
46
- },
47
-
48
- interpretResponse(response, request) {
49
- return converter.fromORTB({response: response.body, request: request.data}).bids;
50
- },
51
-
40
+ supportedMediaTypes: [BANNER, VIDEO],
41
+ isBidRequestValid,
42
+ buildRequests,
43
+ interpretResponse,
52
44
  /**
53
45
  * Register bidder specific code, which will execute if a bid from this bidder won the auction
54
46
  * @param {Bid} bid The bid that won the auction
@@ -60,13 +52,151 @@ export const spec = {
60
52
  }
61
53
  }
62
54
 
63
- const converter = ortbConverter({
55
+ registerBidder(spec);
56
+
57
+ const CONVERTER = ortbConverter({
64
58
  context: {
65
59
  netRevenue: DEFAULT_NET_REVENUE,
66
60
  ttl: DEFAULT_BID_TTL,
67
- currency: DEFAULT_CURRENCY,
68
- mediaType: BANNER // TODO: support more types, we should set mtype on the winning bid
61
+ currency: DEFAULT_CURRENCY
62
+ },
63
+ imp(buildImp, bidRequest, context) {
64
+ let imp = buildImp(bidRequest, context);
65
+ imp.secure = Number(window.location.protocol === 'https:');
66
+ if (!imp.bidfloor && bidRequest.params.bidFloor) {
67
+ imp.bidfloor = bidRequest.params.bidFloor;
68
+ imp.bidfloorcur = utils.getBidIdParameter('bidFloorCur', bidRequest.params).toUpperCase() || 'USD'
69
+ }
70
+
71
+ if (bidRequest.mediaTypes[VIDEO]) {
72
+ imp = buildVideoImp(bidRequest, imp);
73
+ } else if (bidRequest.mediaTypes[BANNER]) {
74
+ imp = buildBannerImp(bidRequest, imp);
75
+ }
76
+
77
+ return imp;
69
78
  }
70
79
  });
71
80
 
72
- registerBidder(spec);
81
+ function isBidRequestValid(bidRequest) {
82
+ return (isPlacementIdValid(bidRequest) && (isValidBannerRequest(bidRequest) || isValidVideoRequest(bidRequest)));
83
+ }
84
+
85
+ function isPlacementIdValid(bidRequest) {
86
+ return utils.isNumber(bidRequest.params.placementId);
87
+ }
88
+
89
+ function isValidBannerRequest(bidRequest) {
90
+ const bannerSizes = utils.deepAccess(bidRequest, `mediaTypes.${BANNER}.sizes`);
91
+ return utils.isArray(bannerSizes) && bannerSizes.length > 0 && bannerSizes.every(size => utils.isNumber(size[0]) && utils.isNumber(size[1]));
92
+ }
93
+
94
+ function isValidVideoRequest(bidRequest) {
95
+ const videoSizes = utils.deepAccess(bidRequest, `mediaTypes.${VIDEO}.playerSize`);
96
+
97
+ return utils.isArray(videoSizes) && videoSizes.length > 0 && videoSizes.every(size => utils.isNumber(size[0]) && utils.isNumber(size[1]));
98
+ }
99
+
100
+ function buildRequests(validBids, bidderRequest) {
101
+ let videoBids = validBids.filter(bid => isVideoBid(bid));
102
+ let bannerBids = validBids.filter(bid => isBannerBid(bid));
103
+ let requests = [];
104
+
105
+ bannerBids.forEach(bid => {
106
+ requests.push(createRequest([bid], bidderRequest, BANNER));
107
+ });
108
+
109
+ videoBids.forEach(bid => {
110
+ requests.push(createRequest([bid], bidderRequest, VIDEO));
111
+ });
112
+
113
+ return requests;
114
+ }
115
+
116
+ function interpretResponse(response, request) {
117
+ return CONVERTER.fromORTB({ request: request.data, response: response.body }).bids;
118
+ }
119
+
120
+ function buildVideoImp(bidRequest, imp) {
121
+ const videoAdUnitParams = utils.deepAccess(bidRequest, `mediaTypes.${VIDEO}`, {});
122
+ const videoBidderParams = utils.deepAccess(bidRequest, `params.${VIDEO}`, {});
123
+
124
+ const videoParams = { ...videoAdUnitParams, ...videoBidderParams };
125
+
126
+ const videoSizes = (videoAdUnitParams && videoAdUnitParams.playerSize) || [];
127
+
128
+ if (videoSizes && videoSizes.length > 0) {
129
+ utils.deepSetValue(imp, 'video.w', videoSizes[0][0]);
130
+ utils.deepSetValue(imp, 'video.h', videoSizes[0][1]);
131
+ }
132
+
133
+ VIDEO_ORTB_PARAMS.forEach((param) => {
134
+ if (videoParams.hasOwnProperty(param)) {
135
+ utils.deepSetValue(imp, `video.${param}`, videoParams[param]);
136
+ }
137
+ });
138
+
139
+ if (imp.video && videoParams?.context === 'outstream') {
140
+ imp.video.placement = imp.video.placement || 4;
141
+ }
142
+
143
+ return { ...imp };
144
+ }
145
+
146
+ function buildBannerImp(bidRequest, imp) {
147
+ const bannerAdUnitParams = utils.deepAccess(bidRequest, `mediaTypes.${BANNER}`, {});
148
+ const bannerBidderParams = utils.deepAccess(bidRequest, `params.${BANNER}`, {});
149
+
150
+ const bannerParams = { ...bannerAdUnitParams, ...bannerBidderParams };
151
+
152
+ let sizes = bidRequest.mediaTypes.banner.sizes;
153
+
154
+ if (sizes) {
155
+ utils.deepSetValue(imp, 'banner.w', sizes[0][0]);
156
+ utils.deepSetValue(imp, 'banner.h', sizes[0][1]);
157
+ }
158
+
159
+ BANNER_ORTB_PARAMS.forEach((param) => {
160
+ if (bannerParams.hasOwnProperty(param)) {
161
+ utils.deepSetValue(imp, `banner.${param}`, bannerParams[param]);
162
+ }
163
+ });
164
+
165
+ return { ...imp };
166
+ }
167
+
168
+ function createRequest(bidRequests, bidderRequest, mediaType) {
169
+ const data = CONVERTER.toORTB({ bidRequests, bidderRequest, context: { mediaType } })
170
+
171
+ const bid = bidRequests.find((b) => b.params.placementId)
172
+ if (!data.site) data.site = {}
173
+ data.site.ext = { placementId: bid.params.placementId }
174
+
175
+ if (bidderRequest.gdprConsent) {
176
+ if (!data.user) data.user = {};
177
+ if (!data.user.ext) data.user.ext = {};
178
+ if (!data.regs) data.regs = {};
179
+ if (!data.regs.ext) data.regs.ext = {};
180
+ data.user.ext.consent = bidderRequest.gdprConsent.consentString;
181
+ data.regs.ext.gdpr = bidderRequest.gdprConsent.gdprApplies ? 1 : 0;
182
+ }
183
+
184
+ if (bid.params.bcat) data.bcat = bid.params.bcat;
185
+ if (bid.params.badv) data.badv = bid.params.badv;
186
+ if (bid.params.bapp) data.bapp = bid.params.bapp;
187
+
188
+ return {
189
+ method: 'POST',
190
+ url: ENDPOINT,
191
+ data: data,
192
+ options: { contentType: 'application/json;charset=UTF-8', withCredentials: false }
193
+ }
194
+ }
195
+
196
+ function isVideoBid(bid) {
197
+ return utils.deepAccess(bid, 'mediaTypes.video');
198
+ }
199
+
200
+ function isBannerBid(bid) {
201
+ return utils.deepAccess(bid, 'mediaTypes.banner') || !isVideoBid(bid);
202
+ }
@@ -6,29 +6,48 @@ Maintainer: tech@eskimi.com
6
6
 
7
7
  # Description
8
8
 
9
- An adapter to get a bid from Eskimi DSP.
9
+ Module that connects to Eskimi demand sources to fetch bids using OpenRTB standard.
10
+ Banner and video formats are supported.
10
11
 
11
12
  # Test Parameters
12
13
  ```javascript
13
14
  var adUnits = [{
14
- code: 'div-gpt-ad-1460505748561-0',
15
- mediaTypes: {
16
- banner: {
17
- sizes: [[300, 250], [300, 600]]
18
- }
19
- },
20
-
21
- bids: [{
22
- bidder: 'eskimi',
23
- params: {
24
- placementId: 612
25
- }
26
- }]
27
-
28
- }];
15
+ code: '/19968336/prebid_banner_example_1',
16
+ mediaTypes: {
17
+ banner: {
18
+ sizes: [[ 300, 250 ]],
19
+ ... // battr
20
+ }
21
+ },
22
+ bids: [{
23
+ bidder: 'eskimi',
24
+ params: {
25
+ placementId: 612,
26
+ ... // bcat, badv, bapp
27
+ }
28
+ }]
29
+ }, {
30
+ code: '/19968336/prebid_video_example_1',
31
+ mediaTypes: {
32
+ video: {
33
+ context: 'outstream',
34
+ mimes: ['video/mp4'],
35
+ api: [1, 2, 4, 6],
36
+ ... // Aditional ORTB video params (including battr)
37
+ }
38
+ },
39
+ bids: [{
40
+ bidder: 'eskimi',
41
+ params: {
42
+ placementId: 612,
43
+ ... // bcat, badv, bapp
44
+ }
45
+ }]
46
+ }];
29
47
  ```
30
48
 
31
49
  Where:
32
50
 
33
51
  * placementId - Placement ID of the ad unit (required)
52
+ * bcat, badv, bapp, battr - ORTB blocking parameters as specified by OpenRTB 2.5
34
53
 
@@ -0,0 +1,121 @@
1
+ /**
2
+ * This module adds EUID ID support to the User ID module. It shares significant functionality with the UID2 module.
3
+ * The {@link module:modules/userId} module is required.
4
+ * @module modules/euidIdSystem
5
+ * @requires module:modules/userId
6
+ */
7
+
8
+ import { logInfo, logWarn, deepAccess } from '../src/utils.js';
9
+ import {submodule} from '../src/hook.js';
10
+ import {getStorageManager} from '../src/storageManager.js';
11
+ import {MODULE_TYPE_UID} from '../src/activities/modules.js';
12
+
13
+ // RE below lint exception: UID2 and EUID are separate modules, but the protocol is the same and shared code makes sense here.
14
+ // eslint-disable-next-line prebid/validate-imports
15
+ import { Uid2GetId, Uid2CodeVersion } from './uid2IdSystem_shared.js';
16
+
17
+ const MODULE_NAME = 'euid';
18
+ const MODULE_REVISION = Uid2CodeVersion;
19
+ const PREBID_VERSION = '$prebid.version$';
20
+ const EUID_CLIENT_ID = `PrebidJS-${PREBID_VERSION}-EUIDModule-${MODULE_REVISION}`;
21
+ const GVLID_TTD = 21; // The Trade Desk
22
+ const LOG_PRE_FIX = 'EUID: ';
23
+ const ADVERTISING_COOKIE = '__euid_advertising_token';
24
+
25
+ // eslint-disable-next-line no-unused-vars
26
+ const EUID_TEST_URL = 'https://integ.euid.eu';
27
+ const EUID_PROD_URL = 'https://prod.euid.eu';
28
+ const EUID_BASE_URL = EUID_PROD_URL;
29
+
30
+ function createLogger(logger, prefix) {
31
+ return function (...strings) {
32
+ logger(prefix + ' ', ...strings);
33
+ }
34
+ }
35
+ const _logInfo = createLogger(logInfo, LOG_PRE_FIX);
36
+ const _logWarn = createLogger(logWarn, LOG_PRE_FIX);
37
+
38
+ export const storage = getStorageManager({moduleType: MODULE_TYPE_UID, moduleName: MODULE_NAME});
39
+
40
+ function hasWriteToDeviceConsent(consentData) {
41
+ const gdprApplies = consentData?.gdprApplies === true;
42
+ const localStorageConsent = deepAccess(consentData, `vendorData.purpose.consents.1`)
43
+ const prebidVendorConsent = deepAccess(consentData, `vendorData.vendor.consents.${GVLID_TTD.toString()}`)
44
+ if (gdprApplies && (!localStorageConsent || !prebidVendorConsent)) {
45
+ return false;
46
+ }
47
+ return true;
48
+ }
49
+
50
+ /** @type {Submodule} */
51
+ export const euidIdSubmodule = {
52
+ /**
53
+ * used to link submodule with config
54
+ * @type {string}
55
+ */
56
+ name: MODULE_NAME,
57
+
58
+ /**
59
+ * Vendor id of The Trade Desk
60
+ * @type {Number}
61
+ */
62
+ gvlid: GVLID_TTD,
63
+ /**
64
+ * decode the stored id value for passing to bid requests
65
+ * @function
66
+ * @param {string} value
67
+ * @returns {{euid:{ id: string } }} or undefined if value doesn't exists
68
+ */
69
+ decode(value) {
70
+ const result = decodeImpl(value);
71
+ _logInfo('EUID decode returned', result);
72
+ return result;
73
+ },
74
+
75
+ /**
76
+ * performs action to obtain id and return a value.
77
+ * @function
78
+ * @param {SubmoduleConfig} [configparams]
79
+ * @param {ConsentData|undefined} consentData
80
+ * @returns {euidId}
81
+ */
82
+ getId(config, consentData) {
83
+ if (consentData?.gdprApplies !== true) {
84
+ logWarn('EUID is intended for use within the EU. The module will not run when GDPR does not apply.');
85
+ return;
86
+ }
87
+ if (!hasWriteToDeviceConsent(consentData)) {
88
+ // The module cannot operate without this permission.
89
+ _logWarn(`Unable to use EUID module due to insufficient consent. The EUID module requires storage permission.`)
90
+ return;
91
+ }
92
+
93
+ const mappedConfig = {
94
+ apiBaseUrl: config?.params?.euidApiBase ?? EUID_BASE_URL,
95
+ paramToken: config?.params?.euidToken,
96
+ serverCookieName: config?.params?.euidCookie,
97
+ storage: config?.params?.storage ?? 'localStorage',
98
+ clientId: EUID_CLIENT_ID,
99
+ internalStorage: ADVERTISING_COOKIE
100
+ };
101
+
102
+ const result = Uid2GetId(mappedConfig, storage, _logInfo, _logWarn);
103
+ _logInfo(`EUID getId returned`, result);
104
+ return result;
105
+ },
106
+ };
107
+
108
+ function decodeImpl(value) {
109
+ if (typeof value === 'string') {
110
+ _logInfo('Found server-only token. Refresh is unavailable for this token.');
111
+ const result = { euid: { id: value } };
112
+ return result;
113
+ }
114
+ if (Date.now() < value.latestToken.identity_expires) {
115
+ return { euid: { id: value.latestToken.advertising_token } };
116
+ }
117
+ return null;
118
+ }
119
+
120
+ // Register submodule for userId
121
+ submodule('userId', euidIdSubmodule);
@@ -0,0 +1,131 @@
1
+ ## EUID User ID Submodule
2
+
3
+ EUID requires initial tokens to be generated server-side. The EUID module handles storing, providing, and optionally refreshing them. The module can operate in one of two different modes: *Client Refresh* mode or *Server Only* mode.
4
+
5
+ *Server Only* mode was originally referred to as *legacy mode*, but it is a popular mode for new integrations where publishers prefer to handle token refresh server-side.
6
+
7
+ ## Client Refresh mode
8
+
9
+ This is the recommended mode for most scenarios. In this mode, the full response body from the EUID Token Generate or Token Refresh endpoint must be provided to the module. As long as the refresh token remains valid, the module will refresh the advertising token as needed.
10
+
11
+ To configure the module to use this mode, you must **either**:
12
+ 1. Set `params.euidCookie` to the name of the cookie which contains the response body as a JSON string, **or**
13
+ 2. Set `params.euidToken` to the response body as a JavaScript object.
14
+
15
+ ### Client refresh cookie example
16
+
17
+ In this example, the cookie is called `euid_pub_cookie`.
18
+
19
+ Cookie:
20
+ ```
21
+ euid_pub_cookie={"advertising_token":"...advertising token...","refresh_token":"...refresh token...","identity_expires":1684741472161,"refresh_from":1684741425653,"refresh_expires":1684784643668,"refresh_response_key":"...response key..."}
22
+ ```
23
+
24
+ Configuration:
25
+ ```
26
+ pbjs.setConfig({
27
+ userSync: {
28
+ userIds: [{
29
+ name: 'euid',
30
+ params: {
31
+ euidCookie: 'euid_pub_cookie'
32
+ }
33
+ }]
34
+ }
35
+ });
36
+ ```
37
+
38
+ ### Client refresh euidToken example
39
+
40
+ Configuration:
41
+ ```
42
+ pbjs.setConfig({
43
+ userSync: {
44
+ userIds: [{
45
+ name: 'euid',
46
+ params: {
47
+ euidToken: {
48
+ 'advertising_token': '...advertising token...',
49
+ 'refresh_token': '...refresh token...',
50
+ // etc. - see the Sample Token below for contents of this object
51
+ }
52
+ }
53
+ }]
54
+ }
55
+ });
56
+ ```
57
+
58
+ ## Server-Only Mode
59
+
60
+ In this mode, only the advertising token is provided to the module. The module will not be able to refresh the token. The publisher is responsible for implementing some other way to refresh the token.
61
+
62
+ To configure the module to use this mode, you must **either**:
63
+ 1. Set a cookie named `__euid_advertising_token` to the advertising token, **or**
64
+ 2. Set `value` to an ID block containing the advertising token.
65
+
66
+ ### Server only cookie example
67
+
68
+ Cookie:
69
+ ```
70
+ __euid_advertising_token=...advertising token...
71
+ ```
72
+
73
+ Configuration:
74
+ ```
75
+ pbjs.setConfig({
76
+ userSync: {
77
+ userIds: [{
78
+ name: 'euid'
79
+ }]
80
+ }
81
+ });
82
+ ```
83
+
84
+ ### Server only value example
85
+
86
+ Configuration:
87
+ ```
88
+ pbjs.setConfig({
89
+ userSync: {
90
+ userIds: [{
91
+ name: 'euid'
92
+ value: {
93
+ 'euid': {
94
+ 'id': '...advertising token...'
95
+ }
96
+ }
97
+ }]
98
+ }
99
+ });
100
+ ```
101
+
102
+ ## Storage
103
+
104
+ The module stores a number of internal values. By default, all values are stored in HTML5 local storage. You can switch to cookie storage by setting `params.storage` to `cookie`. The cookie size can be significant and this is not recommended, but is provided as an option if local storage is not an option.
105
+
106
+ ## Sample token
107
+
108
+ `{`<br />&nbsp;&nbsp;`"advertising_token": "...",`<br />&nbsp;&nbsp;`"refresh_token": "...",`<br />&nbsp;&nbsp;`"identity_expires": 1633643601000,`<br />&nbsp;&nbsp;`"refresh_from": 1633643001000,`<br />&nbsp;&nbsp;`"refresh_expires": 1636322000000,`<br />&nbsp;&nbsp;`"refresh_response_key": "wR5t6HKMfJ2r4J7fEGX9Gw=="`<br />`}`
109
+
110
+ ### Notes
111
+
112
+ If you are trying to limit the size of cookies, provide the token in configuration and use the default option of local storage.
113
+
114
+ If you provide an expired identity and the module has a valid identity which was refreshed from the identity you provide, it will use the refreshed identity. The module stores the original token used for refreshing the token, and it will use the refreshed tokens as long as the original token matches the one supplied.
115
+
116
+ If a new token is supplied which does not match the original token used to generate any refreshed tokens, all stored tokens will be discarded and the new token used instead (refreshed if necessary).
117
+
118
+ You can set `params.euidApiBase` to `"https://integ.euid.eu"` during integration testing. Be aware that you must use the same environment (production or integration) here as you use for generating tokens.
119
+
120
+ ## Parameter Descriptions for the `usersync` Configuration Section
121
+
122
+ The below parameters apply only to the EUID User ID Module integration.
123
+
124
+ | Param under userSync.userIds[] | Scope | Type | Description | Example |
125
+ | --- | --- | --- | --- | --- |
126
+ | name | Required | String | ID value for the EUID module - `"euid"` | `"euid"` |
127
+ | value | Optional, Server only | Object | An object containing the value for the advertising token. | See the example above. |
128
+ | params.euidToken | Optional, Client refresh | Object | The initial EUID token. This should be `body` element of the decrypted response from a call to the `/token/generate` or `/token/refresh` endpoint. | See the sample token above. |
129
+ | params.euidCookie | Optional, Client refresh | String | The name of a cookie which holds the initial EUID token, set by the server. The cookie should contain JSON in the same format as the euidToken param. **If euidToken is supplied, this param is ignored.** | See the sample token above. |
130
+ | params.euidApiBase | Optional, Client refresh | String | Overrides the default EUID API endpoint. | `"https://prod.euid.eu"` _(default)_|
131
+ | params.storage | Optional, Client refresh | String | Specify whether to use `cookie` or `localStorage` for module-internal storage. It is recommended to not provide this and allow the module to use the default. | `localStorage` _(default)_ |
@@ -0,0 +1,61 @@
1
+ import { submodule } from '../src/hook.js';
2
+ import {generateUUID, logMessage} from '../src/utils.js';
3
+
4
+ const MODULE_NAME = 'freepassId';
5
+
6
+ export const freepassIdSubmodule = {
7
+ name: MODULE_NAME,
8
+ decode: function (value, config) {
9
+ logMessage('Decoding FreePass ID: ', value);
10
+
11
+ return { [MODULE_NAME]: value };
12
+ },
13
+
14
+ getId: function (config, consent, cachedIdObject) {
15
+ logMessage('Getting FreePass ID using config: ' + JSON.stringify(config));
16
+
17
+ const freepassData = config.params !== undefined ? (config.params.freepassData || {}) : {}
18
+ let idObject = {userId: generateUUID()};
19
+
20
+ if (freepassData.commonId !== undefined) {
21
+ idObject.commonId = config.params.freepassData.commonId;
22
+ }
23
+
24
+ if (freepassData.userIp !== undefined) {
25
+ idObject.userIp = config.params.freepassData.userIp;
26
+ }
27
+
28
+ return {id: idObject};
29
+ },
30
+
31
+ extendId: function (config, consent, cachedIdObject) {
32
+ let freepassData = config.params.freepassData;
33
+ let hasFreepassData = freepassData !== undefined;
34
+ if (!hasFreepassData) {
35
+ logMessage('No Freepass Data. CachedIdObject will not be extended: ' + JSON.stringify(cachedIdObject));
36
+ return {
37
+ id: cachedIdObject
38
+ };
39
+ }
40
+
41
+ if (freepassData.commonId === cachedIdObject.commonId && freepassData.userIp === cachedIdObject.userIp) {
42
+ logMessage('FreePass ID is already up-to-date: ' + JSON.stringify(cachedIdObject));
43
+ return {
44
+ id: cachedIdObject
45
+ };
46
+ }
47
+
48
+ logMessage('Extending FreePass ID object: ' + JSON.stringify(cachedIdObject));
49
+ logMessage('Extending FreePass ID using config: ' + JSON.stringify(config));
50
+
51
+ return {
52
+ id: {
53
+ commonId: freepassData.commonId,
54
+ userIp: freepassData.userIp,
55
+ userId: cachedIdObject.userId,
56
+ },
57
+ };
58
+ }
59
+ };
60
+
61
+ submodule('userId', freepassIdSubmodule);