Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

tappx Bid Adapter: update isBidRequestValid and fix request url #6761

Merged
merged 98 commits into from
May 19, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
98 commits
Select commit Hold shift + click to select a range
1646d1f
UPDATE: add initial UID
Mar 24, 2021
62d04e2
UPDATE: UID change user ext
Mar 26, 2021
9a2f9cb
UPDATE: UID clean logs
Mar 26, 2021
3fedc33
UPDATE: add host info
Mar 26, 2021
3cfb943
UPDATE: tappx bid adapter universal id
Mar 30, 2021
22a2b71
UPDATE: fix bidder param
Mar 31, 2021
8700881
UPDATE: tappxBidAdapter tests
Mar 31, 2021
88dfa06
tappxBidAdapter - fix spacing
Mar 31, 2021
919c2f2
tappxBidAdapter: add test user eids array
Mar 31, 2021
37d9f96
tappxBidAdapter: update eids array
Mar 31, 2021
e5777a2
FIX: package-lock.json
Mar 31, 2021
d9a9969
Conversant adapter: add adomain, remove digitrust (#6495)
patmmccann Mar 31, 2021
668c017
Rads Bid Adapter: add GDPR support & user sync support (#6455)
onlsol Mar 31, 2021
7da6799
Proxistore Bid Adapter: add cookieless url endpoint & use floor modul…
vincentproxistore Mar 31, 2021
1a7a7a3
AdYoulike Bid Adapter: Add an "Insertion" tracking for Native mediaty…
guiann Mar 31, 2021
3876d67
Dspx Bid Adapter : add user sync support (#6456)
onlsol Mar 31, 2021
d9e3b12
Multibid Module: add new module to handle multiple bids from single b…
mmoschovas Mar 31, 2021
709e967
Adding uid2 to submodules.json (#6508)
SKOCHERI Mar 31, 2021
b87bfb1
NextRoll ID System: add new ID module (#6396)
abijr Apr 1, 2021
1fae3c4
Qwarry Bid Adapter: add GDPR and consent string handling (#6489)
artemiokost Apr 1, 2021
f2ff4dd
Zemanta Bid Adapter: add support for new params & consent strings to …
Apr 1, 2021
6697dc9
Automatad Bid Adapter: Add meta.advertiserDomains to bid response (#6…
Apr 1, 2021
4230a2c
Adhese Bid Adapter: add support for caching video content (#6501)
Apr 1, 2021
f94d9b4
update apacdex unit test to disable debug mode (#6511)
jsnellbaker Apr 1, 2021
d6d29a7
Telaria: not setting adid (#6507)
bretg Apr 1, 2021
cb19d28
Prebid 4.33.0 Release
jsnellbaker Apr 1, 2021
2b865a3
increment pre version
jsnellbaker Apr 1, 2021
0ce4ae3
rubicon: removing maxduration as a required bidder parameter (#6513)
bretg Apr 1, 2021
61ac2eb
Zemanta adapter: add advertiserDomains (#6517)
Apr 2, 2021
d6426dc
Lemma Bid Adapter: accepting the floor to use the getFloor function (…
lm-abhijit Apr 2, 2021
22f7de5
Mediasquare Bid Adapter: fix getUserSyncs issue with empty bids + add…
matthieularere-msq Apr 2, 2021
fcc2928
Update nextroll ID variable name to match published ID module (#6519)
abijr Apr 2, 2021
391cbb7
Merkle User ID Module: updates to user id submodule (#6503)
SKOCHERI Apr 3, 2021
40c85ca
AdKernel Bid/Analytics Adapters: user privacy related changes (#6488)
ckbo3hrk Apr 5, 2021
7a7af27
SynacorMedia: remove adId from the bid response (#6520)
rajcspsg Apr 5, 2021
e519ead
Rubicon: making doc data types consistent (#6526)
bretg Apr 5, 2021
e8b02b9
Synacormedia Bid Adapter: add meta.advertiserDomains (#6527)
rajcspsg Apr 5, 2021
25ba111
Adloox Analytics Adapter: add new analytics adapter (#6308)
jimdigriz Apr 5, 2021
8aed380
Seedtag adapter: Fixing bug preventing to receive the right params on…
lauramorillo Apr 6, 2021
55831de
adot bid adapter: add publisher path from bidder config to endpoint u…
Giudici-a Apr 6, 2021
ac5c107
Admixer ID System: add userId submodule (#6238)
Galphimbl Apr 6, 2021
42e1c66
PBJS Core: call custom render func after loadscript if provided (#6422)
jeremiegirault Apr 6, 2021
e35140a
Pubxai Analytics Adapter: bug fixes and code revamp (#6474)
pnhegde Apr 6, 2021
a265241
PBJS Core: canBidderRegisterSync ignoring iframe sync disabled by def…
patmmccann Apr 7, 2021
a7ab978
Added automatic tzo and targetId to adserver request. (#6534)
mikael-lundin Apr 7, 2021
c3ee6f9
Impactify Bid Adapter: add new bid adapter (#6518)
thomasdseao Apr 7, 2021
1157b6d
Prebid 4.34.0 Release
Apr 7, 2021
71518cd
Increment pre version
Apr 7, 2021
35de47d
Prebid server adapter: add config for openx hosting (#6530)
deivydas Apr 8, 2021
955c472
Yieldmo adapter: add meta data to bids (#6550)
ym-atsymuk Apr 8, 2021
927496e
Smartx Bid Adapter: Add meta.advertiserDomains support (#6547)
Skylinar Apr 8, 2021
26a5462
Onevideo / Adap.tv Adapter: updated example configuration (#6546)
adam-browning Apr 8, 2021
87a6b47
Mass Deal Rendering Module: support multiple custom configs for dealI…
cciocov Apr 9, 2021
7e43042
ZetaSsp Bid Adapter: add new bid adapter (#6432)
asurovenko-zeta Apr 9, 2021
05c568c
Adnuntius Bid Adapter: Fix for bid too low. (#6557)
mikael-lundin Apr 9, 2021
37f803c
ReadPeak Bid Adapter: fix api issues, add gdpr consent, & getfloor mo…
readpeaktuomo Apr 9, 2021
195572d
BetweenBidAdatper: added sharedid support (#6531)
ignat-one Apr 9, 2021
b9f9f88
adWMG Bid Adapter: update endpoints for cookie sync (#6544)
nyakove Apr 9, 2021
32a74f7
Yieldmo Bid Adapter: add support for the floors module (#6541)
ym-dlabuzov Apr 9, 2021
81139c4
Sortable Bid Adapter: add eids support (#6565)
karentnarvaez Apr 10, 2021
c50694b
Outbrain Bid Adapter: replacing Zemanta (#6558)
Apr 10, 2021
81546c8
Sirdata Real-time Data Module: add new RTD module (#6515)
nouchy Apr 10, 2021
67de22f
Logicad Bid Adapter: add support for userid modules (#6529)
logicad Apr 12, 2021
4297d45
ATS-identityLinkIdSystem - add use3P config property to control firin…
mamatic Apr 12, 2021
8ce416a
Proxistore Bid Adapter: add support for tcf v2 consent (#6543)
vincentproxistore Apr 12, 2021
df0d4dd
BlueBillyWig Bid Adapter: add renderer customization options (#6540)
K-JBoon Apr 12, 2021
d911c0f
OpenX Bid Adapter: Set Deal ID for video requests (#6573)
kenan-gillet Apr 12, 2021
87a3338
33Across Bid Adapter: add support for User ID modules (#6554)
curlyblueeagle Apr 12, 2021
62ea47c
pubGENIUS bid adapter: support floor module (#6555)
edmonl Apr 12, 2021
36d211a
Welect Bid Adapter: update url of API (#6570)
nduitz Apr 13, 2021
2794ce9
Bright Mountain Media Bid Adapter: change bidder code to bmtm; alias …
Apr 13, 2021
df6cf9a
Adtelligent Bid Adapter: add adUrl support & new alias (#6559)
GeneGenie Apr 13, 2021
28cd35a
Bright Mountain Media Bid Adapter: Change Endpoint URL (#6576)
Apr 13, 2021
587a5f6
tappxBidAdapter: update
Mar 24, 2021
dee1db6
tasppxBidAdapter: add video
Apr 9, 2021
96ef7f5
tappxBidAdapter: update video
Apr 12, 2021
62753cd
tappxBidAdapter: update name interpret banner
Apr 13, 2021
036265f
tappxBidAdapter: add tests for video
Apr 13, 2021
6a5fcfa
tappxBidAdapter: add adomain
Apr 13, 2021
29cb756
tappxBidAdapter: update adapter version
Apr 13, 2021
1f3cd3e
tappxBidAdapter: update interpretBid adomain and dealid
Apr 13, 2021
3aa5068
tappxBidAdapter: update isBidRequestValid
Apr 13, 2021
b78f0ab
tappxBidAdapter: update tests. Adding video to isBidRequestValid
Apr 13, 2021
0b6ddf3
tappxBidAdapter: update doc .md file
Apr 13, 2021
454881a
Merge branch 'master' of https://github.com/prebid/Prebid.js
prebidtappx Apr 14, 2021
244b4ac
Merge branch 'master' of https://github.com/prebid/Prebid.js
prebidtappx Apr 19, 2021
8fb69ad
Merge branch 'master' of https://github.com/prebid/Prebid.js
prebidtappx Apr 22, 2021
61a7f9d
Merge branch 'prebid:master' into master
prebidtappx May 13, 2021
9ca82bd
Merge branch 'master' of https://github.com/prebidtappx/Prebid.js
prebidtappx May 13, 2021
2590efb
tappxBidAdapter: update isBidRequestValid
prebidtappx May 13, 2021
500b816
tappxBidAdapter: update ads sizes available
prebidtappx May 14, 2021
d4d9c53
tappxBidAdapter: update isBidRequestValid
prebidtappx May 14, 2021
6fc8b2e
tappxBidAdapter: update host depending tappx endpoint
prebidtappx May 14, 2021
8cc86d2
tappxBidAdapter: update tappx adapter version
prebidtappx May 14, 2021
59975ca
tappxBidAdapter: add EOL
prebidtappx May 14, 2021
d759cf2
revert outbrain cahnges to untrack in this pr
ChrisHuie May 18, 2021
004bbe0
tappxBidAdapter: update isBidRequestValid tests
prebidtappx May 19, 2021
ca5e1ab
tappxBidAdapter: fix circleci error
prebidtappx May 19, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 37 additions & 20 deletions modules/tappxBidAdapter.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,10 @@ import { config } from '../src/config.js';
const BIDDER_CODE = 'tappx';
const TTL = 360;
const CUR = 'USD';
const TAPPX_BIDDER_VERSION = '0.1.10420';
const TAPPX_BIDDER_VERSION = '0.1.10514';
const TYPE_CNN = 'prebidjs';
const VIDEO_SUPPORT = ['instream'];

var HOST;
var hostDomain;

export const spec = {
Expand Down Expand Up @@ -105,13 +104,31 @@ export const spec = {
}

function validBasic(bid) {
if (
(bid.params == null) ||
(bid.params.endpoint == null) ||
(bid.params.tappxkey == null)) {
if (bid.params == null) {
utils.logWarn(`[TAPPX]: Please review the mandatory Tappx parameters.`);
return false;
}

if (bid.params.tappxkey == null) {
utils.logWarn(`[TAPPX]: Please review the mandatory Tappxkey parameter.`);
return false;
}

if (bid.params.host == null) {
utils.logWarn(`[TAPPX]: Please review the mandatory Host parameter.`);
return false;
}

let classicEndpoint = true
if ((new RegExp(`^(vz.*|zz.*)\.*$`, 'i')).test(bid.params.host)) {
classicEndpoint = false
}

if (classicEndpoint && bid.params.endpoint == null) {
utils.logWarn(`[TAPPX]: Please review the mandatory endpoint Tappx parameters.`);
return false;
}

return true;
}

Expand Down Expand Up @@ -174,11 +191,10 @@ function interpretBid(serverBid, request) {
* @return response ad
*/
function buildOneRequest(validBidRequests, bidderRequest) {
HOST = utils.deepAccess(validBidRequests, 'params.host');
let hostInfo = getHostInfo(HOST);
let hostInfo = getHostInfo(validBidRequests);
const ENDPOINT = hostInfo.endpoint;
hostDomain = hostInfo.domain;

const ENDPOINT = utils.deepAccess(validBidRequests, 'params.endpoint');
const TAPPXKEY = utils.deepAccess(validBidRequests, 'params.tappxkey');
const BIDFLOOR = utils.deepAccess(validBidRequests, 'params.bidfloor');
const BIDEXTRA = utils.deepAccess(validBidRequests, 'params.ext');
Expand Down Expand Up @@ -359,7 +375,7 @@ function buildOneRequest(validBidRequests, bidderRequest) {

return {
method: 'POST',
url: `https://${HOST}/${ENDPOINT}?type_cnn=${TYPE_CNN}&v=${TAPPX_BIDDER_VERSION}`,
url: `${hostInfo.url}?type_cnn=${TYPE_CNN}&v=${TAPPX_BIDDER_VERSION}`,
data: JSON.stringify(payload),
bids: validBidRequests
};
Expand All @@ -375,23 +391,24 @@ function getOs() {
if (ua == null) { return 'unknown'; } else if (ua.match(/(iPhone|iPod|iPad)/)) { return 'ios'; } else if (ua.match(/Android/)) { return 'android'; } else if (ua.match(/Window/)) { return 'windows'; } else { return 'unknown'; }
}

function getHostInfo(hostParam) {
function getHostInfo(validBidRequests) {
let domainInfo = {};
let endpoint = utils.deepAccess(validBidRequests, 'params.endpoint');
let hostParam = utils.deepAccess(validBidRequests, 'params.host');

domainInfo.domain = hostParam.split('/', 1)[0];
domainInfo.url = hostParam;

let regexNewEndpoints = new RegExp(`^(vz.*|zz.*|testing)\.ssp\.tappx\.com$`, 'i');
let regexClassicEndpoints = new RegExp(`^[a-z]{3}\.[a-z]{3}\.tappx\.com$`, 'i');
let regexNewEndpoints = new RegExp(`^(vz.*|zz.*)\.pub\.tappx\.com$`, 'i');
let regexClassicEndpoints = new RegExp(`^([a-z]{3}|testing)\.[a-z]{3}\.tappx\.com$`, 'i');

if (regexNewEndpoints.test(domainInfo.domain)) {
let endpoint = domainInfo.domain.split('.', 1)[0]
if (endpoint.toUpperCase().indexOf('TESTING') === -1) {
domainInfo.endpoint = endpoint
domainInfo.new_endpoint = true;
}
domainInfo.newEndpoint = true;
domainInfo.endpoint = domainInfo.domain.split('.', 1)[0]
domainInfo.url = `https://${hostParam}`
} else if (regexClassicEndpoints.test(domainInfo.domain)) {
domainInfo.new_endpoint = false;
domainInfo.newEndpoint = false;
domainInfo.endpoint = endpoint
domainInfo.url = `https://${hostParam}${endpoint}`
}

return domainInfo;
Expand Down
2 changes: 1 addition & 1 deletion modules/tappxBidAdapter.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ Maintainer: prebid@tappx.com
Module that connects to :tappx demand sources.
Suppots Banner and Instream Video.
Please use ```tappx``` as the bidder code.
Ads sizes available: [320,50], [300,250], [320,480], [1024,768], [728,90]
Ads sizes available: [300,250], [320,50], [320,480], [480,320], [728,90], [768,1024], [1024,768]

# Banner Test Parameters
```
Expand Down
34 changes: 29 additions & 5 deletions test/spec/modules/tappxBidAdapter_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -126,11 +126,35 @@ describe('Tappx bid adapter', function () {
assert.isTrue(spec.isBidRequestValid(c_BIDREQUEST.bids[0]), JSON.stringify(c_BIDREQUEST));
});

it('should return false when required params are missing', function () {
let badBidRequest = c_BIDREQUEST;
delete badBidRequest.bids[0].params.tappxkey;
delete badBidRequest.bids[0].params.endpoint;
assert.isFalse(spec.isBidRequestValid(badBidRequest.bids[0]));
it('should return false when params are missing', function () {
let badBidRequestParam = JSON.parse(JSON.stringify(c_BIDREQUEST));
delete badBidRequestParam.bids[0].params;
assert.isFalse(spec.isBidRequestValid(badBidRequestParam.bids[0]));
});

it('should return false when tappxkey is missing', function () {
let badBidRequestTpxkey = JSON.parse(JSON.stringify(c_BIDREQUEST)); ;
delete badBidRequestTpxkey.bids[0].params.tappxkey;
assert.isFalse(spec.isBidRequestValid(badBidRequestTpxkey.bids[0]));
});

it('should return false when host is missing', function () {
let badBidRequestHost = JSON.parse(JSON.stringify(c_BIDREQUEST)); ;
delete badBidRequestHost.bids[0].params.host;
assert.isFalse(spec.isBidRequestValid(badBidRequestHost.bids[0]));
});

it('should return false when classic endpoint is missing', function () {
let badBidRequestClEp = JSON.parse(JSON.stringify(c_BIDREQUEST)); ;
delete badBidRequestClEp.bids[0].params.endpoint;
assert.isFalse(spec.isBidRequestValid(badBidRequestClEp.bids[0]));
});

it('should return true when endpoint is not set for new endpoints', function () {
let badBidRequestNwEp = JSON.parse(JSON.stringify(c_BIDREQUEST)); ;
delete badBidRequestNwEp.bids[0].params.endpoint;
badBidRequestNwEp.bids[0].params.host = 'zztesting.ssp.tappx.com/rtb/v2/';
assert.isTrue(spec.isBidRequestValid(badBidRequestNwEp.bids[0]));
});

it('should return false for not instream requests', function () {
Expand Down