prebid.js 9.7.0 → 9.8.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.
- package/.github/codeql/codeql-config.yml +3 -0
- package/.github/codeql/queries/deviceMemory.ql +14 -0
- package/.github/codeql/queries/hardwareConcurrency.ql +14 -0
- package/.github/codeql/queries/prebid.qll +36 -0
- package/.github/codeql/queries/qlpack.yml +8 -0
- package/.github/workflows/jscpd.yml +1 -1
- package/dist/33acrossAnalyticsAdapter.js +1 -1
- package/dist/33acrossBidAdapter.js +1 -1
- package/dist/33acrossIdSystem.js +1 -1
- package/dist/BTBidAdapter.js +1 -1
- package/dist/adagioAnalyticsAdapter.js +1 -1
- package/dist/adagioBidAdapter.js +1 -1
- package/dist/adagioUtils.js +1 -1
- package/dist/addefendBidAdapter.js +1 -1
- package/dist/adgenerationBidAdapter.js +1 -1
- package/dist/adlooxRtdProvider.js +1 -1
- package/dist/admixerBidAdapter.js +1 -1
- package/dist/adqueryBidAdapter.js +1 -1
- package/dist/adrelevantisBidAdapter.js +1 -1
- package/dist/adstirBidAdapter.js +1 -1
- package/dist/adtrgtmeBidAdapter.js +1 -1
- package/dist/adxcgAnalyticsAdapter.js +1 -1
- package/dist/adxcgBidAdapter.js +1 -1
- package/dist/adyoulikeBidAdapter.js +1 -1
- package/dist/agmaAnalyticsAdapter.js +1 -1
- package/dist/ajaBidAdapter.js +1 -1
- package/dist/amxBidAdapter.js +1 -1
- package/dist/amxIdSystem.js +1 -1
- package/dist/appierAnalyticsAdapter.js +1 -1
- package/dist/appnexusBidAdapter.js +1 -1
- package/dist/asoBidAdapter.js +1 -1
- package/dist/axonixBidAdapter.js +1 -1
- package/dist/bidglassBidAdapter.js +1 -1
- package/dist/big-richmediaBidAdapter.js +1 -1
- package/dist/bridBidAdapter.js +1 -1
- package/dist/bridgewellBidAdapter.js +1 -1
- package/dist/brightMountainMediaBidAdapter.js +1 -1
- package/dist/carodaBidAdapter.js +1 -1
- package/dist/ccxBidAdapter.js +1 -1
- package/dist/chtnwBidAdapter.js +1 -1
- package/dist/chunk-core.js +1 -1
- package/dist/concertBidAdapter.js +1 -1
- package/dist/connectadBidAdapter.js +1 -1
- package/dist/consumableBidAdapter.js +1 -1
- package/dist/contxtfulRtdProvider.js +1 -1
- package/dist/conversantAnalyticsAdapter.js +1 -1
- package/dist/conversantBidAdapter.js +1 -1
- package/dist/craftBidAdapter.js +1 -1
- package/dist/criteoBidAdapter.js +1 -1
- package/dist/cwireBidAdapter.js +1 -1
- package/dist/dailymotionBidAdapter.js +1 -1
- package/dist/dependencies.json +11 -2
- package/dist/discoveryBidAdapter.js +1 -1
- package/dist/dspxBidAdapter.js +1 -1
- package/dist/dxkultureBidAdapter.js +1 -1
- package/dist/eightPodAnalyticsAdapter.js +1 -1
- package/dist/eplanningBidAdapter.js +1 -1
- package/dist/euidIdSystem.js +1 -1
- package/dist/exadsBidAdapter.js +1 -1
- package/dist/feedadBidAdapter.js +1 -1
- package/dist/finativeBidAdapter.js +1 -1
- package/dist/freewheel-sspBidAdapter.js +1 -1
- package/dist/gmosspBidAdapter.js +1 -1
- package/dist/goldbachBidAdapter.js +1 -1
- package/dist/greenbidsAnalyticsAdapter.js +1 -1
- package/dist/greenbidsRtdProvider.js +1 -1
- package/dist/gridBidAdapter.js +1 -1
- package/dist/gumgumBidAdapter.js +1 -1
- package/dist/h12mediaBidAdapter.js +1 -1
- package/dist/hypelabBidAdapter.js +1 -1
- package/dist/id5AnalyticsAdapter.js +1 -1
- package/dist/id5IdSystem.js +1 -1
- package/dist/imdsBidAdapter.js +1 -1
- package/dist/improvedigitalBidAdapter.js +1 -1
- package/dist/insticatorBidAdapter.js +1 -1
- package/dist/intentIqAnalyticsAdapter.js +1 -1
- package/dist/ixBidAdapter.js +1 -1
- package/dist/jixieBidAdapter.js +1 -1
- package/dist/justpremiumBidAdapter.js +1 -1
- package/dist/kargoBidAdapter.js +1 -1
- package/dist/kimberliteBidAdapter.js +1 -1
- package/dist/konduitAnalyticsAdapter.js +1 -1
- package/dist/kueezBidAdapter.js +1 -1
- package/dist/lassoBidAdapter.js +1 -1
- package/dist/lifestreetBidAdapter.js +1 -1
- package/dist/liveIntentIdSystem.js +1 -1
- package/dist/logicadBidAdapter.js +1 -1
- package/dist/loglyliftBidAdapter.js +1 -1
- package/dist/luceadBidAdapter.js +1 -1
- package/dist/mabidderBidAdapter.js +1 -1
- package/dist/magniteAnalyticsAdapter.js +1 -1
- package/dist/malltvAnalyticsAdapter.js +1 -1
- package/dist/marsmediaBidAdapter.js +1 -1
- package/dist/mediafuseBidAdapter.js +1 -1
- package/dist/mediagoBidAdapter.js +1 -1
- package/dist/medianetAnalyticsAdapter.js +1 -1
- package/dist/medianetBidAdapter.js +1 -1
- package/dist/mediasquareBidAdapter.js +1 -1
- package/dist/mgidBidAdapter.js +1 -1
- package/dist/mgidUtils.js +1 -0
- package/dist/mgidXBidAdapter.js +1 -1
- package/dist/missenaBidAdapter.js +1 -1
- package/dist/navigatorData.js +1 -0
- package/dist/nexx360BidAdapter.js +1 -1
- package/dist/nobidAnalyticsAdapter.js +1 -1
- package/dist/nobidBidAdapter.js +1 -1
- package/dist/not-for-prod/prebid.js +165 -162
- package/dist/oguryBidAdapter.js +1 -1
- package/dist/omsBidAdapter.js +1 -1
- package/dist/onetagBidAdapter.js +1 -1
- package/dist/ooloAnalyticsAdapter.js +1 -1
- package/dist/openxBidAdapter.js +1 -1
- package/dist/optidigitalBidAdapter.js +1 -1
- package/dist/orbidderBidAdapter.js +1 -1
- package/dist/outbrainBidAdapter.js +1 -1
- package/dist/pixfutureBidAdapter.js +1 -1
- package/dist/publinkIdSystem.js +1 -1
- package/dist/pubmaticAnalyticsAdapter.js +1 -1
- package/dist/pubmaticBidAdapter.js +1 -1
- package/dist/pubriseBidAdapter.js +1 -0
- package/dist/pubwiseAnalyticsAdapter.js +1 -1
- package/dist/pubxaiAnalyticsAdapter.js +1 -1
- package/dist/pubxaiRtdProvider.js +1 -1
- package/dist/pxyzBidAdapter.js +1 -1
- package/dist/quantcastBidAdapter.js +1 -1
- package/dist/readpeakBidAdapter.js +1 -1
- package/dist/redtramBidAdapter.js +1 -1
- package/dist/relaidoBidAdapter.js +1 -1
- package/dist/retailspotBidAdapter.js +1 -1
- package/dist/rhythmoneBidAdapter.js +1 -1
- package/dist/riseUtils.js +1 -1
- package/dist/rubiconBidAdapter.js +1 -1
- package/dist/seedingAllianceBidAdapter.js +1 -1
- package/dist/seedtagBidAdapter.js +1 -1
- package/dist/sharethroughAnalyticsAdapter.js +1 -1
- package/dist/sharethroughBidAdapter.js +1 -1
- package/dist/smaatoBidAdapter.js +1 -1
- package/dist/smartadserverBidAdapter.js +1 -1
- package/dist/smarthubBidAdapter.js +1 -1
- package/dist/smartxBidAdapter.js +1 -1
- package/dist/smilewantedBidAdapter.js +1 -1
- package/dist/snigelBidAdapter.js +1 -1
- package/dist/sonobiBidAdapter.js +1 -1
- package/dist/sovrnBidAdapter.js +1 -1
- package/dist/sspBCBidAdapter.js +1 -1
- package/dist/stvBidAdapter.js +1 -1
- package/dist/sublimeBidAdapter.js +1 -1
- package/dist/taboolaBidAdapter.js +1 -1
- package/dist/tappxBidAdapter.js +1 -1
- package/dist/targetVideoBidAdapter.js +1 -1
- package/dist/teadsBidAdapter.js +1 -1
- package/dist/terceptAnalyticsAdapter.js +1 -1
- package/dist/themoneytizerBidAdapter.js +1 -1
- package/dist/trionBidAdapter.js +1 -1
- package/dist/tripleliftBidAdapter.js +1 -1
- package/dist/ttdBidAdapter.js +1 -1
- package/dist/ucfunnelAnalyticsAdapter.js +1 -1
- package/dist/uid2IdSystem.js +1 -1
- package/dist/underdogmediaBidAdapter.js +1 -1
- package/dist/undertoneBidAdapter.js +1 -1
- package/dist/unrulyBidAdapter.js +1 -1
- package/dist/userId.js +1 -1
- package/dist/vidazooUtils.js +1 -1
- package/dist/videobyteBidAdapter.js +1 -1
- package/dist/visxBidAdapter.js +1 -1
- package/dist/vuukleBidAdapter.js +1 -1
- package/dist/widespaceBidAdapter.js +1 -1
- package/dist/winrBidAdapter.js +1 -1
- package/dist/yahooAdsBidAdapter.js +1 -1
- package/dist/yieldmoBidAdapter.js +1 -1
- package/dist/yieldoneAnalyticsAdapter.js +1 -1
- package/libraries/mgidUtils/mgidUtils.js +73 -0
- package/{src/fpd/navigator.js → libraries/navigatorData/navigatorData.js} +1 -1
- package/libraries/riseUtils/index.js +1 -1
- package/modules/admixerBidAdapter.js +12 -5
- package/modules/ccxBidAdapter.js +6 -2
- package/modules/contxtfulRtdProvider.js +15 -12
- package/modules/cwireBidAdapter.js +13 -9
- package/modules/cwireBidAdapter.md +29 -10
- package/modules/dailymotionBidAdapter.js +1 -1
- package/modules/dailymotionBidAdapter.md +11 -7
- package/modules/discoveryBidAdapter.js +1 -1
- package/modules/eightPodAnalyticsAdapter.js +13 -1
- package/modules/ixBidAdapter.js +0 -1
- package/modules/mediagoBidAdapter.js +4 -4
- package/modules/mgidBidAdapter.js +30 -109
- package/modules/mgidXBidAdapter.js +2 -66
- package/modules/omsBidAdapter.js +1 -1
- package/modules/pubriseBidAdapter.js +19 -0
- package/modules/pubriseBidAdapter.md +79 -0
- package/modules/pubxaiAnalyticsAdapter.js +9 -4
- package/modules/pubxaiRtdProvider.js +38 -18
- package/modules/pubxaiRtdProvider.md +2 -2
- package/modules/redtramBidAdapter.js +2 -6
- package/modules/rubiconBidAdapter.js +3 -3
- package/modules/smarthubBidAdapter.js +2 -0
- package/modules/teadsBidAdapter.js +4 -3
- package/modules/undertoneBidAdapter.js +1 -19
- package/modules/userId/index.js +1 -1
- package/package.json +1 -1
- package/src/utils/focusTimeout.js +17 -6
- package/src/utils/ttlCollection.js +1 -1
- package/src/utils.js +28 -0
- package/test/spec/modules/admixerBidAdapter_spec.js +2 -2
- package/test/spec/modules/ccxBidAdapter_spec.js +81 -0
- package/test/spec/modules/contxtfulRtdProvider_spec.js +19 -19
- package/test/spec/modules/dailymotionBidAdapter_spec.js +12 -12
- package/test/spec/modules/discoveryBidAdapter_spec.js +1 -1
- package/test/spec/modules/ixBidAdapter_spec.js +8 -1
- package/test/spec/modules/openxBidAdapter_spec.js +1 -1
- package/test/spec/modules/pubriseBidAdapter_spec.js +514 -0
- package/test/spec/modules/pubxaiAnalyticsAdapter_spec.js +9 -4
- package/test/spec/modules/pubxaiRtdProvider_spec.js +37 -5
- package/test/spec/modules/rubiconBidAdapter_spec.js +10 -0
- package/test/spec/modules/trafficgateBidAdapter_spec.js +1 -1
- package/test/spec/ortbConverter/userId_spec.js +23 -2
- package/test/spec/unit/utils/focusTimeout_spec.js +33 -6
|
@@ -3987,6 +3987,16 @@ describe('the rubicon adapter', function () {
|
|
|
3987
3987
|
let bids = spec.interpretResponse({body: response}, {data: request});
|
|
3988
3988
|
expect(bids).to.have.nested.property('[0].native');
|
|
3989
3989
|
});
|
|
3990
|
+
it('should set 0 to bids width and height if `w` and `h` in response object not defined', () => {
|
|
3991
|
+
const nativeBidderRequest = addNativeToBidRequest(bidderRequest);
|
|
3992
|
+
const request = converter.toORTB({bidderRequest: nativeBidderRequest, bidRequests: nativeBidderRequest.bids});
|
|
3993
|
+
let response = getNativeResponse({impid: request.imp[0].id});
|
|
3994
|
+
delete response.seatbid[0].bid[0].w;
|
|
3995
|
+
delete response.seatbid[0].bid[0].h
|
|
3996
|
+
let bids = spec.interpretResponse({body: response}, {data: request});
|
|
3997
|
+
expect(bids[0].width).to.equal(0);
|
|
3998
|
+
expect(bids[0].height).to.equal(0);
|
|
3999
|
+
})
|
|
3990
4000
|
});
|
|
3991
4001
|
}
|
|
3992
4002
|
|
|
@@ -1006,7 +1006,7 @@ describe('TrafficgateOpenxRtbAdapter', function () {
|
|
|
1006
1006
|
// enrich bid request with userId key/value
|
|
1007
1007
|
|
|
1008
1008
|
const request = spec.buildRequests(bidRequestsWithUserId, mockBidderRequest);
|
|
1009
|
-
expect(request[0].data.user.ext.eids).to.
|
|
1009
|
+
expect(request[0].data.user.ext.eids).to.eql(userIdAsEids);
|
|
1010
1010
|
});
|
|
1011
1011
|
|
|
1012
1012
|
it(`when no user ids are available, it should not send any extended ids`, function () {
|
|
@@ -6,13 +6,34 @@ describe('pbjs - ortb user eids', () => {
|
|
|
6
6
|
setOrtbUserExtEids(req, {}, {
|
|
7
7
|
bidRequests: [
|
|
8
8
|
{
|
|
9
|
-
userIdAsEids: {e: 'id'}
|
|
9
|
+
userIdAsEids: [{e: 'id'}]
|
|
10
10
|
}
|
|
11
11
|
]
|
|
12
12
|
});
|
|
13
|
-
expect(req.user.ext.eids).to.eql({e: 'id'});
|
|
13
|
+
expect(req.user.ext.eids).to.eql([{e: 'id'}]);
|
|
14
14
|
});
|
|
15
15
|
|
|
16
|
+
it('should not override eids from fpd', () => {
|
|
17
|
+
const req = {
|
|
18
|
+
user: {
|
|
19
|
+
ext: {
|
|
20
|
+
eids: [{existing: 'id'}]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
setOrtbUserExtEids(req, {}, {
|
|
25
|
+
bidRequests: [
|
|
26
|
+
{
|
|
27
|
+
userIdAsEids: [{nw: 'id'}]
|
|
28
|
+
}
|
|
29
|
+
]
|
|
30
|
+
});
|
|
31
|
+
expect(req.user.ext.eids).to.eql([
|
|
32
|
+
{nw: 'id'},
|
|
33
|
+
{existing: 'id'},
|
|
34
|
+
])
|
|
35
|
+
})
|
|
36
|
+
|
|
16
37
|
it('has no effect if requests have no eids', () => {
|
|
17
38
|
const req = {};
|
|
18
39
|
setOrtbUserExtEids(req, {}, [{}]);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import setFocusTimeout from '../../../../src/utils/focusTimeout';
|
|
1
|
+
import {setFocusTimeout, reset} from '../../../../src/utils/focusTimeout';
|
|
2
2
|
|
|
3
3
|
export const setDocumentHidden = (hidden) => {
|
|
4
4
|
Object.defineProperty(document, 'hidden', {
|
|
@@ -9,10 +9,12 @@ export const setDocumentHidden = (hidden) => {
|
|
|
9
9
|
};
|
|
10
10
|
|
|
11
11
|
describe('focusTimeout', () => {
|
|
12
|
-
let clock;
|
|
12
|
+
let clock, callback;
|
|
13
13
|
|
|
14
14
|
beforeEach(() => {
|
|
15
|
+
reset()
|
|
15
16
|
clock = sinon.useFakeTimers();
|
|
17
|
+
callback = sinon.spy();
|
|
16
18
|
});
|
|
17
19
|
|
|
18
20
|
afterEach(() => {
|
|
@@ -20,14 +22,21 @@ describe('focusTimeout', () => {
|
|
|
20
22
|
})
|
|
21
23
|
|
|
22
24
|
it('should invoke callback when page is visible', () => {
|
|
23
|
-
let callback = sinon.stub();
|
|
24
25
|
setFocusTimeout(callback, 2000);
|
|
25
26
|
clock.tick(2000);
|
|
26
27
|
expect(callback.called).to.be.true;
|
|
27
28
|
});
|
|
28
29
|
|
|
30
|
+
it('should not choke if page starts hidden', () => {
|
|
31
|
+
setDocumentHidden(true);
|
|
32
|
+
reset();
|
|
33
|
+
setDocumentHidden(false);
|
|
34
|
+
setFocusTimeout(callback, 1000);
|
|
35
|
+
clock.tick(1000);
|
|
36
|
+
sinon.assert.called(callback);
|
|
37
|
+
})
|
|
38
|
+
|
|
29
39
|
it('should not invoke callback if page was hidden', () => {
|
|
30
|
-
let callback = sinon.stub();
|
|
31
40
|
setFocusTimeout(callback, 2000);
|
|
32
41
|
setDocumentHidden(true);
|
|
33
42
|
clock.tick(3000);
|
|
@@ -35,7 +44,6 @@ describe('focusTimeout', () => {
|
|
|
35
44
|
});
|
|
36
45
|
|
|
37
46
|
it('should defer callback execution when page is hidden', () => {
|
|
38
|
-
let callback = sinon.stub();
|
|
39
47
|
setFocusTimeout(callback, 4000);
|
|
40
48
|
clock.tick(2000);
|
|
41
49
|
setDocumentHidden(true);
|
|
@@ -46,8 +54,27 @@ describe('focusTimeout', () => {
|
|
|
46
54
|
expect(callback.called).to.be.true;
|
|
47
55
|
});
|
|
48
56
|
|
|
57
|
+
it('should not execute deferred callbacks again', () => {
|
|
58
|
+
setDocumentHidden(true);
|
|
59
|
+
setFocusTimeout(callback, 1000);
|
|
60
|
+
clock.tick(2000);
|
|
61
|
+
[false, true, false].forEach(setDocumentHidden);
|
|
62
|
+
clock.tick(2000);
|
|
63
|
+
sinon.assert.calledOnce(callback);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it('should run callbacks that expire while page is hidden', () => {
|
|
67
|
+
setFocusTimeout(callback, 1000);
|
|
68
|
+
clock.tick(500);
|
|
69
|
+
setDocumentHidden(true);
|
|
70
|
+
clock.tick(1000);
|
|
71
|
+
setDocumentHidden(false);
|
|
72
|
+
sinon.assert.notCalled(callback);
|
|
73
|
+
clock.tick(1000);
|
|
74
|
+
sinon.assert.called(callback);
|
|
75
|
+
})
|
|
76
|
+
|
|
49
77
|
it('should return updated timerId after page was showed again', () => {
|
|
50
|
-
let callback = sinon.stub();
|
|
51
78
|
const getCurrentTimerId = setFocusTimeout(callback, 4000);
|
|
52
79
|
const oldTimerId = getCurrentTimerId();
|
|
53
80
|
clock.tick(2000);
|