Skip to content
This repository has been archived by the owner on Dec 22, 2022. It is now read-only.

Commit

Permalink
verizonmedia: override tag ID and site ID + split up multi-imp reques…
Browse files Browse the repository at this point in the history
…ts (prebid#1050)
  • Loading branch information
Aadeshp authored and mansinahar committed Oct 1, 2019
1 parent c66ae59 commit fd1c166
Show file tree
Hide file tree
Showing 5 changed files with 76 additions and 63 deletions.
130 changes: 71 additions & 59 deletions adapters/verizonmedia/verizonmedia.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,12 @@ import (
"encoding/json"
"errors"
"fmt"
"net/http"

"github.com/mxmCherry/openrtb"
"github.com/prebid/prebid-server/adapters"
"github.com/prebid/prebid-server/errortypes"
"github.com/prebid/prebid-server/openrtb_ext"
"net/http"
)

type VerizonMediaAdapter struct {
Expand All @@ -25,8 +26,8 @@ func (a *VerizonMediaAdapter) SkipNoCookies() bool {
}

func (a *VerizonMediaAdapter) MakeRequests(request *openrtb.BidRequest, reqInfo *adapters.ExtraRequestInfo) ([]*adapters.RequestData, []error) {

errors := make([]error, 0, 1)

if len(request.Imp) == 0 {
err := &errortypes.BadInput{
Message: "No impression in the bid request",
Expand All @@ -35,68 +36,82 @@ func (a *VerizonMediaAdapter) MakeRequests(request *openrtb.BidRequest, reqInfo
return nil, errors
}

var bidderExt adapters.ExtImpBidder
err := json.Unmarshal(request.Imp[0].Ext, &bidderExt)
if err != nil {
err = &errortypes.BadInput{
Message: "ext.bidder not provided",
}
errors = append(errors, err)
return nil, errors
reqs := make([]*adapters.RequestData, 0, len(request.Imp))
headers := http.Header{}

headers.Add("Content-Type", "application/json;charset=utf-8")
headers.Add("Accept", "application/json")
headers.Add("x-openrtb-version", "2.5")

if request.Device != nil && request.Device.UA != "" {
headers.Set("User-Agent", request.Device.UA)
}
var verizonMediaExt openrtb_ext.ExtImpVerizonMedia
err = json.Unmarshal(bidderExt.Bidder, &verizonMediaExt)
if err != nil {
err = &errortypes.BadInput{
Message: err.Error(),

for idx, imp := range request.Imp {
var bidderExt adapters.ExtImpBidder
err := json.Unmarshal(imp.Ext, &bidderExt)
if err != nil {
err = &errortypes.BadInput{
Message: fmt.Sprintf("imp #%d: ext.bidder not provided", idx),
}
errors = append(errors, err)
continue
}
errors = append(errors, err)
return nil, errors
}

if verizonMediaExt.Dcn == "" {
err = &errortypes.BadInput{
Message: "Missing param dcn",
var verizonMediaExt openrtb_ext.ExtImpVerizonMedia
err = json.Unmarshal(bidderExt.Bidder, &verizonMediaExt)
if err != nil {
err = &errortypes.BadInput{
Message: fmt.Sprintf("imp #%d: %s", idx, err.Error()),
}
errors = append(errors, err)
continue
}
errors = append(errors, err)
return nil, errors
}

if verizonMediaExt.Pos == "" {
err = &errortypes.BadInput{
Message: "Missing param pos",
if verizonMediaExt.Dcn == "" {
err = &errortypes.BadInput{
Message: fmt.Sprintf("imp #%d: missing param dcn", idx),
}
errors = append(errors, err)
continue
}
errors = append(errors, err)
return nil, errors
}

siteCopy := *request.Site
request.Site = &siteCopy
if err := changeRequestForBidService(request, &verizonMediaExt); err != nil {
errors = append(errors, err)
return nil, errors
}
if verizonMediaExt.Pos == "" {
err = &errortypes.BadInput{
Message: fmt.Sprintf("imp #%d: missing param pos", idx),
}
errors = append(errors, err)
continue
}

reqJSON, err := json.Marshal(request)
if err != nil {
errors = append(errors, err)
return nil, errors
}
// Split up multi-impression requests into multiple requests so that
// each split request is only associated to a single impression
reqCopy := *request
reqCopy.Imp = []openrtb.Imp{imp}

thisURI := a.URI
siteCopy := *request.Site
reqCopy.Site = &siteCopy

headers := http.Header{}
headers.Add("Content-Type", "application/json;charset=utf-8")
headers.Add("Accept", "application/json")
headers.Set("User-Agent", request.Device.UA)
headers.Add("x-openrtb-version", "2.5")
if err := changeRequestForBidService(&reqCopy, &verizonMediaExt); err != nil {
errors = append(errors, err)
continue
}

return []*adapters.RequestData{{
Method: "POST",
Uri: thisURI,
Body: reqJSON,
Headers: headers,
}}, errors
reqJSON, err := json.Marshal(&reqCopy)
if err != nil {
errors = append(errors, err)
continue
}

reqs = append(reqs, &adapters.RequestData{
Method: "POST",
Uri: a.URI,
Body: reqJSON,
Headers: headers,
})
}

return reqs, errors
}

func (a *VerizonMediaAdapter) MakeBids(internalRequest *openrtb.BidRequest, externalRequest *adapters.RequestData, response *adapters.ResponseData) (*adapters.BidderResponse, []error) {
Expand Down Expand Up @@ -166,12 +181,9 @@ func getImpInfo(impId string, imps []openrtb.Imp) (bool, openrtb_ext.BidType) {
}

func changeRequestForBidService(request *openrtb.BidRequest, extension *openrtb_ext.ExtImpVerizonMedia) error {
if request.Imp[0].TagID == "" {
request.Imp[0].TagID = extension.Pos
}
if request.Site.ID == "" {
request.Site.ID = extension.Dcn
}
/* Always override the tag ID and site ID of the request */
request.Imp[0].TagID = extension.Pos
request.Site.ID = extension.Dcn

if request.Imp[0].Banner == nil {
return nil
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
"banner": {
"format": [{"w": 728, "h": 90}]
},
"tagid": "123",
"ext": {
"bidder": {
"dcn": "dcn1",
Expand All @@ -20,7 +21,7 @@
"ip": "127.0.0.1"
},
"site": {
"id": ""
"id": "test-site-id"
}
},

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,5 @@
]
},

"expectedMakeRequestsErrors": ["ext.bidder not provided"]
"expectedMakeRequestsErrors": ["imp #0: ext.bidder not provided"]
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,5 +16,5 @@
"site": {}
},

"expectedMakeRequestsErrors": ["Missing param dcn"]
"expectedMakeRequestsErrors": ["imp #0: missing param dcn"]
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,5 +17,5 @@
"site": {}
},

"expectedMakeRequestsErrors": ["Missing param pos"]
"expectedMakeRequestsErrors": ["imp #0: missing param pos"]
}

0 comments on commit fd1c166

Please sign in to comment.