Skip to content

Commit

Permalink
Add vuble adapter (prebid#2201)
Browse files Browse the repository at this point in the history
* Add: vuble bid adapter

* Add: vuble bid adapter unit tests

* Fix: getUserSync returns an empty array if no user sync is found

* Add: unit tests for getUserSync

* Mod vuble unit test use single quotes

* Mod: check mediatypes for bid request valid check on vuble adapter

* Add: vuble adapter: bid id and env in request data

* Fix: vuble adaptor uses bid data in interpret reponse

* Del: unused size param anymore
  • Loading branch information
Roffray authored and dluxemburg committed Jul 17, 2018
1 parent ec8821d commit 139c0b6
Show file tree
Hide file tree
Showing 3 changed files with 461 additions and 0 deletions.
135 changes: 135 additions & 0 deletions modules/vubleBidAdapter.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
// Vuble Adapter

import * as utils from 'src/utils';
import {registerBidder} from 'src/adapters/bidderFactory';

const BIDDER_CODE = 'vuble';

const ENVS = ['com', 'net'];
const CURRENCIES = {
com: 'EUR',
net: 'USD'
};
const TTL = 60;

export const spec = {
code: BIDDER_CODE,
supportedMediaTypes: ['video'],

/**
* Determines whether or not the given bid request is valid.
*
* @param {BidRequest} bid The bid params to validate.
* @return boolean True if this is a valid bid, and false otherwise.
*/
isBidRequestValid: function (bid) {
if (utils.isEmpty(bid.sizes) || utils.parseSizesInput(bid.sizes).length == 0) {
return false;
}

if (!utils.deepAccess(bid, 'mediaTypes.video.context')) {
return false;
}

if (!utils.contains(ENVS, bid.params.env)) {
return false;
}

return !!(bid.params.env && bid.params.pubId && bid.params.zoneId);
},

/**
* Make a server request from the list of BidRequests.
*
* @param {validBidRequests[]} - an array of bids
* @return ServerRequest Info describing the request to the server.
*/
buildRequests: function (validBidRequests) {
return validBidRequests.map(bid => {
// We take the first size
let size = utils.parseSizesInput(bid.sizes)[0].split('x');

// Get the page's url
let referrer = utils.getTopWindowUrl();
if (bid.params.referrer) {
referrer = bid.params.referrer;
}

// Get Video Context
let context = utils.deepAccess(bid, 'mediaTypes.video.context');

let url = '//player.mediabong.' + bid.params.env + '/prebid/request';
let data = {
width: size[0],
height: size[1],
pub_id: bid.params.pubId,
zone_id: bid.params.zoneId,
context: context,
floor_price: bid.params.floorPrice ? bid.params.floorPrice : 0,
url: referrer,
env: bid.params.env,
bid_id: bid.bidId
};

return {
method: 'POST',
url: url,
data: data
};
});
},

/**
* Unpack the response from the server into a list of bids.
*
* @param {ServerResponse} serverResponse A successful response from the server.
* @return {Bid[]} An array of bids which were nested inside the server.
*/
interpretResponse: function (serverResponse, bid) {
const responseBody = serverResponse.body;

if (typeof responseBody !== 'object' || responseBody.status !== 'ok') {
return [];
}

let responses = [];
let reponse = {
requestId: bid.data.bid_id,
cpm: responseBody.cpm,
width: bid.data.width,
height: bid.data.height,
ttl: TTL,
creativeId: responseBody.creativeId,
netRevenue: true,
currency: CURRENCIES[bid.data.env],
vastUrl: responseBody.url
};
responses.push(reponse);

return responses;
},

/**
* Register the user sync pixels which should be dropped after the auction.
*
* @param {SyncOptions} syncOptions Which user syncs are allowed?
* @param {ServerResponse[]} serverResponses List of server's responses.
* @return {UserSync[]} The user syncs which should be dropped.
*/
getUserSyncs: function (syncOptions, serverResponses) {
if (syncOptions.iframeEnabled) {
if (serverResponses.length > 0) {
let responseBody = serverResponses[0].body;
if (typeof responseBody !== 'object' || responseBody.iframeSync) {
return [{
type: 'iframe',
url: responseBody.iframeSync
}];
}
}
}
return [];
}
};

registerBidder(spec);
58 changes: 58 additions & 0 deletions modules/vubleBidAdapter.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
# Overview

```
Module Name: Vuble Bidder Adapter
Module Type: Vuble Adapter
Maintainer: [email protected]
```

# Description

Module that connects to Vuble's demand sources

# Test Parameters
```
var adUnits = [
{
code: 'test-video-instream',
sizes: [[640, 360]],
mediaTypes: {
video: {
context: 'instream'
}
},
bids: [
{
bidder: "vuble",
params: {
env: 'net',
pubId: '3',
zoneId: '12345',
referrer: "http://www.vuble.tv/", // optional
floorPrice: 5.00 // optional
}
}
]
},
{
code: 'test-video-outstream',
sizes: [[640, 360]],
mediaTypes: {
video: {
context: 'outstream'
}
},
bids: [
{
bidder: "vuble",
params: {
env: 'net',
pubId: '3',
zoneId: '12345',
referrer: "http://www.vuble.tv/", // optional
floorPrice: 5.00 // optional
}
}
]
}
];
Loading

0 comments on commit 139c0b6

Please sign in to comment.