Skip to content
forked from Avocarrot/openrtb

A Node.js library which builds, validates and processes OpenRTB objects.

License

Notifications You must be signed in to change notification settings

kerngven/openrtb

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

52 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenRTB Objects

NPM

Purpose

A Node.js library which builds, validates and processes OpenRTB objects. This project was inspired by the good people at Metamarkets who build a similar library for Java.

Contents

Installation

npm install openrtb

Constructing objects

The library exposes object builders which are used to construct new objects.

Supported objects builders

OpenRTB API Specification Version 2.3

  • BidRequest

    • Imp
      • Native
      • Banner
      • Pmp
        • Deal
    • App
      • Publisher
    • Device
    • User
    • Site
      • Content
        • Producer
  • BidResponse

    • SeatBid
      • Bid

OpenRTB API Specification Version 2.2

Not supported but most objects for v2.3 should work for this one too.

Construct a bid request

    var builder = new BidRequestBuilder();
	builder
	.timestamp(moment.utc().format())
	.id('1234')
	.at(2)
	.imp([
	  {
	      "id":"1",
          "native":{
            "request": {
              "ver": 1,
              "layout": 6,
              "assets": [
                { "id": 0, "req": 1, "title": { "len": 25 } }, 
                { "id": 1, "req": 1, "img": { "type": 3, "wmin": 100, "hmin": 100 } },
                { "id": 3, "req": 0, "data": { "type": 2, "len": 90 } }
              ]
            }
          },
	      "tagid": "eb09ff2a287598302fd631493949169b0d17f815",
	      "bidfloor": 1.3,
	      "pmp": [{
          "private_auction": 0,
          "deals": [{
            "id": "deal_1",
            "bidfloor": 1.3,
            "bidfloorcur": "CNY",
            "at": 2,
            "wseat": [mockResponse.seatbid],
            "wadomain": ["example.com"]
          }]
        }]
	  }
	])
	.app({
	  "id":"55",
	  "name":"Test App",
	  "cat":["IAB3-1"],
	  "storeurl": "http://www.example.com",
	  "publisher":{  
	      "id": "6332"
	  }
	})
	.device({
		"dnt":0,
		"ua":"Mozilla/5.0 (Linux; U; Android 4.0.3; ko-kr; LG-L160L Build/IML74K) AppleWebkit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30",
		"ip":"76.174.49.222",
		"connectiontype":2,
		"devicetype":1,
		"didsha1": "bbc9ff2a287598302fd631693949169b0d17f215",
		"carrier": "o2",
		"make": "samsung GT-I9300",
		"model": "Android",
		"language": "en",
		"os": "Android",
		"osv": "5.1.1",
		"geo": {
		    "country": "UK"
		}
	})
	.user({
		"id":"55816b39711f9b5acf3b90e313ed29e51665623f",
		"yob": 1987,
		"gender": "M"
	})
	.site({
  	"id": "10",
  	"name": "Test Site",
  	"domain": "example.com",
  	"cat": ['IAB3-1'],
  	"sectioncat": ['IAB3-1'],
  	"pagecat": ['IAB3-1'],
  	"page": "http://www.example.com",
  	"ref": "http://www.google.com",
  	"search": "example+test+openRTB",
  	"mobile": 0,
  	"privacypolicy": 1,
  	"keywords": "nodejs+openRTB",
  	"publisher": {  
      "id": "6332",
      "name": 'publisher 1'
  	},
  	"content": {
    	"id": "100",
      "episode": "1",
      "title": "example video",
      "series": "nodejs+openRTB",
      "season": "one",
    	"producer": {
    		"id": "100",
      	"name": "Test Producer",
      	"cat": ['IAB3-1'],
      	"domain": "example.com"
    	},
      "url": "http://www.example.com",
      "cat": ["IAB3-1"],
      "videoquality": 1,
      "context": 1,
      "contentrating": "18X",
      "userrating": "18",
      "qagmediarating": 1,
      "keywords": "nodejs+openRTB+example",
      "livestream": 0,
      "sourcerelationship": 1,
      "len": 1024,
      "language": "ISO-639-1-alpha-2",
      "embeddable": 0
  	}
	})
	.ext({
		'extra': '1234'
	})
	.build()
	.then(function(bidRequest){
		//Do something with the object
	});

