prebid.js 7.51.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.
- package/dist/1plusXRtdProvider.js +1 -1
- package/dist/33acrossBidAdapter.js +1 -1
- package/dist/33acrossIdSystem.js +1 -1
- package/dist/adagioBidAdapter.js +1 -1
- package/dist/adbookpspBidAdapter.js +1 -1
- package/dist/adgenerationBidAdapter.js +1 -1
- package/dist/adkernelBidAdapter.js +1 -1
- package/dist/adqueryBidAdapter.js +1 -1
- package/dist/adrelevantisBidAdapter.js +1 -1
- package/dist/adriverIdSystem.js +1 -1
- package/dist/adtrgtmeBidAdapter.js +1 -1
- package/dist/adxcgBidAdapter.js +1 -1
- package/dist/adyoulikeBidAdapter.js +1 -1
- package/dist/airgridRtdProvider.js +1 -1
- package/dist/ajaBidAdapter.js +1 -1
- package/dist/allowActivities.js +1 -0
- 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/beopBidAdapter.js +1 -1
- package/dist/bidglassBidAdapter.js +1 -1
- package/dist/big-richmediaBidAdapter.js +1 -1
- package/dist/bridgewellBidAdapter.js +1 -1
- package/dist/brightMountainMediaBidAdapter.js +1 -1
- package/dist/carodaBidAdapter.js +1 -1
- package/dist/chtnwBidAdapter.js +1 -1
- package/dist/conceptxBidAdapter.js +1 -0
- package/dist/concertBidAdapter.js +1 -1
- package/dist/connectIdSystem.js +1 -1
- package/dist/connectadBidAdapter.js +1 -1
- package/dist/consumableBidAdapter.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/dependencies.json +6 -0
- package/dist/dspxBidAdapter.js +1 -1
- package/dist/eplanningBidAdapter.js +1 -1
- package/dist/eskimiBidAdapter.js +1 -1
- package/dist/euidIdSystem.js +1 -0
- package/dist/feedadBidAdapter.js +1 -1
- package/dist/finativeBidAdapter.js +1 -1
- package/dist/freepassIdSystem.js +1 -0
- package/dist/freewheel-sspBidAdapter.js +1 -1
- package/dist/gdprEnforcement.js +1 -1
- package/dist/glimpseBidAdapter.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/growthCodeRtdProvider.js +1 -0
- package/dist/gumgumBidAdapter.js +1 -1
- package/dist/h12mediaBidAdapter.js +1 -1
- package/dist/id5IdSystem.js +1 -1
- package/dist/improvedigitalBidAdapter.js +1 -1
- package/dist/inmarBidAdapter.js +1 -1
- package/dist/insticatorBidAdapter.js +1 -1
- package/dist/ixBidAdapter.js +1 -1
- package/dist/justpremiumBidAdapter.js +1 -1
- package/dist/kargoBidAdapter.js +1 -1
- package/dist/konduitAnalyticsAdapter.js +1 -1
- package/dist/kueezBidAdapter.js +1 -1
- package/dist/kueezRtbBidAdapter.js +1 -1
- package/dist/kulturemediaBidAdapter.js +1 -1
- package/dist/lassoBidAdapter.js +1 -1
- package/dist/lifestreetBidAdapter.js +1 -1
- package/dist/limelightDigitalBidAdapter.js +1 -1
- package/dist/liveyieldAnalyticsAdapter.js +1 -1
- package/dist/logicadBidAdapter.js +1 -1
- package/dist/loglyliftBidAdapter.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/mediasquareBidAdapter.js +1 -1
- package/dist/mgidBidAdapter.js +1 -1
- package/dist/minutemediaBidAdapter.js +1 -1
- package/dist/minutemediaplusBidAdapter.js +1 -1
- package/dist/nexx360BidAdapter.js +1 -1
- package/dist/not-for-prod/prebid.js +154 -146
- package/dist/objectGuard.js +1 -0
- package/dist/oguryBidAdapter.js +1 -1
- package/dist/onetagBidAdapter.js +1 -1
- package/dist/ooloAnalyticsAdapter.js +1 -1
- package/dist/optidigitalBidAdapter.js +1 -1
- package/dist/outbrainBidAdapter.js +1 -1
- package/dist/oxxionAnalyticsAdapter.js +1 -0
- package/dist/pairIdSystem.js +1 -1
- package/dist/parrableIdSystem.js +1 -1
- package/dist/pixfutureBidAdapter.js +1 -1
- package/dist/prebid-core.js +1 -1
- package/dist/proxistoreBidAdapter.js +1 -1
- package/dist/publinkIdSystem.js +1 -1
- package/dist/pubmaticBidAdapter.js +1 -1
- package/dist/pubwiseAnalyticsAdapter.js +1 -1
- package/dist/pxyzBidAdapter.js +1 -1
- package/dist/quantcastBidAdapter.js +1 -1
- package/dist/readpeakBidAdapter.js +1 -1
- package/dist/relaidoBidAdapter.js +1 -1
- package/dist/retailspotBidAdapter.js +1 -1
- package/dist/rhythmoneBidAdapter.js +1 -1
- package/dist/richaudienceBidAdapter.js +1 -1
- package/dist/riseBidAdapter.js +1 -1
- package/dist/rtdModule.js +1 -1
- package/dist/rubiconAnalyticsAdapter.js +1 -1
- package/dist/rubiconBidAdapter.js +1 -1
- package/dist/schain.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/shinezBidAdapter.js +1 -1
- package/dist/sirdataRtdProvider.js +1 -1
- package/dist/smaatoBidAdapter.js +1 -1
- package/dist/smartadserverBidAdapter.js +1 -1
- package/dist/smartxBidAdapter.js +1 -1
- package/dist/smilewantedBidAdapter.js +1 -1
- package/dist/sonobiBidAdapter.js +1 -1
- package/dist/sovrnAnalyticsAdapter.js +1 -1
- package/dist/sovrnBidAdapter.js +1 -1
- package/dist/sspBCBidAdapter.js +1 -1
- package/dist/stroeerCoreBidAdapter.js +1 -1
- package/dist/stvBidAdapter.js +1 -1
- package/dist/sublimeBidAdapter.js +1 -1
- package/dist/synacormediaBidAdapter.js +1 -1
- package/dist/targetVideoBidAdapter.js +1 -1
- package/dist/teadsBidAdapter.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/uid2IdSystem_shared.js +1 -0
- package/dist/underdogmediaBidAdapter.js +1 -1
- package/dist/undertoneBidAdapter.js +1 -1
- package/dist/userId.js +1 -1
- package/dist/vidazooBidAdapter.js +1 -1
- package/dist/videobyteBidAdapter.js +1 -1
- package/dist/viouslyBidAdapter.js +1 -1
- package/dist/visxBidAdapter.js +1 -1
- package/dist/vuukleBidAdapter.js +1 -1
- package/dist/weboramaRtdProvider.js +1 -1
- package/dist/widespaceBidAdapter.js +1 -1
- package/dist/winrBidAdapter.js +1 -1
- package/dist/yahoosspBidAdapter.js +1 -1
- package/dist/yieldlabBidAdapter.js +1 -1
- package/dist/yieldmoBidAdapter.js +1 -1
- package/dist/yieldoneAnalyticsAdapter.js +1 -1
- package/dist/zeta_global_sspBidAdapter.js +1 -1
- package/integrationExamples/gpt/growthcode.html +20 -9
- package/integrationExamples/gpt/userId_example.html +20 -6
- package/libraries/objectGuard/objectGuard.js +108 -0
- package/libraries/objectGuard/ortbGuard.js +88 -0
- package/modules/.submodules.json +3 -1
- package/modules/1plusXRtdProvider.js +31 -60
- package/modules/adagioBidAdapter.js +86 -24
- package/modules/adgenerationBidAdapter.js +14 -5
- package/modules/adkernelBidAdapter.js +2 -2
- package/modules/adriverIdSystem.js +1 -1
- package/modules/airgridRtdProvider.js +11 -12
- package/modules/allowActivities.js +74 -0
- package/modules/asoBidAdapter.js +2 -1
- package/modules/beopBidAdapter.js +6 -0
- package/modules/conceptxBidAdapter.js +70 -0
- package/modules/conceptxBidAdapter.md +36 -0
- package/modules/connectIdSystem.js +89 -13
- package/modules/connectIdSystem.md +4 -7
- package/modules/criteoBidAdapter.js +18 -2
- package/modules/eskimiBidAdapter.js +171 -41
- package/modules/eskimiBidAdapter.md +35 -16
- package/modules/euidIdSystem.js +121 -0
- package/modules/euidIdSystem.md +131 -0
- package/modules/freepassIdSystem.js +61 -0
- package/modules/freepassIdSystem.md +47 -0
- package/modules/gdprEnforcement.js +98 -169
- package/modules/greenbidsAnalyticsAdapter.js +1 -1
- package/modules/growthCodeRtdProvider.js +131 -0
- package/modules/growthCodeRtdProvider.md +55 -0
- package/modules/id5IdSystem.js +3 -5
- package/modules/ixBidAdapter.js +17 -3
- package/modules/limelightDigitalBidAdapter.js +1 -1
- package/modules/logicadBidAdapter.js +14 -1
- package/modules/mediasquareBidAdapter.js +13 -5
- package/modules/nexx360BidAdapter.js +1 -0
- package/modules/oxxionAnalyticsAdapter.js +212 -0
- package/modules/oxxionAnalyticsAdapter.md +33 -0
- package/modules/pairIdSystem.js +16 -11
- package/modules/proxistoreBidAdapter.js +11 -14
- package/modules/richaudienceBidAdapter.js +10 -1
- package/modules/riseBidAdapter.js +1 -1
- package/modules/rtdModule/index.js +12 -1
- package/modules/schain.js +2 -2
- package/modules/sharethroughBidAdapter.js +2 -2
- package/modules/sirdataRtdProvider.js +73 -146
- package/modules/smartadserverBidAdapter.js +5 -0
- package/modules/sovrnBidAdapter.js +4 -1
- package/modules/stroeerCoreBidAdapter.js +55 -6
- package/modules/stvBidAdapter.js +34 -1
- package/modules/uid2IdSystem.js +27 -210
- package/modules/uid2IdSystem.md +104 -23
- package/modules/uid2IdSystem_shared.js +232 -0
- package/modules/undertoneBidAdapter.js +9 -1
- package/modules/userId/eids.js +8 -0
- package/modules/userId/index.js +69 -41
- package/modules/userId/userId.md +2 -1
- package/modules/viouslyBidAdapter.js +2 -2
- package/modules/weboramaRtdProvider.js +25 -95
- package/modules/weboramaRtdProvider.md +4 -4
- package/modules/yahoosspBidAdapter.js +45 -3
- package/modules/yahoosspBidAdapter.md +1 -1
- package/modules/yieldlabBidAdapter.js +23 -14
- package/modules/zeta_global_sspBidAdapter.js +28 -22
- package/package.json +1 -1
- package/src/activities/activities.js +47 -0
- package/src/activities/activityParams.js +8 -0
- package/src/activities/modules.js +1 -1
- package/src/activities/params.js +59 -0
- package/src/activities/redactor.js +157 -0
- package/src/activities/rules.js +95 -0
- package/src/adapterManager.js +45 -8
- package/src/adloader.js +1 -0
- package/src/fpd/rootDomain.js +1 -1
- package/src/prebid.js +1 -1
- package/src/storageManager.js +57 -44
- package/src/userSync.js +35 -18
- package/test/spec/activities/allowActivites_spec.js +138 -0
- package/test/spec/activities/objectGuard_spec.js +144 -0
- package/test/spec/activities/ortbGuard_spec.js +140 -0
- package/test/spec/activities/params_spec.js +25 -0
- package/test/spec/activities/redactor_spec.js +296 -0
- package/test/spec/activities/rules_spec.js +135 -0
- package/test/spec/modules/1plusXRtdProvider_spec.js +98 -149
- package/test/spec/modules/adagioBidAdapter_spec.js +46 -17
- package/test/spec/modules/adgenerationBidAdapter_spec.js +52 -12
- package/test/spec/modules/airgridRtdProvider_spec.js +2 -0
- package/test/spec/modules/beopBidAdapter_spec.js +24 -0
- package/test/spec/modules/conceptxBidAdapter_spec.js +136 -0
- package/test/spec/modules/connectIdSystem_spec.js +291 -23
- package/test/spec/modules/criteoBidAdapter_spec.js +85 -1
- package/test/spec/modules/eids_spec.js +15 -0
- package/test/spec/modules/eskimiBidAdapter_spec.js +264 -112
- package/test/spec/modules/euidIdSystem_spec.js +130 -0
- package/test/spec/modules/freepassIdSystem_spec.js +186 -0
- package/test/spec/modules/gdprEnforcement_spec.js +127 -414
- package/test/spec/modules/growthCodeRtdProvider_spec.js +127 -0
- package/test/spec/modules/id5IdSystem_spec.js +10 -3
- package/test/spec/modules/ixBidAdapter_spec.js +32 -1
- package/test/spec/modules/logicadBidAdapter_spec.js +122 -2
- package/test/spec/modules/mediasquareBidAdapter_spec.js +4 -0
- package/test/spec/modules/oxxionAnalyticsAdapter_spec.js +324 -0
- package/test/spec/modules/pairIdSystem_spec.js +16 -3
- package/test/spec/modules/realTimeDataModule_spec.js +1 -1
- package/test/spec/modules/richaudienceBidAdapter_spec.js +44 -0
- package/test/spec/modules/schain_spec.js +9 -0
- package/test/spec/modules/sharethroughBidAdapter_spec.js +1 -1
- package/test/spec/modules/sirdataRtdProvider_spec.js +110 -17
- package/test/spec/modules/smartadserverBidAdapter_spec.js +42 -0
- package/test/spec/modules/sovrnBidAdapter_spec.js +13 -0
- package/test/spec/modules/stroeerCoreBidAdapter_spec.js +151 -6
- package/test/spec/modules/stvBidAdapter_spec.js +13 -1
- package/test/spec/modules/uid2IdSystem_helpers.js +70 -0
- package/test/spec/modules/uid2IdSystem_spec.js +131 -86
- package/test/spec/modules/undertoneBidAdapter_spec.js +57 -1
- package/test/spec/modules/userId_spec.js +96 -33
- package/test/spec/modules/weboramaRtdProvider_spec.js +331 -205
- package/test/spec/modules/yahoosspBidAdapter_spec.js +103 -51
- package/test/spec/modules/yieldlabBidAdapter_spec.js +42 -2
- package/test/spec/modules/zeta_global_sspBidAdapter_spec.js +204 -4
- package/test/spec/unit/core/adapterManager_spec.js +181 -1
- package/test/spec/unit/core/storageManager_spec.js +76 -68
- package/test/spec/unit/pbjs_api_spec.js +15 -25
- package/test/spec/userSync_spec.js +45 -16
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import {config} from 'src/config.js';
|
|
2
|
+
import {ruleRegistry} from '../../../src/activities/rules.js';
|
|
3
|
+
import {updateRulesFromConfig} from '../../../modules/allowActivities.js';
|
|
4
|
+
import {activityParams} from '../../../src/activities/activityParams.js';
|
|
5
|
+
|
|
6
|
+
describe('allowActivities config', () => {
|
|
7
|
+
const MODULE_TYPE = 'test'
|
|
8
|
+
const MODULE_NAME = 'testMod';
|
|
9
|
+
const ACTIVITY = 'testActivity';
|
|
10
|
+
|
|
11
|
+
let isAllowed, params;
|
|
12
|
+
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
let registerRule;
|
|
15
|
+
[registerRule, isAllowed] = ruleRegistry();
|
|
16
|
+
updateRulesFromConfig(registerRule);
|
|
17
|
+
params = activityParams(MODULE_TYPE, MODULE_NAME)
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
afterEach(() => {
|
|
21
|
+
config.resetConfig();
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
function setupActivityConfig(cfg) {
|
|
25
|
+
config.setConfig({
|
|
26
|
+
allowActivities: {
|
|
27
|
+
[ACTIVITY]: cfg
|
|
28
|
+
}
|
|
29
|
+
})
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
describe('default = false', () => {
|
|
33
|
+
it('should deny activites with no other rules', () => {
|
|
34
|
+
setupActivityConfig({
|
|
35
|
+
default: false
|
|
36
|
+
})
|
|
37
|
+
expect(isAllowed(ACTIVITY, {})).to.be.false;
|
|
38
|
+
});
|
|
39
|
+
it('should not deny activities that are explicitly allowed', () => {
|
|
40
|
+
setupActivityConfig({
|
|
41
|
+
default: false,
|
|
42
|
+
rules: [
|
|
43
|
+
{
|
|
44
|
+
condition({componentName}) {
|
|
45
|
+
return componentName === MODULE_NAME
|
|
46
|
+
},
|
|
47
|
+
allow: true
|
|
48
|
+
}
|
|
49
|
+
]
|
|
50
|
+
})
|
|
51
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
52
|
+
});
|
|
53
|
+
it('should be removable by a config update', () => {
|
|
54
|
+
setupActivityConfig({
|
|
55
|
+
default: false
|
|
56
|
+
});
|
|
57
|
+
setupActivityConfig({});
|
|
58
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
59
|
+
})
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
describe('rules', () => {
|
|
63
|
+
it('are tested for their condition', () => {
|
|
64
|
+
setupActivityConfig({
|
|
65
|
+
rules: [{
|
|
66
|
+
condition({flag}) { return flag },
|
|
67
|
+
allow: false
|
|
68
|
+
}]
|
|
69
|
+
});
|
|
70
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
71
|
+
params.flag = true;
|
|
72
|
+
expect(isAllowed(ACTIVITY, params)).to.be.false;
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it('always apply if they have no condition', () => {
|
|
76
|
+
setupActivityConfig({
|
|
77
|
+
rules: [{allow: false}]
|
|
78
|
+
});
|
|
79
|
+
expect(isAllowed(ACTIVITY, params)).to.be.false;
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
it('do not choke when the condition throws', () => {
|
|
83
|
+
setupActivityConfig({
|
|
84
|
+
rules: [{
|
|
85
|
+
condition() {
|
|
86
|
+
throw new Error()
|
|
87
|
+
},
|
|
88
|
+
allow: true
|
|
89
|
+
}]
|
|
90
|
+
});
|
|
91
|
+
expect(isAllowed(ACTIVITY, params)).to.be.false;
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it('does not pass private (underscored) parameters to condition', () => {
|
|
95
|
+
setupActivityConfig({
|
|
96
|
+
rules: [{
|
|
97
|
+
condition({_priv}) { return _priv },
|
|
98
|
+
allow: false
|
|
99
|
+
}]
|
|
100
|
+
});
|
|
101
|
+
params._priv = true;
|
|
102
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
103
|
+
})
|
|
104
|
+
|
|
105
|
+
it('are evaluated in order of priority', () => {
|
|
106
|
+
setupActivityConfig({
|
|
107
|
+
rules: [{
|
|
108
|
+
priority: 1000,
|
|
109
|
+
allow: false
|
|
110
|
+
}, {
|
|
111
|
+
priority: 100,
|
|
112
|
+
allow: true
|
|
113
|
+
}]
|
|
114
|
+
});
|
|
115
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
it('can be set with priority 0', () => {
|
|
119
|
+
setupActivityConfig({
|
|
120
|
+
rules: [{
|
|
121
|
+
allow: false
|
|
122
|
+
}, {
|
|
123
|
+
priority: 0,
|
|
124
|
+
allow: true
|
|
125
|
+
}]
|
|
126
|
+
});
|
|
127
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
128
|
+
})
|
|
129
|
+
|
|
130
|
+
it('can be reset with a config update', () => {
|
|
131
|
+
setupActivityConfig({
|
|
132
|
+
allow: false
|
|
133
|
+
});
|
|
134
|
+
config.setConfig({allowActivities: {}});
|
|
135
|
+
expect(isAllowed(ACTIVITY, params)).to.be.true;
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
});
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import {objectGuard, writeProtectRule} from '../../../libraries/objectGuard/objectGuard.js';
|
|
2
|
+
|
|
3
|
+
describe('objectGuard', () => {
|
|
4
|
+
describe('read rule', () => {
|
|
5
|
+
let rule, applies;
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
applies = true;
|
|
8
|
+
rule = {
|
|
9
|
+
paths: ['foo', 'outer.inner.foo'],
|
|
10
|
+
name: 'testRule',
|
|
11
|
+
applies: sinon.stub().callsFake(() => applies),
|
|
12
|
+
get(val) { return `repl${val}` },
|
|
13
|
+
}
|
|
14
|
+
})
|
|
15
|
+
it('can prevent top level read access', () => {
|
|
16
|
+
const {obj} = objectGuard([rule])({'foo': 1, 'other': 2});
|
|
17
|
+
expect(obj).to.eql({
|
|
18
|
+
foo: 'repl1',
|
|
19
|
+
other: 2
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
it('does not choke if a guarded property is missing', () => {
|
|
24
|
+
const {obj} = objectGuard([rule])({});
|
|
25
|
+
expect(obj.foo).to.not.exist;
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
it('does not prevent access if applies returns false', () => {
|
|
29
|
+
applies = false;
|
|
30
|
+
const {obj} = objectGuard([rule])({foo: 1});
|
|
31
|
+
expect(obj).to.eql({
|
|
32
|
+
foo: 1
|
|
33
|
+
});
|
|
34
|
+
})
|
|
35
|
+
|
|
36
|
+
it('can prevent nested property access', () => {
|
|
37
|
+
const {obj} = objectGuard([rule])({
|
|
38
|
+
other: 0,
|
|
39
|
+
outer: {
|
|
40
|
+
foo: 1,
|
|
41
|
+
inner: {
|
|
42
|
+
foo: 2
|
|
43
|
+
},
|
|
44
|
+
bar: {
|
|
45
|
+
foo: 3
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
expect(obj).to.eql({
|
|
50
|
+
other: 0,
|
|
51
|
+
outer: {
|
|
52
|
+
foo: 1,
|
|
53
|
+
inner: {
|
|
54
|
+
foo: 'repl2',
|
|
55
|
+
},
|
|
56
|
+
bar: {
|
|
57
|
+
foo: 3
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
})
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('does not call applies more than once', () => {
|
|
64
|
+
JSON.stringify(objectGuard([rule])({
|
|
65
|
+
foo: 0,
|
|
66
|
+
outer: {
|
|
67
|
+
inner: {
|
|
68
|
+
foo: 1
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}).obj);
|
|
72
|
+
expect(rule.applies.callCount).to.equal(1);
|
|
73
|
+
})
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
describe('write protection', () => {
|
|
77
|
+
let applies, rule;
|
|
78
|
+
|
|
79
|
+
beforeEach(() => {
|
|
80
|
+
applies = true;
|
|
81
|
+
rule = writeProtectRule({
|
|
82
|
+
paths: ['foo', 'bar', 'outer.inner.foo', 'outer.inner.bar'],
|
|
83
|
+
applies: sinon.stub().callsFake(() => applies)
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
it('should undo top-level writes', () => {
|
|
88
|
+
const obj = {bar: {nested: 'val'}, other: 'val'};
|
|
89
|
+
const guard = objectGuard([rule])(obj);
|
|
90
|
+
guard.obj.foo = 'denied';
|
|
91
|
+
guard.obj.bar.nested = 'denied';
|
|
92
|
+
guard.obj.bar.other = 'denied';
|
|
93
|
+
guard.obj.other = 'allowed';
|
|
94
|
+
guard.verify();
|
|
95
|
+
expect(obj).to.eql({bar: {nested: 'val'}, other: 'allowed'});
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
it('should undo top-level deletes', () => {
|
|
99
|
+
const obj = {foo: {nested: 'val'}, bar: 'val'};
|
|
100
|
+
const guard = objectGuard([rule])(obj);
|
|
101
|
+
delete guard.obj.foo.nested;
|
|
102
|
+
delete guard.obj.bar;
|
|
103
|
+
guard.verify();
|
|
104
|
+
expect(obj).to.eql({foo: {nested: 'val'}, bar: 'val'});
|
|
105
|
+
})
|
|
106
|
+
|
|
107
|
+
it('should undo nested writes', () => {
|
|
108
|
+
const obj = {outer: {inner: {bar: {nested: 'val'}, other: 'val'}}};
|
|
109
|
+
const guard = objectGuard([rule])(obj);
|
|
110
|
+
guard.obj.outer.inner.bar.other = 'denied';
|
|
111
|
+
guard.obj.outer.inner.bar.nested = 'denied';
|
|
112
|
+
guard.obj.outer.inner.foo = 'denied';
|
|
113
|
+
guard.obj.outer.inner.other = 'allowed';
|
|
114
|
+
guard.verify();
|
|
115
|
+
expect(obj).to.eql({
|
|
116
|
+
outer: {
|
|
117
|
+
inner: {
|
|
118
|
+
bar: {
|
|
119
|
+
nested: 'val'
|
|
120
|
+
},
|
|
121
|
+
other: 'allowed'
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
})
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
it('should undo nested deletes', () => {
|
|
128
|
+
const obj = {outer: {inner: {foo: {nested: 'val'}, bar: 'val'}}};
|
|
129
|
+
const guard = objectGuard([rule])(obj);
|
|
130
|
+
delete guard.obj.outer.inner.foo.nested;
|
|
131
|
+
delete guard.obj.outer.inner.bar;
|
|
132
|
+
guard.verify();
|
|
133
|
+
expect(obj).to.eql({outer: {inner: {foo: {nested: 'val'}, bar: 'val'}}})
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
it('should work on null properties', () => {
|
|
137
|
+
const obj = {foo: null};
|
|
138
|
+
const guard = objectGuard([rule])(obj);
|
|
139
|
+
guard.obj.foo = 'denied';
|
|
140
|
+
guard.verify();
|
|
141
|
+
expect(obj).to.eql({foo: null});
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
});
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import {ortb2FragmentsGuardFactory, ortb2GuardFactory} from '../../../libraries/objectGuard/ortbGuard.js';
|
|
2
|
+
import {ACTIVITY_PARAM_COMPONENT_NAME, ACTIVITY_PARAM_COMPONENT_TYPE} from '../../../src/activities/params.js';
|
|
3
|
+
import {
|
|
4
|
+
ACTIVITY_ENRICH_EIDS, ACTIVITY_ENRICH_UFPD,
|
|
5
|
+
ACTIVITY_TRANSMIT_EIDS,
|
|
6
|
+
ACTIVITY_TRANSMIT_UFPD
|
|
7
|
+
} from '../../../src/activities/activities.js';
|
|
8
|
+
import {activityParams} from '../../../src/activities/activityParams.js';
|
|
9
|
+
import {deepAccess, deepClone, deepSetValue, mergeDeep} from '../../../src/utils.js';
|
|
10
|
+
import {ORTB_EIDS_PATHS, ORTB_UFPD_PATHS} from '../../../src/activities/redactor.js';
|
|
11
|
+
import {objectGuard, writeProtectRule} from '../../../libraries/objectGuard/objectGuard.js';
|
|
12
|
+
|
|
13
|
+
describe('ortb2Guard', () => {
|
|
14
|
+
const MOD_TYPE = 'test';
|
|
15
|
+
const MOD_NAME = 'mock';
|
|
16
|
+
let isAllowed, ortb2Guard;
|
|
17
|
+
beforeEach(() => {
|
|
18
|
+
isAllowed = sinon.stub();
|
|
19
|
+
ortb2Guard = ortb2GuardFactory(function (activity, params) {
|
|
20
|
+
if (params[ACTIVITY_PARAM_COMPONENT_TYPE] === MOD_TYPE && params[ACTIVITY_PARAM_COMPONENT_NAME] === MOD_NAME) {
|
|
21
|
+
return isAllowed(activity)
|
|
22
|
+
} else {
|
|
23
|
+
throw new Error('wrong component')
|
|
24
|
+
}
|
|
25
|
+
})
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
function testAllowDeny(transmitActivity, enrichActivity, fn) {
|
|
29
|
+
Object.entries({
|
|
30
|
+
allowed: true,
|
|
31
|
+
denied: false
|
|
32
|
+
}).forEach(([t, allowed]) => {
|
|
33
|
+
describe(`when '${enrichActivity}' is ${t}`, () => {
|
|
34
|
+
beforeEach(() => {
|
|
35
|
+
isAllowed.callsFake((activity) => {
|
|
36
|
+
if (activity === transmitActivity) return true;
|
|
37
|
+
if (activity === enrichActivity) return allowed;
|
|
38
|
+
throw new Error('wrong activity');
|
|
39
|
+
})
|
|
40
|
+
});
|
|
41
|
+
fn(allowed);
|
|
42
|
+
})
|
|
43
|
+
})
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function testPropertiesAreProtected(properties, allowed) {
|
|
47
|
+
properties.forEach(prop => {
|
|
48
|
+
it(`should ${allowed ? 'keep' : 'undo'} additions to ${prop}`, () => {
|
|
49
|
+
const orig = [{n: 'orig'}];
|
|
50
|
+
const ortb2 = {};
|
|
51
|
+
deepSetValue(ortb2, prop, deepClone(orig));
|
|
52
|
+
const guard = ortb2Guard(ortb2, activityParams(MOD_TYPE, MOD_NAME));
|
|
53
|
+
const mod = {};
|
|
54
|
+
const insert = [{n: 'new'}];
|
|
55
|
+
deepSetValue(mod, prop, insert);
|
|
56
|
+
mergeDeep(guard.obj, mod);
|
|
57
|
+
guard.verify();
|
|
58
|
+
const actual = deepAccess(ortb2, prop);
|
|
59
|
+
if (allowed) {
|
|
60
|
+
expect(actual).to.eql(orig.concat(insert))
|
|
61
|
+
} else {
|
|
62
|
+
expect(actual).to.eql(orig);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it(`should ${allowed ? 'keep' : 'undo'} modifications to ${prop}`, () => {
|
|
67
|
+
const orig = [{n: 'orig'}];
|
|
68
|
+
const ortb2 = {};
|
|
69
|
+
deepSetValue(ortb2, prop, orig);
|
|
70
|
+
const guard = ortb2Guard(ortb2, activityParams(MOD_TYPE, MOD_NAME));
|
|
71
|
+
deepSetValue(guard.obj, `${prop}.0.n`, 'new');
|
|
72
|
+
guard.verify();
|
|
73
|
+
const actual = deepAccess(ortb2, prop);
|
|
74
|
+
if (allowed) {
|
|
75
|
+
expect(actual).to.eql([{n: 'new'}]);
|
|
76
|
+
} else {
|
|
77
|
+
expect(actual).to.eql([{n: 'orig'}]);
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
})
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
testAllowDeny(ACTIVITY_TRANSMIT_EIDS, ACTIVITY_ENRICH_EIDS, (allowed) => {
|
|
84
|
+
testPropertiesAreProtected(ORTB_EIDS_PATHS, allowed);
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
testAllowDeny(ACTIVITY_TRANSMIT_UFPD, ACTIVITY_ENRICH_UFPD, (allowed) => {
|
|
88
|
+
testPropertiesAreProtected(ORTB_UFPD_PATHS, allowed);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe('ortb2FragmentsGuard', () => {
|
|
93
|
+
let guardFragments
|
|
94
|
+
beforeEach(() => {
|
|
95
|
+
const testGuard = objectGuard([
|
|
96
|
+
writeProtectRule({
|
|
97
|
+
paths: ['foo'],
|
|
98
|
+
applies: () => true,
|
|
99
|
+
name: 'testRule'
|
|
100
|
+
})
|
|
101
|
+
])
|
|
102
|
+
guardFragments = ortb2FragmentsGuardFactory(testGuard);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('should undo changes to global FPD', () => {
|
|
106
|
+
const fragments = {
|
|
107
|
+
global: {
|
|
108
|
+
foo: {inner: 'val'}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
const guard = guardFragments(fragments);
|
|
112
|
+
guard.obj.global.foo = 'other';
|
|
113
|
+
guard.verify();
|
|
114
|
+
expect(fragments.global.foo).to.eql({inner: 'val'});
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
it('should undo changes to bidder FPD', () => {
|
|
118
|
+
const fragments = {
|
|
119
|
+
bidder: {
|
|
120
|
+
A: {
|
|
121
|
+
foo: 'val'
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
const guard = guardFragments(fragments);
|
|
126
|
+
guard.obj.bidder.A.foo = 'denied';
|
|
127
|
+
guard.verify();
|
|
128
|
+
expect(fragments.bidder.A).to.eql({foo: 'val'});
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
it('should undo changes to bidder FPD that was not initially there', () => {
|
|
132
|
+
const fragments = {
|
|
133
|
+
bidder: {}
|
|
134
|
+
};
|
|
135
|
+
const guard = guardFragments(fragments);
|
|
136
|
+
guard.obj.bidder.A = {foo: 'denied', other: 'allowed'};
|
|
137
|
+
guard.verify();
|
|
138
|
+
expect(fragments.bidder.A).to.eql({other: 'allowed'});
|
|
139
|
+
});
|
|
140
|
+
})
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ACTIVITY_PARAM_ADAPTER_CODE,
|
|
3
|
+
ACTIVITY_PARAM_COMPONENT, ACTIVITY_PARAM_COMPONENT_NAME,
|
|
4
|
+
ACTIVITY_PARAM_COMPONENT_TYPE
|
|
5
|
+
} from '../../../src/activities/params.js';
|
|
6
|
+
import adapterManager from '../../../src/adapterManager.js';
|
|
7
|
+
import {MODULE_TYPE_BIDDER} from '../../../src/activities/modules.js';
|
|
8
|
+
import {activityParams} from '../../../src/activities/activityParams.js';
|
|
9
|
+
|
|
10
|
+
describe('activityParams', () => {
|
|
11
|
+
it('fills out component params', () => {
|
|
12
|
+
sinon.assert.match(activityParams('bidder', 'mockBidder', {foo: 'bar'}), {
|
|
13
|
+
[ACTIVITY_PARAM_COMPONENT]: 'bidder.mockBidder',
|
|
14
|
+
[ACTIVITY_PARAM_COMPONENT_TYPE]: 'bidder',
|
|
15
|
+
[ACTIVITY_PARAM_COMPONENT_NAME]: 'mockBidder',
|
|
16
|
+
foo: 'bar'
|
|
17
|
+
})
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
it('fills out adapterCode', () => {
|
|
21
|
+
adapterManager.registerBidAdapter({callBids: sinon.stub(), getSpec: sinon.stub().returns({})}, 'mockBidder')
|
|
22
|
+
adapterManager.aliasBidAdapter('mockBidder', 'mockAlias');
|
|
23
|
+
expect(activityParams(MODULE_TYPE_BIDDER, 'mockAlias')[ACTIVITY_PARAM_ADAPTER_CODE]).to.equal('mockBidder');
|
|
24
|
+
});
|
|
25
|
+
});
|