Skip to content

Commit

Permalink
Boldwin Bid Adapter: add advertiserDomains and getFloor handling (pre…
Browse files Browse the repository at this point in the history
…bid#7254)

* new boldwin bid adapter

* fix

* Restarting ci / circleci

* changes

Co-authored-by: Aiholkin <[email protected]>
Co-authored-by: Vladislav Isaiko <[email protected]>
Co-authored-by: Mykhailo Yaremchuk <[email protected]>
  • Loading branch information
4 people authored Aug 3, 2021
1 parent ca7ab18 commit 72eacfa
Show file tree
Hide file tree
Showing 3 changed files with 442 additions and 4 deletions.
152 changes: 152 additions & 0 deletions modules/boldwinBidAdapter.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,152 @@
import {registerBidder} from '../src/adapters/bidderFactory.js';
import { BANNER, NATIVE, VIDEO } from '../src/mediaTypes.js';
import * as utils from '../src/utils.js';

const BIDDER_CODE = 'boldwin';
const AD_URL = 'https://ssp.videowalldirect.com/pbjs';
const SYNC_URL = 'https://cs.videowalldirect.com'

function isBidResponseValid(bid) {
if (!bid.requestId || !bid.cpm || !bid.creativeId ||
!bid.ttl || !bid.currency) {
return false;
}
switch (bid.mediaType) {
case BANNER:
return Boolean(bid.width && bid.height && bid.ad);
case VIDEO:
return Boolean(bid.vastUrl);
case NATIVE:
return Boolean(bid.native && bid.native.title && bid.native.image && bid.native.impressionTrackers);
default:
return false;
}
}

function getBidFloor(bid) {
if (!utils.isFn(bid.getFloor)) {
return utils.deepAccess(bid, 'params.bidfloor', 0);
}

try {
const bidFloor = bid.getFloor({
currency: 'USD',
mediaType: '*',
size: '*',
});
return bidFloor.floor;
} catch (_) {
return 0
}
}

export const spec = {
code: BIDDER_CODE,
supportedMediaTypes: [BANNER, VIDEO, NATIVE],

isBidRequestValid: (bid) => {
return Boolean(bid.bidId && bid.params && bid.params.placementId);
},

buildRequests: (validBidRequests = [], bidderRequest) => {
let winTop = window;
let location;
try {
location = new URL(bidderRequest.refererInfo.referer)
winTop = window.top;
} catch (e) {
location = winTop.location;
utils.logMessage(e);
};
let placements = [];
let request = {
'deviceWidth': winTop.screen.width,
'deviceHeight': winTop.screen.height,
'language': (navigator && navigator.language) ? navigator.language.split('-')[0] : '',
'secure': 1,
'host': location.host,
'page': location.pathname,
'placements': placements
};
if (bidderRequest) {
if (bidderRequest.uspConsent) {
request.ccpa = bidderRequest.uspConsent;
}
if (bidderRequest.gdprConsent) {
request.gdpr = bidderRequest.gdprConsent
}
}
const len = validBidRequests.length;

for (let i = 0; i < len; i++) {
let bid = validBidRequests[i];
const { mediaTypes } = bid;
const placement = {};
let sizes;
if (mediaTypes) {
if (mediaTypes[BANNER] && mediaTypes[BANNER].sizes) {
placement.adFormat = BANNER;
sizes = mediaTypes[BANNER].sizes
} else if (mediaTypes[VIDEO] && mediaTypes[VIDEO].playerSize) {
placement.adFormat = VIDEO;
sizes = mediaTypes[VIDEO].playerSize
placement.minduration = mediaTypes[VIDEO].minduration;
placement.maxduration = mediaTypes[VIDEO].maxduration;
placement.mimes = mediaTypes[VIDEO].mimes;
placement.protocols = mediaTypes[VIDEO].protocols;
placement.startdelay = mediaTypes[VIDEO].startdelay;
placement.placement = mediaTypes[VIDEO].placement;
placement.skip = mediaTypes[VIDEO].skip;
placement.skipafter = mediaTypes[VIDEO].skipafter;
placement.minbitrate = mediaTypes[VIDEO].minbitrate;
placement.maxbitrate = mediaTypes[VIDEO].maxbitrate;
placement.delivery = mediaTypes[VIDEO].delivery;
placement.playbackmethod = mediaTypes[VIDEO].playbackmethod;
placement.api = mediaTypes[VIDEO].api;
placement.linearity = mediaTypes[VIDEO].linearity;
} else {
placement.adFormat = NATIVE;
placement.native = mediaTypes[NATIVE];
}
}
placements.push({
...placement,
placementId: bid.params.placementId,
bidId: bid.bidId,
sizes: sizes || [],
wPlayer: sizes ? sizes[0] : 0,
hPlayer: sizes ? sizes[1] : 0,
schain: bid.schain || {},
bidFloor: getBidFloor(bid),
});
}
return {
method: 'POST',
url: AD_URL,
data: request
};
},

interpretResponse: (serverResponse) => {
let response = [];
for (let i = 0; i < serverResponse.body.length; i++) {
let resItem = serverResponse.body[i];
if (isBidResponseValid(resItem)) {
const advertiserDomains = resItem.adomain && resItem.adomain.length ? resItem.adomain : [];
resItem.meta = { ...resItem.meta, advertiserDomains };

response.push(resItem);
}
}
return response;
},

getUserSyncs: () => {
return [{
type: 'image',
url: SYNC_URL
}];
}
};

registerBidder(spec);
6 changes: 2 additions & 4 deletions modules/boldwinBidAdapter.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,7 @@ Module that connects to boldwin demand sources
{
bidder: 'boldwin',
params: {
placementId: 0,
traffic: 'banner'
placementId: 'testBanner',
}
}
]
Expand All @@ -43,8 +42,7 @@ Module that connects to boldwin demand sources
{
bidder: 'boldwin',
params: {
placementId: 0,
traffic: 'video'
placementId: 'testVideo',
}
}
]
Expand Down
Loading

0 comments on commit 72eacfa

Please sign in to comment.