Construct a bid response

	var builder = new BidResponseBuilder();
	builder
	.timestamp(moment.utc().format())
	.status(1)
	.bidderName('test-bidder')
	.seatbid([
		{
			bid: [
				{
				  status: 1,
				  clearPrice: 0.9,
				  adid: 1,
				  id: '819582c3-96b2-401a-b60d-7ac3c117a513',
				  impid: 'e317ae49-8cd1-47b0-b022-02a8830182ce',
				  price: 1.05,
				  nurl: 'http://trackwin.com/win?pid=784170&data=OuJifVtEK&price=${AUCTION_PRICE}',
				  adm: '{"native":{"assets":[{"id":0,"title":{"text":"Test Campaign"}},{"id":1,"img":{"url":"http://cdn.exampleimage.com/a/100/100/2639042","w":100,"h":100}},{"id":2,"img":{"url":"http://cdn.exampleimage.com/a/50/50/2639042","w":50,"h":50}},{"id":3,"data":{"value":"This is an amazing offer..."}},{"id":5,"data":{"value":"Install"}}],"link":{"url":"http://trackclick.com/Click?data=soDvIjYdQMm3WBjoORcGaDvJGOzgMvUap7vAw2"},"imptrackers":["http://trackimp.com/Pixel/Impression/?bidPrice=${AUCTION_PRICE}&data=OuJifVtEKZqw3Hw7456F-etFgvhJpYOu0&type=img"]}}',
				  cid: '9607',
				  crid: '335224',
				  iurl: 'http://cdn.testimage.net/1200x627.png',
				  adomain: ["example.com"] 
				} 
			]
		}
	])
	.build()
	.then(function(bidResponse){
		//Do something with the object
	});

Validating objects

All builders will throw an error when trying to build an object that is missing a required parameter.

	var builder = new BidRequestBuilder();

	//Trying to build a bid request without a request id
	builder
    .timestamp(moment.utc().format())
	.build()
	.catch(function(err){
		//The following statement will print 'BidRequest should have a requestId'
		console.log(err.message);
	});

Objects API

All objects inherit common functionality from a base RtbObject and also define some functionality of their own. See below for the documentation.

RtbObject

.stringify()

Converts the object to a JSON string. Properties that are undefined are not included.

BidRequest

Additional Properties

timestamp

The timestamp of the bid request. If not provided explicitly at build time the default will be the current UTC when the object is created.

BidResponse

Additional Properties

status

The table below lists the possible values for a bid response status.

Status Description
1 Valid
2 Timeout
3 Invalid JSON
4 HTTP Error
bidderName

The bidder's name used for reporting and debugging.

timestamp

The timestamp of bid response. If not provided explicitly at build time the default will be the current UTC when the object is created.

Bid

Additional Properties

status

The table below lists the possible values for a bid status.

Status Description
1 Won
2 Lost on Price
3 Below floor
4 Markup Delivery Failure
5 Unscreenable
6 Blocked by publisher
7 Unverified creative
8 Blocked advertiser
9 Blocked content category
10 Block creative attribute
clearPrice

The bid clearing price determined after an auction.

parseAdm

A function which parses the bid's adm. If not provided explicitly the default implenentation is to return the adm as is.

Functions

replaceMacros()

Replaces auction macros for a bid.

Disclaimer

This project is a work in progress. It was created for the specific purposes of the Avocarrot Native Ad Exchange (AVX) and some objects fields or functionality might be missing. If you want something to be added then please either get in touch or submit your own pull request.

Contributing

This project is work in progress and we'd love more people contributing to it.

  1. Fork the repo
  2. Apply your changes
  3. Write tests
  4. Submit your pull request

For feedback or suggestions you can drop us a line at [email protected]

About

A Node.js library which builds, validates and processes OpenRTB objects.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%