From c8bfa8909c34fc19974a89411a9d37da4ce825e0 Mon Sep 17 00:00:00 2001 From: Scott Kay Date: Mon, 23 Nov 2020 15:06:25 -0500 Subject: [PATCH 1/9] Work In Progress --- exchange/exchange.go | 7 ++++++ exchange/utils.go | 55 +++++++++++++++++++++++++++----------------- 2 files changed, 41 insertions(+), 21 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 7a9fbc7cf8d..95207c95d94 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -329,6 +329,13 @@ func (e *exchange) getAllBids(ctx context.Context, cleanRequests map[openrtb_ext chBids := make(chan *bidResponseWrapper, len(cleanRequests)) bidsFound := false + // NOTES ON BID LABEL USAGE: + // RecordAdapterRequest: .Adapter, .PubID, .AdapterBids, .AdapterErrors, .CookieFlag + // .RType + // RecordAdapterTime: .Adapter, .PubID + // RecordAdapterPrice: .Adapter, .PubID, + // RecordAdapterBidReceived: .Adapter, .PubID, + for bidderName, req := range cleanRequests { // Here we actually call the adapters and collect the bids. coreBidder := resolveBidder(string(bidderName), aliases) diff --git a/exchange/utils.go b/exchange/utils.go index 285f650cbc5..f3868b24e0d 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -47,6 +47,14 @@ func BidderToPrebidSChains(req *openrtb_ext.ExtRequest) (map[string]*openrtb_ext return bidderToSChains, nil } +// BidderRequest needs a good comment +type BidderRequest struct { + Request *openrtb.BidRequest + Name string + CoreName string + Labels pbsmetrics.AdapterLabels +} + // cleanOpenRTBRequests splits the input request into requests which are sanitized for each bidder. Intended behavior is: // // 1. BidRequest.Imp[].Ext will only contain the "prebid" field and a "bidder" field which has the params for the intended Bidder. @@ -61,7 +69,7 @@ func cleanOpenRTBRequests(ctx context.Context, gDPR gdpr.Permissions, usersyncIfAmbiguous bool, privacyConfig config.Privacy, - account *config.Account) (requestsByBidder map[openrtb_ext.BidderName]*openrtb.BidRequest, aliases map[string]string, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { + account *config.Account) (requestsByBidder []BidderRequest, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { impsByBidder, errs := splitImps(orig.Imp) if len(errs) > 0 { @@ -182,10 +190,10 @@ func splitBidRequest(req *openrtb.BidRequest, impsByBidder map[string][]openrtb.Imp, aliases map[string]string, usersyncs IdFetcher, - blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, - labels pbsmetrics.Labels) (map[openrtb_ext.BidderName]*openrtb.BidRequest, []error) { + labels pbsmetrics.Labels) ([]BidderRequest, []error) { + + bidderRequests := make([]BidderRequest, 0, len(impsByBidder)) - requestsByBidder := make(map[openrtb_ext.BidderName]*openrtb.BidRequest, len(impsByBidder)) explicitBuyerUIDs, err := extractBuyerUIDs(req.User) if err != nil { return nil, []error{err} @@ -204,30 +212,35 @@ func splitBidRequest(req *openrtb.BidRequest, } for bidder, imps := range impsByBidder { - reqCopy := *req coreBidder := resolveBidder(bidder, aliases) - newLabel := pbsmetrics.AdapterLabels{ - Source: labels.Source, - RType: labels.RType, - Adapter: coreBidder, - PubID: labels.PubID, - CookieFlag: labels.CookieFlag, - AdapterBids: pbsmetrics.AdapterBidPresent, + + reqCopy := *req + reqCopy.Imp = imps + reqCopy.Ext = reqExt + prepareSource(&reqCopy, bidder, sChainsByBidder) + + bidderRequest := BidderRequest{ + Name: bidder, + CoreName: coreBidder, + Request: &reqCopy, + Labels: pbsmetrics.AdapterLabels{ + Source: labels.Source, + RType: labels.RType, + Adapter: coreBidder, + PubID: labels.PubID, + CookieFlag: labels.CookieFlag, + AdapterBids: pbsmetrics.AdapterBidPresent, + }, } - blabels[coreBidder] = &newLabel if hadSync := prepareUser(&reqCopy, bidder, coreBidder, explicitBuyerUIDs, usersyncs); !hadSync && req.App == nil { - blabels[coreBidder].CookieFlag = pbsmetrics.CookieFlagNo + bidderRequest.Labels.CookieFlag = pbsmetrics.CookieFlagNo } else { - blabels[coreBidder].CookieFlag = pbsmetrics.CookieFlagYes + bidderRequest.Labels.CookieFlag = pbsmetrics.CookieFlagYes } - reqCopy.Imp = imps - - prepareSource(&reqCopy, bidder, sChainsByBidder) - reqCopy.Ext = reqExt - requestsByBidder[openrtb_ext.BidderName(bidder)] = &reqCopy + bidderRequests = append(bidderRequests, bidderRequest) } - return requestsByBidder, nil + return bidderRequests, nil } func getExtJson(req *openrtb.BidRequest, unpackedExt *openrtb_ext.ExtRequest) (json.RawMessage, error) { From 339b5690593381ff64d54d227030cd29480d383a Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Mon, 30 Nov 2020 05:56:50 -0500 Subject: [PATCH 2/9] Refactor splitBidRequest and cleanOpenRTBRequests args --- exchange/exchange.go | 57 ++++++++++++++++++------------- exchange/utils.go | 81 ++++++++++++++++++-------------------------- 2 files changed, 66 insertions(+), 72 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 95207c95d94..8ed02fe8e1e 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -92,21 +92,31 @@ func NewExchange(adapters map[openrtb_ext.BidderName]adaptedBidder, cache prebid GDPR: cfg.GDPR, LMT: cfg.LMT, }, - } -} - +// AuctionRequest holds the bid request for the auction +// and all other information needed to process that request type AuctionRequest struct { BidRequest *openrtb.BidRequest Account config.Account UserSyncs IdFetcher - RequestType pbsmetrics.RequestType StartTime time.Time + RequestType pbsmetrics.RequestType // LegacyLabels is included here for temporary compatability with cleanOpenRTBRequests // in HoldAuction until we get to factoring it away. Do not use for anything new. LegacyLabels pbsmetrics.Labels } +// Bidder holds the bidder specific request and all other +// information needed by to process that request. +type Bidder struct { + Request *openrtb.BidRequest + Name openrtb_ext.BidderName + CoreName openrtb_ext.BidderName + Labels pbsmetrics.AdapterLabels +} + } +} + func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog *DebugLog) (*openrtb.BidResponse, error) { var err error requestExt, err := extractBidRequestExt(r.BidRequest) @@ -134,12 +144,12 @@ func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog * // Slice of BidRequests, each a copy of the original cleaned to only contain bidder data for the named bidder blabels := make(map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels) - cleanRequests, aliases, privacyLabels, errs := cleanOpenRTBRequests(ctx, r.BidRequest, requestExt, r.UserSyncs, blabels, r.LegacyLabels, e.gDPR, usersyncIfAmbiguous, e.privacyConfig, &r.Account) + reqBidders, privacyLabels, errs := cleanOpenRTBRequests(ctx, r, requestExt, blabels, e.gDPR, usersyncIfAmbiguous, e.privacyConfig) e.me.RecordRequestPrivacy(privacyLabels) // List of bidders we have requests for. - liveAdapters := listBiddersWithRequests(cleanRequests) + liveAdapters := listBiddersWithRequests(reqBidders) // If we need to cache bids, then it will take some time to call prebid cache. // We should reduce the amount of time the bidders have, to compensate. @@ -149,7 +159,7 @@ func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog * // Get currency rates conversions for the auction conversions := e.currencyConverter.Rates() - adapterBids, adapterExtra, anyBidsReturned := e.getAllBids(auctionCtx, cleanRequests, aliases, bidAdjustmentFactors, blabels, conversions) + adapterBids, adapterExtra, anyBidsReturned := e.getAllBids(auctionCtx, reqBidders, bidAdjustmentFactors, blabels, conversions) var auc *auction var cacheErrs []error @@ -322,11 +332,11 @@ func (e *exchange) makeAuctionContext(ctx context.Context, needsCache bool) (auc } // This piece sends all the requests to the bidder adapters and gathers the results. -func (e *exchange) getAllBids(ctx context.Context, cleanRequests map[openrtb_ext.BidderName]*openrtb.BidRequest, aliases map[string]string, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { +func (e *exchange) getAllBids(ctx context.Context, reqBidders []Bidder, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { // Set up pointers to the bid results - adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(cleanRequests)) - adapterExtra := make(map[openrtb_ext.BidderName]*seatResponseExtra, len(cleanRequests)) - chBids := make(chan *bidResponseWrapper, len(cleanRequests)) + adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(reqBidders)) + adapterExtra := make(map[openrtb_ext.BidderName]*seatResponseExtra, len(reqBidders)) + chBids := make(chan *bidResponseWrapper, len(reqBidders)) bidsFound := false // NOTES ON BID LABEL USAGE: @@ -336,14 +346,13 @@ func (e *exchange) getAllBids(ctx context.Context, cleanRequests map[openrtb_ext // RecordAdapterPrice: .Adapter, .PubID, // RecordAdapterBidReceived: .Adapter, .PubID, - for bidderName, req := range cleanRequests { + for _, bidder := range reqBidders { // Here we actually call the adapters and collect the bids. - coreBidder := resolveBidder(string(bidderName), aliases) - bidderRunner := e.recoverSafely(cleanRequests, func(aName openrtb_ext.BidderName, coreBidder openrtb_ext.BidderName, request *openrtb.BidRequest, bidlabels *pbsmetrics.AdapterLabels, conversions currencies.Conversions) { + bidderRunner := e.recoverSafely(reqBidders, func(aName openrtb_ext.BidderName, coreBidder openrtb_ext.BidderName, request *openrtb.BidRequest, bidlabels *pbsmetrics.AdapterLabels, conversions currencies.Conversions) { // Passing in aName so a doesn't change out from under the go routine if bidlabels.Adapter == "" { glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", aName, coreBidder) - bidlabels.Adapter = coreBidder + bidlabels.Adapter = bidder.CoreName } brw := new(bidResponseWrapper) brw.bidder = aName @@ -388,10 +397,10 @@ func (e *exchange) getAllBids(ctx context.Context, cleanRequests map[openrtb_ext } chBids <- brw }, chBids) - go bidderRunner(bidderName, coreBidder, req, blabels[coreBidder], conversions) + go bidderRunner(bidder.Name, bidder.CoreName, bidder.Request, blabels[bidder.CoreName], conversions) } // Wait for the bidders to do their thing - for i := 0; i < len(cleanRequests); i++ { + for i := 0; i < len(reqBidders); i++ { brw := <-chBids //if bidder returned no bids back - remove bidder from further processing @@ -409,15 +418,15 @@ func (e *exchange) getAllBids(ctx context.Context, cleanRequests map[openrtb_ext return adapterBids, adapterExtra, bidsFound } -func (e *exchange) recoverSafely(cleanRequests map[openrtb_ext.BidderName]*openrtb.BidRequest, inner func(openrtb_ext.BidderName, openrtb_ext.BidderName, *openrtb.BidRequest, *pbsmetrics.AdapterLabels, currencies.Conversions), chBids chan *bidResponseWrapper) func(openrtb_ext.BidderName, openrtb_ext.BidderName, *openrtb.BidRequest, *pbsmetrics.AdapterLabels, currencies.Conversions) { +func (e *exchange) recoverSafely(bidders []Bidder, inner func(openrtb_ext.BidderName, openrtb_ext.BidderName, *openrtb.BidRequest, *pbsmetrics.AdapterLabels, currencies.Conversions), chBids chan *bidResponseWrapper) func(openrtb_ext.BidderName, openrtb_ext.BidderName, *openrtb.BidRequest, *pbsmetrics.AdapterLabels, currencies.Conversions) { return func(aName openrtb_ext.BidderName, coreBidder openrtb_ext.BidderName, request *openrtb.BidRequest, bidlabels *pbsmetrics.AdapterLabels, conversions currencies.Conversions) { defer func() { if r := recover(); r != nil { allBidders := "" sb := strings.Builder{} - for k := range cleanRequests { - sb.WriteString(string(k)) + for _, bidder := range bidders { + sb.WriteString(bidder.Name.String()) sb.WriteString(",") } if sb.Len() > 0 { @@ -874,11 +883,11 @@ func buildCacheURL(cache prebid_cache_client.Client, uuid string) string { return strings.TrimPrefix(cacheURL.String(), "//") } -func listBiddersWithRequests(cleanRequests map[openrtb_ext.BidderName]*openrtb.BidRequest) []openrtb_ext.BidderName { - liveAdapters := make([]openrtb_ext.BidderName, len(cleanRequests)) +func listBiddersWithRequests(bidders []Bidder) []openrtb_ext.BidderName { + liveAdapters := make([]openrtb_ext.BidderName, len(bidders)) i := 0 - for a := range cleanRequests { - liveAdapters[i] = a + for _, bidder := range bidders { + liveAdapters[i] = bidder.Name i++ } // Randomize the list of adapters to make the auction more fair diff --git a/exchange/utils.go b/exchange/utils.go index f3868b24e0d..e56df72e359 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -47,61 +47,50 @@ func BidderToPrebidSChains(req *openrtb_ext.ExtRequest) (map[string]*openrtb_ext return bidderToSChains, nil } -// BidderRequest needs a good comment -type BidderRequest struct { - Request *openrtb.BidRequest - Name string - CoreName string - Labels pbsmetrics.AdapterLabels -} - // cleanOpenRTBRequests splits the input request into requests which are sanitized for each bidder. Intended behavior is: // // 1. BidRequest.Imp[].Ext will only contain the "prebid" field and a "bidder" field which has the params for the intended Bidder. // 2. Every BidRequest.Imp[] requested Bids from the Bidder who keys it. // 3. BidRequest.User.BuyerUID will be set to that Bidder's ID. func cleanOpenRTBRequests(ctx context.Context, - orig *openrtb.BidRequest, + req AuctionRequest, requestExt *openrtb_ext.ExtRequest, - usersyncs IdFetcher, blables map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, - labels pbsmetrics.Labels, gDPR gdpr.Permissions, usersyncIfAmbiguous bool, - privacyConfig config.Privacy, - account *config.Account) (requestsByBidder []BidderRequest, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { + privacyConfig config.Privacy) (reqBidders []Bidder, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { - impsByBidder, errs := splitImps(orig.Imp) + impsByBidder, errs := splitImps(req.BidRequest.Imp) if len(errs) > 0 { return } - aliases, errs = parseAliases(orig) + aliases, errs := parseAliases(req.BidRequest) if len(errs) > 0 { return } - requestsByBidder, errs = splitBidRequest(orig, requestExt, impsByBidder, aliases, usersyncs, blables, labels) + reqBidders, errs = getAuctionReqBidders(req, requestExt, impsByBidder, aliases) - if len(requestsByBidder) == 0 { + if len(reqBidders) == 0 { return } - gdpr := extractGDPR(orig, usersyncIfAmbiguous) - consent := extractConsent(orig) - ampGDPRException := (labels.RType == pbsmetrics.ReqTypeAMP) && gDPR.AMPException() + gdpr := extractGDPR(req.BidRequest, usersyncIfAmbiguous) + consent := extractConsent(req.BidRequest) + ampGDPRException := (req.LegacyLabels.RType == pbsmetrics.ReqTypeAMP) && gDPR.AMPException() - ccpaEnforcer, err := extractCCPA(orig, privacyConfig, account, aliases, integrationTypeMap[labels.RType]) + ccpaEnforcer, err := extractCCPA(req.BidRequest, privacyConfig, &req.Account, aliases, integrationTypeMap[req.LegacyLabels.RType]) if err != nil { errs = append(errs, err) return } - lmtEnforcer := extractLMT(orig, privacyConfig) + lmtEnforcer := extractLMT(req.BidRequest, privacyConfig) // request level privacy policies privacyEnforcement := privacy.Enforcement{ - COPPA: orig.Regs != nil && orig.Regs.COPPA == 1, + COPPA: req.BidRequest.Regs != nil && req.BidRequest.Regs.COPPA == 1, LMT: lmtEnforcer.ShouldEnforce(unknownBidder), } @@ -110,7 +99,7 @@ func cleanOpenRTBRequests(ctx context.Context, privacyLabels.COPPAEnforced = privacyEnforcement.COPPA privacyLabels.LMTEnforced = lmtEnforcer.ShouldEnforce(unknownBidder) - gdprEnabled := gdprEnabled(account, privacyConfig, integrationTypeMap[labels.RType]) + gdprEnabled := gdprEnabled(&req.Account, privacyConfig, integrationTypeMap[req.LegacyLabels.RType]) if gdpr == 1 && gdprEnabled { privacyLabels.GDPREnforced = true @@ -122,16 +111,14 @@ func cleanOpenRTBRequests(ctx context.Context, } // bidder level privacy policies - for bidder, bidReq := range requestsByBidder { + for _, bidder := range reqBidders { // CCPA - privacyEnforcement.CCPA = ccpaEnforcer.ShouldEnforce(bidder.String()) + privacyEnforcement.CCPA = ccpaEnforcer.ShouldEnforce(bidder.Name.String()) // GDPR if gdpr == 1 && gdprEnabled { - coreBidder := resolveBidder(bidder.String(), aliases) - - var publisherID = labels.PubID - _, geo, id, err := gDPR.PersonalInfoAllowed(ctx, coreBidder, publisherID, consent) + var publisherID = req.LegacyLabels.PubID + _, geo, id, err := gDPR.PersonalInfoAllowed(ctx, bidder.CoreName, publisherID, consent) privacyEnforcement.GDPRGeo = !geo && err == nil privacyEnforcement.GDPRID = !id && err == nil } else { @@ -139,7 +126,7 @@ func cleanOpenRTBRequests(ctx context.Context, privacyEnforcement.GDPRID = false } - privacyEnforcement.Apply(bidReq, ampGDPRException) + privacyEnforcement.Apply(bidder.Request, ampGDPRException) } return @@ -185,16 +172,14 @@ func extractLMT(orig *openrtb.BidRequest, privacyConfig config.Privacy) privacy. } } -func splitBidRequest(req *openrtb.BidRequest, +func getAuctionReqBidders(req AuctionRequest, requestExt *openrtb_ext.ExtRequest, impsByBidder map[string][]openrtb.Imp, - aliases map[string]string, - usersyncs IdFetcher, - labels pbsmetrics.Labels) ([]BidderRequest, []error) { + aliases map[string]string) ([]Bidder, []error) { - bidderRequests := make([]BidderRequest, 0, len(impsByBidder)) + reqBidders := make([]Bidder, 0, len(impsByBidder)) - explicitBuyerUIDs, err := extractBuyerUIDs(req.User) + explicitBuyerUIDs, err := extractBuyerUIDs(req.BidRequest.User) if err != nil { return nil, []error{err} } @@ -206,7 +191,7 @@ func splitBidRequest(req *openrtb.BidRequest, return nil, []error{err} } - reqExt, err := getExtJson(req, requestExt) + reqExt, err := getExtJson(req.BidRequest, requestExt) if err != nil { return nil, []error{err} } @@ -214,33 +199,33 @@ func splitBidRequest(req *openrtb.BidRequest, for bidder, imps := range impsByBidder { coreBidder := resolveBidder(bidder, aliases) - reqCopy := *req + reqCopy := *req.BidRequest reqCopy.Imp = imps reqCopy.Ext = reqExt prepareSource(&reqCopy, bidder, sChainsByBidder) - bidderRequest := BidderRequest{ - Name: bidder, + bidder := Bidder{ + Name: openrtb_ext.BidderName(bidder), CoreName: coreBidder, Request: &reqCopy, Labels: pbsmetrics.AdapterLabels{ - Source: labels.Source, - RType: labels.RType, + Source: req.LegacyLabels.Source, + RType: req.LegacyLabels.RType, Adapter: coreBidder, PubID: labels.PubID, CookieFlag: labels.CookieFlag, AdapterBids: pbsmetrics.AdapterBidPresent, }, } - if hadSync := prepareUser(&reqCopy, bidder, coreBidder, explicitBuyerUIDs, usersyncs); !hadSync && req.App == nil { - bidderRequest.Labels.CookieFlag = pbsmetrics.CookieFlagNo + if hadSync := prepareUser(&reqCopy, bidder.Name.String(), coreBidder, explicitBuyerUIDs, req.UserSyncs); !hadSync && req.BidRequest.App == nil { + bidder.Labels.CookieFlag = pbsmetrics.CookieFlagNo } else { - bidderRequest.Labels.CookieFlag = pbsmetrics.CookieFlagYes + bidder.Labels.CookieFlag = pbsmetrics.CookieFlagYes } - bidderRequests = append(bidderRequests, bidderRequest) + reqBidders = append(reqBidders, bidder) } - return bidderRequests, nil + return reqBidders, nil } func getExtJson(req *openrtb.BidRequest, unpackedExt *openrtb_ext.ExtRequest) (json.RawMessage, error) { From 789e480e8c1ab3a97c59d27944b1df0d85ce5e30 Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Mon, 30 Nov 2020 08:16:06 -0500 Subject: [PATCH 3/9] Refactor recoverSafely args --- exchange/exchange.go | 40 ++++++++++++++++++++-------------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 8ed02fe8e1e..22ea18d5fe6 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -348,27 +348,27 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []Bidder, bidAdjus for _, bidder := range reqBidders { // Here we actually call the adapters and collect the bids. - bidderRunner := e.recoverSafely(reqBidders, func(aName openrtb_ext.BidderName, coreBidder openrtb_ext.BidderName, request *openrtb.BidRequest, bidlabels *pbsmetrics.AdapterLabels, conversions currencies.Conversions) { + bidderRunner := e.recoverSafely(reqBidders, func(bidder Bidder, conversions currencies.Conversions) { // Passing in aName so a doesn't change out from under the go routine - if bidlabels.Adapter == "" { - glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", aName, coreBidder) - bidlabels.Adapter = bidder.CoreName + if bidder.Labels.Adapter == "" { + glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", bidder.Name, bidder.CoreName) + bidder.Labels.Adapter = bidder.CoreName } brw := new(bidResponseWrapper) - brw.bidder = aName + brw.bidder = bidder.Name // Defer basic metrics to insure we capture them after all the values have been set defer func() { - e.me.RecordAdapterRequest(*bidlabels) + e.me.RecordAdapterRequest(bidder.Labels) }() start := time.Now() adjustmentFactor := 1.0 - if givenAdjustment, ok := bidAdjustments[string(aName)]; ok { + if givenAdjustment, ok := bidAdjustments[string(bidder.Name)]; ok { adjustmentFactor = givenAdjustment } var reqInfo adapters.ExtraRequestInfo - reqInfo.PbsEntryPoint = bidlabels.RType - bids, err := e.adapterMap[coreBidder].requestBid(ctx, request, aName, adjustmentFactor, conversions, &reqInfo) + reqInfo.PbsEntryPoint = bidder.Labels.RType + bids, err := e.adapterMap[bidder.CoreName].requestBid(ctx, bidder.Request, bidder.Name, adjustmentFactor, conversions, &reqInfo) // Add in time reporting elapsed := time.Since(start) @@ -381,23 +381,23 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []Bidder, bidAdjus } // Timing statistics - e.me.RecordAdapterTime(*bidlabels, time.Since(start)) + e.me.RecordAdapterTime(bidder.Labels, time.Since(start)) serr := errsToBidderErrors(err) - bidlabels.AdapterBids = bidsToMetric(brw.adapterBids) - bidlabels.AdapterErrors = errorsToMetric(err) + bidder.Labels.AdapterBids = bidsToMetric(brw.adapterBids) + bidder.Labels.AdapterErrors = errorsToMetric(err) // Append any bid validation errors to the error list ae.Errors = serr brw.adapterExtra = ae if bids != nil { for _, bid := range bids.bids { var cpm = float64(bid.bid.Price * 1000) - e.me.RecordAdapterPrice(*bidlabels, cpm) - e.me.RecordAdapterBidReceived(*bidlabels, bid.bidType, bid.bid.AdM != "") + e.me.RecordAdapterPrice(bidder.Labels, cpm) + e.me.RecordAdapterBidReceived(bidder.Labels, bid.bidType, bid.bid.AdM != "") } } chBids <- brw }, chBids) - go bidderRunner(bidder.Name, bidder.CoreName, bidder.Request, blabels[bidder.CoreName], conversions) + go bidderRunner(bidder, conversions) } // Wait for the bidders to do their thing for i := 0; i < len(reqBidders); i++ { @@ -418,8 +418,8 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []Bidder, bidAdjus return adapterBids, adapterExtra, bidsFound } -func (e *exchange) recoverSafely(bidders []Bidder, inner func(openrtb_ext.BidderName, openrtb_ext.BidderName, *openrtb.BidRequest, *pbsmetrics.AdapterLabels, currencies.Conversions), chBids chan *bidResponseWrapper) func(openrtb_ext.BidderName, openrtb_ext.BidderName, *openrtb.BidRequest, *pbsmetrics.AdapterLabels, currencies.Conversions) { - return func(aName openrtb_ext.BidderName, coreBidder openrtb_ext.BidderName, request *openrtb.BidRequest, bidlabels *pbsmetrics.AdapterLabels, conversions currencies.Conversions) { +func (e *exchange) recoverSafely(bidders []Bidder, inner func(Bidder, currencies.Conversions), chBids chan *bidResponseWrapper) func(Bidder, currencies.Conversions) { + return func(bidder Bidder, conversions currencies.Conversions) { defer func() { if r := recover(); r != nil { @@ -435,15 +435,15 @@ func (e *exchange) recoverSafely(bidders []Bidder, inner func(openrtb_ext.Bidder glog.Errorf("OpenRTB auction recovered panic from Bidder %s: %v. "+ "Account id: %s, All Bidders: %s, Stack trace is: %v", - coreBidder, r, bidlabels.PubID, allBidders, string(debug.Stack())) - e.me.RecordAdapterPanic(*bidlabels) + bidder.CoreName, r, bidder.Labels.PubID, allBidders, string(debug.Stack())) + e.me.RecordAdapterPanic(bidder.Labels) // Let the master request know that there is no data here brw := new(bidResponseWrapper) brw.adapterExtra = new(seatResponseExtra) chBids <- brw } }() - inner(aName, coreBidder, request, bidlabels, conversions) + inner(bidder, conversions) } } From 5821cdf1cc861c769425d518e95f60851004ad78 Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Tue, 1 Dec 2020 08:39:10 -0500 Subject: [PATCH 4/9] Change name from Bidder to AuctionRequestBidder --- exchange/exchange.go | 23 ++++++++--------------- exchange/utils.go | 14 +++++++------- 2 files changed, 15 insertions(+), 22 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 22ea18d5fe6..44b31c51d47 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -106,9 +106,9 @@ type AuctionRequest struct { LegacyLabels pbsmetrics.Labels } -// Bidder holds the bidder specific request and all other +// AuctionRequestBidder holds the bidder specific request and all other // information needed by to process that request. -type Bidder struct { +type AuctionRequestBidder struct { Request *openrtb.BidRequest Name openrtb_ext.BidderName CoreName openrtb_ext.BidderName @@ -332,23 +332,16 @@ func (e *exchange) makeAuctionContext(ctx context.Context, needsCache bool) (auc } // This piece sends all the requests to the bidder adapters and gathers the results. -func (e *exchange) getAllBids(ctx context.Context, reqBidders []Bidder, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { +func (e *exchange) getAllBids(ctx context.Context, reqBidders []AuctionRequestBidder, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { // Set up pointers to the bid results adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(reqBidders)) adapterExtra := make(map[openrtb_ext.BidderName]*seatResponseExtra, len(reqBidders)) chBids := make(chan *bidResponseWrapper, len(reqBidders)) bidsFound := false - // NOTES ON BID LABEL USAGE: - // RecordAdapterRequest: .Adapter, .PubID, .AdapterBids, .AdapterErrors, .CookieFlag - // .RType - // RecordAdapterTime: .Adapter, .PubID - // RecordAdapterPrice: .Adapter, .PubID, - // RecordAdapterBidReceived: .Adapter, .PubID, - for _, bidder := range reqBidders { // Here we actually call the adapters and collect the bids. - bidderRunner := e.recoverSafely(reqBidders, func(bidder Bidder, conversions currencies.Conversions) { + bidderRunner := e.recoverSafely(reqBidders, func(bidder AuctionRequestBidder, conversions currencies.Conversions) { // Passing in aName so a doesn't change out from under the go routine if bidder.Labels.Adapter == "" { glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", bidder.Name, bidder.CoreName) @@ -418,14 +411,14 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []Bidder, bidAdjus return adapterBids, adapterExtra, bidsFound } -func (e *exchange) recoverSafely(bidders []Bidder, inner func(Bidder, currencies.Conversions), chBids chan *bidResponseWrapper) func(Bidder, currencies.Conversions) { - return func(bidder Bidder, conversions currencies.Conversions) { +func (e *exchange) recoverSafely(reqBidders []AuctionRequestBidder, inner func(AuctionRequestBidder, currencies.Conversions), chBids chan *bidResponseWrapper) func(AuctionRequestBidder, currencies.Conversions) { + return func(bidder AuctionRequestBidder, conversions currencies.Conversions) { defer func() { if r := recover(); r != nil { allBidders := "" sb := strings.Builder{} - for _, bidder := range bidders { + for _, bidder := range reqBidders { sb.WriteString(bidder.Name.String()) sb.WriteString(",") } @@ -883,7 +876,7 @@ func buildCacheURL(cache prebid_cache_client.Client, uuid string) string { return strings.TrimPrefix(cacheURL.String(), "//") } -func listBiddersWithRequests(bidders []Bidder) []openrtb_ext.BidderName { +func listBiddersWithRequests(bidders []AuctionRequestBidder) []openrtb_ext.BidderName { liveAdapters := make([]openrtb_ext.BidderName, len(bidders)) i := 0 for _, bidder := range bidders { diff --git a/exchange/utils.go b/exchange/utils.go index e56df72e359..ee0e6fa2052 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -51,14 +51,14 @@ func BidderToPrebidSChains(req *openrtb_ext.ExtRequest) (map[string]*openrtb_ext // // 1. BidRequest.Imp[].Ext will only contain the "prebid" field and a "bidder" field which has the params for the intended Bidder. // 2. Every BidRequest.Imp[] requested Bids from the Bidder who keys it. -// 3. BidRequest.User.BuyerUID will be set to that Bidder's ID. +// 3. BidRequest.User.BuyerUID will be set to that AuctionRequestBidder's ID. func cleanOpenRTBRequests(ctx context.Context, req AuctionRequest, requestExt *openrtb_ext.ExtRequest, blables map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, gDPR gdpr.Permissions, usersyncIfAmbiguous bool, - privacyConfig config.Privacy) (reqBidders []Bidder, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { + privacyConfig config.Privacy) (reqBidders []AuctionRequestBidder, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { impsByBidder, errs := splitImps(req.BidRequest.Imp) if len(errs) > 0 { @@ -70,7 +70,7 @@ func cleanOpenRTBRequests(ctx context.Context, return } - reqBidders, errs = getAuctionReqBidders(req, requestExt, impsByBidder, aliases) + reqBidders, errs = getAuctionRequestBidders(req, requestExt, impsByBidder, aliases) if len(reqBidders) == 0 { return @@ -172,12 +172,12 @@ func extractLMT(orig *openrtb.BidRequest, privacyConfig config.Privacy) privacy. } } -func getAuctionReqBidders(req AuctionRequest, +func getAuctionRequestBidders(req AuctionRequest, requestExt *openrtb_ext.ExtRequest, impsByBidder map[string][]openrtb.Imp, - aliases map[string]string) ([]Bidder, []error) { + aliases map[string]string) ([]AuctionRequestBidder, []error) { - reqBidders := make([]Bidder, 0, len(impsByBidder)) + reqBidders := make([]AuctionRequestBidder, 0, len(impsByBidder)) explicitBuyerUIDs, err := extractBuyerUIDs(req.BidRequest.User) if err != nil { @@ -204,7 +204,7 @@ func getAuctionReqBidders(req AuctionRequest, reqCopy.Ext = reqExt prepareSource(&reqCopy, bidder, sChainsByBidder) - bidder := Bidder{ + bidder := AuctionRequestBidder{ Name: openrtb_ext.BidderName(bidder), CoreName: coreBidder, Request: &reqCopy, From 85ffc00321444dd16cb8051bddcc306a4cda875b Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Tue, 1 Dec 2020 09:05:03 -0500 Subject: [PATCH 5/9] Go back to BidderRequest from AuctionRequestBidder --- exchange/exchange.go | 78 +++++++++++++++++++++++--------------------- exchange/utils.go | 42 ++++++++++++------------ 2 files changed, 61 insertions(+), 59 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 44b31c51d47..d93a5d28dfd 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -106,13 +106,13 @@ type AuctionRequest struct { LegacyLabels pbsmetrics.Labels } -// AuctionRequestBidder holds the bidder specific request and all other +// BidderRequest holds the bidder specific request and all other // information needed by to process that request. -type AuctionRequestBidder struct { - Request *openrtb.BidRequest - Name openrtb_ext.BidderName - CoreName openrtb_ext.BidderName - Labels pbsmetrics.AdapterLabels +type BidderRequest struct { + BidRequest *openrtb.BidRequest + BidderName openrtb_ext.BidderName + BidderCoreName openrtb_ext.BidderName + BidderLabels pbsmetrics.AdapterLabels } } } @@ -144,12 +144,12 @@ func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog * // Slice of BidRequests, each a copy of the original cleaned to only contain bidder data for the named bidder blabels := make(map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels) - reqBidders, privacyLabels, errs := cleanOpenRTBRequests(ctx, r, requestExt, blabels, e.gDPR, usersyncIfAmbiguous, e.privacyConfig) + bidderRequests, privacyLabels, errs := cleanOpenRTBRequests(ctx, r, requestExt, blabels, e.gDPR, usersyncIfAmbiguous, e.privacyConfig) e.me.RecordRequestPrivacy(privacyLabels) // List of bidders we have requests for. - liveAdapters := listBiddersWithRequests(reqBidders) + liveAdapters := listBiddersWithRequests(bidderRequests) // If we need to cache bids, then it will take some time to call prebid cache. // We should reduce the amount of time the bidders have, to compensate. @@ -159,7 +159,7 @@ func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog * // Get currency rates conversions for the auction conversions := e.currencyConverter.Rates() - adapterBids, adapterExtra, anyBidsReturned := e.getAllBids(auctionCtx, reqBidders, bidAdjustmentFactors, blabels, conversions) + adapterBids, adapterExtra, anyBidsReturned := e.getAllBids(auctionCtx, bidderRequests, bidAdjustmentFactors, blabels, conversions) var auc *auction var cacheErrs []error @@ -332,36 +332,36 @@ func (e *exchange) makeAuctionContext(ctx context.Context, needsCache bool) (auc } // This piece sends all the requests to the bidder adapters and gathers the results. -func (e *exchange) getAllBids(ctx context.Context, reqBidders []AuctionRequestBidder, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { +func (e *exchange) getAllBids(ctx context.Context, bidderRequests []BidderRequest, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { // Set up pointers to the bid results - adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(reqBidders)) - adapterExtra := make(map[openrtb_ext.BidderName]*seatResponseExtra, len(reqBidders)) - chBids := make(chan *bidResponseWrapper, len(reqBidders)) + adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(bidderRequests)) + adapterExtra := make(map[openrtb_ext.BidderName]*seatResponseExtra, len(bidderRequests)) + chBids := make(chan *bidResponseWrapper, len(bidderRequests)) bidsFound := false - for _, bidder := range reqBidders { + for _, bidder := range bidderRequests { // Here we actually call the adapters and collect the bids. - bidderRunner := e.recoverSafely(reqBidders, func(bidder AuctionRequestBidder, conversions currencies.Conversions) { + bidderRunner := e.recoverSafely(bidderRequests, func(bidderRequest BidderRequest, conversions currencies.Conversions) { // Passing in aName so a doesn't change out from under the go routine - if bidder.Labels.Adapter == "" { - glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", bidder.Name, bidder.CoreName) - bidder.Labels.Adapter = bidder.CoreName + if bidder.BidderLabels.Adapter == "" { + glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", bidder.BidderName, bidder.BidderCoreName) + bidder.BidderLabels.Adapter = bidder.BidderCoreName } brw := new(bidResponseWrapper) - brw.bidder = bidder.Name + brw.bidder = bidder.BidderName // Defer basic metrics to insure we capture them after all the values have been set defer func() { - e.me.RecordAdapterRequest(bidder.Labels) + e.me.RecordAdapterRequest(bidder.BidderLabels) }() start := time.Now() adjustmentFactor := 1.0 - if givenAdjustment, ok := bidAdjustments[string(bidder.Name)]; ok { + if givenAdjustment, ok := bidAdjustments[string(bidder.BidderName)]; ok { adjustmentFactor = givenAdjustment } var reqInfo adapters.ExtraRequestInfo - reqInfo.PbsEntryPoint = bidder.Labels.RType - bids, err := e.adapterMap[bidder.CoreName].requestBid(ctx, bidder.Request, bidder.Name, adjustmentFactor, conversions, &reqInfo) + reqInfo.PbsEntryPoint = bidder.BidderLabels.RType + bids, err := e.adapterMap[bidder.BidderCoreName].requestBid(ctx, bidder.BidRequest, bidder.BidderName, adjustmentFactor, conversions, &reqInfo) // Add in time reporting elapsed := time.Since(start) @@ -374,18 +374,18 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []AuctionRequestBi } // Timing statistics - e.me.RecordAdapterTime(bidder.Labels, time.Since(start)) + e.me.RecordAdapterTime(bidder.BidderLabels, time.Since(start)) serr := errsToBidderErrors(err) - bidder.Labels.AdapterBids = bidsToMetric(brw.adapterBids) - bidder.Labels.AdapterErrors = errorsToMetric(err) + bidder.BidderLabels.AdapterBids = bidsToMetric(brw.adapterBids) + bidder.BidderLabels.AdapterErrors = errorsToMetric(err) // Append any bid validation errors to the error list ae.Errors = serr brw.adapterExtra = ae if bids != nil { for _, bid := range bids.bids { var cpm = float64(bid.bid.Price * 1000) - e.me.RecordAdapterPrice(bidder.Labels, cpm) - e.me.RecordAdapterBidReceived(bidder.Labels, bid.bidType, bid.bid.AdM != "") + e.me.RecordAdapterPrice(bidder.BidderLabels, cpm) + e.me.RecordAdapterBidReceived(bidder.BidderLabels, bid.bidType, bid.bid.AdM != "") } } chBids <- brw @@ -393,7 +393,7 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []AuctionRequestBi go bidderRunner(bidder, conversions) } // Wait for the bidders to do their thing - for i := 0; i < len(reqBidders); i++ { + for i := 0; i < len(bidderRequests); i++ { brw := <-chBids //if bidder returned no bids back - remove bidder from further processing @@ -411,15 +411,17 @@ func (e *exchange) getAllBids(ctx context.Context, reqBidders []AuctionRequestBi return adapterBids, adapterExtra, bidsFound } -func (e *exchange) recoverSafely(reqBidders []AuctionRequestBidder, inner func(AuctionRequestBidder, currencies.Conversions), chBids chan *bidResponseWrapper) func(AuctionRequestBidder, currencies.Conversions) { - return func(bidder AuctionRequestBidder, conversions currencies.Conversions) { +func (e *exchange) recoverSafely(bidderRequests []BidderRequest, + inner func(BidderRequest, currencies.Conversions), + chBids chan *bidResponseWrapper) func(BidderRequest, currencies.Conversions) { + return func(bidderRequest BidderRequest, conversions currencies.Conversions) { defer func() { if r := recover(); r != nil { allBidders := "" sb := strings.Builder{} - for _, bidder := range reqBidders { - sb.WriteString(bidder.Name.String()) + for _, bidder := range bidderRequests { + sb.WriteString(bidder.BidderName.String()) sb.WriteString(",") } if sb.Len() > 0 { @@ -428,15 +430,15 @@ func (e *exchange) recoverSafely(reqBidders []AuctionRequestBidder, inner func(A glog.Errorf("OpenRTB auction recovered panic from Bidder %s: %v. "+ "Account id: %s, All Bidders: %s, Stack trace is: %v", - bidder.CoreName, r, bidder.Labels.PubID, allBidders, string(debug.Stack())) - e.me.RecordAdapterPanic(bidder.Labels) + bidderRequest.BidderCoreName, r, bidderRequest.BidderLabels.PubID, allBidders, string(debug.Stack())) + e.me.RecordAdapterPanic(bidderRequest.BidderLabels) // Let the master request know that there is no data here brw := new(bidResponseWrapper) brw.adapterExtra = new(seatResponseExtra) chBids <- brw } }() - inner(bidder, conversions) + inner(bidderRequest, conversions) } } @@ -876,11 +878,11 @@ func buildCacheURL(cache prebid_cache_client.Client, uuid string) string { return strings.TrimPrefix(cacheURL.String(), "//") } -func listBiddersWithRequests(bidders []AuctionRequestBidder) []openrtb_ext.BidderName { +func listBiddersWithRequests(bidders []BidderRequest) []openrtb_ext.BidderName { liveAdapters := make([]openrtb_ext.BidderName, len(bidders)) i := 0 for _, bidder := range bidders { - liveAdapters[i] = bidder.Name + liveAdapters[i] = bidder.BidderName i++ } // Randomize the list of adapters to make the auction more fair diff --git a/exchange/utils.go b/exchange/utils.go index ee0e6fa2052..f571650059b 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -51,14 +51,14 @@ func BidderToPrebidSChains(req *openrtb_ext.ExtRequest) (map[string]*openrtb_ext // // 1. BidRequest.Imp[].Ext will only contain the "prebid" field and a "bidder" field which has the params for the intended Bidder. // 2. Every BidRequest.Imp[] requested Bids from the Bidder who keys it. -// 3. BidRequest.User.BuyerUID will be set to that AuctionRequestBidder's ID. +// 3. BidRequest.User.BuyerUID will be set to that Bidder's ID. func cleanOpenRTBRequests(ctx context.Context, req AuctionRequest, requestExt *openrtb_ext.ExtRequest, blables map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, gDPR gdpr.Permissions, usersyncIfAmbiguous bool, - privacyConfig config.Privacy) (reqBidders []AuctionRequestBidder, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { + privacyConfig config.Privacy) (bidderRequests []BidderRequest, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { impsByBidder, errs := splitImps(req.BidRequest.Imp) if len(errs) > 0 { @@ -70,9 +70,9 @@ func cleanOpenRTBRequests(ctx context.Context, return } - reqBidders, errs = getAuctionRequestBidders(req, requestExt, impsByBidder, aliases) + bidderRequests, errs = getAuctionBidderRequests(req, requestExt, impsByBidder, aliases) - if len(reqBidders) == 0 { + if len(bidderRequests) == 0 { return } @@ -111,14 +111,14 @@ func cleanOpenRTBRequests(ctx context.Context, } // bidder level privacy policies - for _, bidder := range reqBidders { + for _, bidder := range bidderRequests { // CCPA - privacyEnforcement.CCPA = ccpaEnforcer.ShouldEnforce(bidder.Name.String()) + privacyEnforcement.CCPA = ccpaEnforcer.ShouldEnforce(bidder.BidderName.String()) // GDPR if gdpr == 1 && gdprEnabled { var publisherID = req.LegacyLabels.PubID - _, geo, id, err := gDPR.PersonalInfoAllowed(ctx, bidder.CoreName, publisherID, consent) + _, geo, id, err := gDPR.PersonalInfoAllowed(ctx, bidder.BidderCoreName, publisherID, consent) privacyEnforcement.GDPRGeo = !geo && err == nil privacyEnforcement.GDPRID = !id && err == nil } else { @@ -126,7 +126,7 @@ func cleanOpenRTBRequests(ctx context.Context, privacyEnforcement.GDPRID = false } - privacyEnforcement.Apply(bidder.Request, ampGDPRException) + privacyEnforcement.Apply(bidder.BidRequest, ampGDPRException) } return @@ -172,12 +172,12 @@ func extractLMT(orig *openrtb.BidRequest, privacyConfig config.Privacy) privacy. } } -func getAuctionRequestBidders(req AuctionRequest, +func getAuctionBidderRequests(req AuctionRequest, requestExt *openrtb_ext.ExtRequest, impsByBidder map[string][]openrtb.Imp, - aliases map[string]string) ([]AuctionRequestBidder, []error) { + aliases map[string]string) ([]BidderRequest, []error) { - reqBidders := make([]AuctionRequestBidder, 0, len(impsByBidder)) + bidderRequests := make([]BidderRequest, 0, len(impsByBidder)) explicitBuyerUIDs, err := extractBuyerUIDs(req.BidRequest.User) if err != nil { @@ -204,11 +204,11 @@ func getAuctionRequestBidders(req AuctionRequest, reqCopy.Ext = reqExt prepareSource(&reqCopy, bidder, sChainsByBidder) - bidder := AuctionRequestBidder{ - Name: openrtb_ext.BidderName(bidder), - CoreName: coreBidder, - Request: &reqCopy, - Labels: pbsmetrics.AdapterLabels{ + bidder := BidderRequest{ + BidderName: openrtb_ext.BidderName(bidder), + BidderCoreName: coreBidder, + BidRequest: &reqCopy, + BidderLabels: pbsmetrics.AdapterLabels{ Source: req.LegacyLabels.Source, RType: req.LegacyLabels.RType, Adapter: coreBidder, @@ -217,15 +217,15 @@ func getAuctionRequestBidders(req AuctionRequest, AdapterBids: pbsmetrics.AdapterBidPresent, }, } - if hadSync := prepareUser(&reqCopy, bidder.Name.String(), coreBidder, explicitBuyerUIDs, req.UserSyncs); !hadSync && req.BidRequest.App == nil { - bidder.Labels.CookieFlag = pbsmetrics.CookieFlagNo + if hadSync := prepareUser(&reqCopy, bidder.BidderName.String(), coreBidder, explicitBuyerUIDs, req.UserSyncs); !hadSync && req.BidRequest.App == nil { + bidder.BidderLabels.CookieFlag = pbsmetrics.CookieFlagNo } else { - bidder.Labels.CookieFlag = pbsmetrics.CookieFlagYes + bidder.BidderLabels.CookieFlag = pbsmetrics.CookieFlagYes } - reqBidders = append(reqBidders, bidder) + bidderRequests = append(bidderRequests, bidder) } - return reqBidders, nil + return bidderRequests, nil } func getExtJson(req *openrtb.BidRequest, unpackedExt *openrtb_ext.ExtRequest) (json.RawMessage, error) { From f8bbf0fd6603bd71699bcaf139931ef2312ed511 Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Tue, 1 Dec 2020 10:40:48 -0500 Subject: [PATCH 6/9] Update tests --- exchange/exchange.go | 31 ++++---- exchange/exchange_test.go | 34 ++++++--- exchange/utils_test.go | 148 +++++++++++++++++++++++--------------- 3 files changed, 132 insertions(+), 81 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index d93a5d28dfd..034eb9b67b4 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -332,7 +332,10 @@ func (e *exchange) makeAuctionContext(ctx context.Context, needsCache bool) (auc } // This piece sends all the requests to the bidder adapters and gathers the results. -func (e *exchange) getAllBids(ctx context.Context, bidderRequests []BidderRequest, bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { +func (e *exchange) getAllBids(ctx context.Context, bidderRequests []BidderRequest, + bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, + conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, + map[openrtb_ext.BidderName]*seatResponseExtra, bool) { // Set up pointers to the bid results adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(bidderRequests)) adapterExtra := make(map[openrtb_ext.BidderName]*seatResponseExtra, len(bidderRequests)) @@ -343,25 +346,25 @@ func (e *exchange) getAllBids(ctx context.Context, bidderRequests []BidderReques // Here we actually call the adapters and collect the bids. bidderRunner := e.recoverSafely(bidderRequests, func(bidderRequest BidderRequest, conversions currencies.Conversions) { // Passing in aName so a doesn't change out from under the go routine - if bidder.BidderLabels.Adapter == "" { - glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", bidder.BidderName, bidder.BidderCoreName) - bidder.BidderLabels.Adapter = bidder.BidderCoreName + if bidderRequest.BidderLabels.Adapter == "" { + glog.Errorf("Exchange: bidlables for %s (%s) missing adapter string", bidderRequest.BidderName, bidderRequest.BidderCoreName) + bidderRequest.BidderLabels.Adapter = bidderRequest.BidderCoreName } brw := new(bidResponseWrapper) - brw.bidder = bidder.BidderName + brw.bidder = bidderRequest.BidderName // Defer basic metrics to insure we capture them after all the values have been set defer func() { - e.me.RecordAdapterRequest(bidder.BidderLabels) + e.me.RecordAdapterRequest(bidderRequest.BidderLabels) }() start := time.Now() adjustmentFactor := 1.0 - if givenAdjustment, ok := bidAdjustments[string(bidder.BidderName)]; ok { + if givenAdjustment, ok := bidAdjustments[string(bidderRequest.BidderName)]; ok { adjustmentFactor = givenAdjustment } var reqInfo adapters.ExtraRequestInfo - reqInfo.PbsEntryPoint = bidder.BidderLabels.RType - bids, err := e.adapterMap[bidder.BidderCoreName].requestBid(ctx, bidder.BidRequest, bidder.BidderName, adjustmentFactor, conversions, &reqInfo) + reqInfo.PbsEntryPoint = bidderRequest.BidderLabels.RType + bids, err := e.adapterMap[bidderRequest.BidderCoreName].requestBid(ctx, bidderRequest.BidRequest, bidderRequest.BidderName, adjustmentFactor, conversions, &reqInfo) // Add in time reporting elapsed := time.Since(start) @@ -374,18 +377,18 @@ func (e *exchange) getAllBids(ctx context.Context, bidderRequests []BidderReques } // Timing statistics - e.me.RecordAdapterTime(bidder.BidderLabels, time.Since(start)) + e.me.RecordAdapterTime(bidderRequest.BidderLabels, time.Since(start)) serr := errsToBidderErrors(err) - bidder.BidderLabels.AdapterBids = bidsToMetric(brw.adapterBids) - bidder.BidderLabels.AdapterErrors = errorsToMetric(err) + bidderRequest.BidderLabels.AdapterBids = bidsToMetric(brw.adapterBids) + bidderRequest.BidderLabels.AdapterErrors = errorsToMetric(err) // Append any bid validation errors to the error list ae.Errors = serr brw.adapterExtra = ae if bids != nil { for _, bid := range bids.bids { var cpm = float64(bid.bid.Price * 1000) - e.me.RecordAdapterPrice(bidder.BidderLabels, cpm) - e.me.RecordAdapterBidReceived(bidder.BidderLabels, bid.bidType, bid.bid.AdM != "") + e.me.RecordAdapterPrice(bidderRequest.BidderLabels, cpm) + e.me.RecordAdapterBidReceived(bidderRequest.BidderLabels, bid.bidType, bid.bid.AdM != "") } } chBids <- brw diff --git a/exchange/exchange_test.go b/exchange/exchange_test.go index c2db87133ae..1d32ca3c6d1 100644 --- a/exchange/exchange_test.go +++ b/exchange/exchange_test.go @@ -1152,18 +1152,10 @@ func TestPanicRecovery(t *testing.T) { e := NewExchange(adapters, nil, cfg, &metricsConf.DummyMetricsEngine{}, gdpr.AlwaysAllow{}, currencyConverter, nilCategoryFetcher{}).(*exchange) chBids := make(chan *bidResponseWrapper, 1) - panicker := func(aName openrtb_ext.BidderName, coreBidder openrtb_ext.BidderName, request *openrtb.BidRequest, bidlabels *pbsmetrics.AdapterLabels, conversions currencies.Conversions) { + panicker := func(bidderRequest BidderRequest, conversions currencies.Conversions) { panic("panic!") } - cleanReqs := map[openrtb_ext.BidderName]*openrtb.BidRequest{ - "bidder1": { - ID: "b-1", - }, - "bidder2": { - ID: "b-2", - }, - } - recovered := e.recoverSafely(cleanReqs, panicker, chBids) + apnLabels := pbsmetrics.AdapterLabels{ Source: pbsmetrics.DemandWeb, RType: pbsmetrics.ReqTypeORTB2Web, @@ -1172,7 +1164,27 @@ func TestPanicRecovery(t *testing.T) { CookieFlag: pbsmetrics.CookieFlagYes, AdapterBids: pbsmetrics.AdapterBidNone, } - recovered(openrtb_ext.BidderAppnexus, openrtb_ext.BidderAppnexus, nil, &apnLabels, nil) + + bidderRequests := []BidderRequest{ + { + BidderName: "bidder1", + BidderCoreName: "appnexus", + BidderLabels: apnLabels, + BidRequest: &openrtb.BidRequest{ + ID: "b-1", + }, + }, + { + BidderName: "bidder2", + BidderCoreName: "bidder2", + BidRequest: &openrtb.BidRequest{ + ID: "b-2", + }, + }, + } + + recovered := e.recoverSafely(bidderRequests, panicker, chBids) + recovered(bidderRequests[0], nil) } func buildImpExt(t *testing.T, jsonFilename string) json.RawMessage { diff --git a/exchange/utils_test.go b/exchange/utils_test.go index e2aa72e04fc..5d794013537 100644 --- a/exchange/utils_test.go +++ b/exchange/utils_test.go @@ -38,38 +38,48 @@ func (p *permissionsMock) AMPException() bool { return false } -func assertReq(t *testing.T, reqByBidders map[openrtb_ext.BidderName]*openrtb.BidRequest, +func assertReq(t *testing.T, bidderRequests []BidderRequest, applyCOPPA bool, consentedVendors map[string]bool) { // assert individual bidder requests - assert.NotEqual(t, reqByBidders, 0, "cleanOpenRTBRequest should split request into individual bidder requests") + assert.NotEqual(t, bidderRequests, 0, "cleanOpenRTBRequest should split request into individual bidder requests") // assert for PI data // Both appnexus and brightroll should be allowed since brightroll // is used as an alias for appnexus in the test request - for bidderName, bidder := range reqByBidders { - if !applyCOPPA && consentedVendors[bidderName.String()] { - assert.NotEqual(t, bidder.User.BuyerUID, "", "cleanOpenRTBRequest shouldn't clean PI data as per COPPA or for a consented vendor as per GDPR or per CCPA") - assert.NotEqual(t, bidder.Device.DIDMD5, "", "cleanOpenRTBRequest shouldn't clean PI data as per COPPA or for a consented vendor as per GDPR or per CCPA") + for _, req := range bidderRequests { + if !applyCOPPA && consentedVendors[req.BidderName.String()] { + assert.NotEqual(t, req.BidRequest.User.BuyerUID, "", "cleanOpenRTBRequest shouldn't clean PI data as per COPPA or for a consented vendor as per GDPR or per CCPA") + assert.NotEqual(t, req.BidRequest.Device.DIDMD5, "", "cleanOpenRTBRequest shouldn't clean PI data as per COPPA or for a consented vendor as per GDPR or per CCPA") } else { - assert.Equal(t, bidder.User.BuyerUID, "", "cleanOpenRTBRequest should clean PI data as per COPPA or for a non-consented vendor as per GDPR or per CCPA", bidderName.String()) - assert.Equal(t, bidder.Device.DIDMD5, "", "cleanOpenRTBRequest should clean PI data as per COPPA or for a non-consented vendor as per GDPR or per CCPA", bidderName.String()) + assert.Equal(t, req.BidRequest.User.BuyerUID, "", "cleanOpenRTBRequest should clean PI data as per COPPA or for a non-consented vendor as per GDPR or per CCPA", req.BidderName.String()) + assert.Equal(t, req.BidRequest.Device.DIDMD5, "", "cleanOpenRTBRequest should clean PI data as per COPPA or for a non-consented vendor as per GDPR or per CCPA", req.BidderName.String()) } } } func TestCleanOpenRTBRequests(t *testing.T) { testCases := []struct { - req *openrtb.BidRequest - bidReqAssertions func(t *testing.T, reqByBidders map[openrtb_ext.BidderName]*openrtb.BidRequest, + req AuctionRequest + bidReqAssertions func(t *testing.T, bidderRequests []BidderRequest, applyCOPPA bool, consentedVendors map[string]bool) hasError bool applyCOPPA bool consentedVendors map[string]bool }{ - {req: newRaceCheckingRequest(t), bidReqAssertions: assertReq, hasError: false, - applyCOPPA: true, consentedVendors: map[string]bool{"appnexus": true}}, - {req: newAdapterAliasBidRequest(t), bidReqAssertions: assertReq, hasError: false, - applyCOPPA: false, consentedVendors: map[string]bool{"appnexus": true, "brightroll": true}}, + { + req: AuctionRequest{BidRequest: newRaceCheckingRequest(t), UserSyncs: &emptyUsersync{}}, + bidReqAssertions: assertReq, + hasError: false, + applyCOPPA: true, + consentedVendors: map[string]bool{"appnexus": true}, + }, + { + req: AuctionRequest{BidRequest: newAdapterAliasBidRequest(t), UserSyncs: &emptyUsersync{}}, + bidReqAssertions: assertReq, + hasError: false, + applyCOPPA: false, + consentedVendors: map[string]bool{"appnexus": true, "brightroll": true}, + }, } privacyConfig := config.Privacy{ @@ -82,12 +92,12 @@ func TestCleanOpenRTBRequests(t *testing.T) { } for _, test := range testCases { - reqByBidders, _, _, err := cleanOpenRTBRequests(context.Background(), test.req, nil, &emptyUsersync{}, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, pbsmetrics.Labels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig, &config.Account{}) + bidderRequests, _, err := cleanOpenRTBRequests(context.Background(), test.req, nil, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) if test.hasError { assert.NotNil(t, err, "Error shouldn't be nil") } else { assert.Nil(t, err, "Err should be nil") - test.bidReqAssertions(t, reqByBidders, test.applyCOPPA, test.consentedVendors) + test.bidReqAssertions(t, bidderRequests, test.applyCOPPA, test.consentedVendors) } } } @@ -227,26 +237,29 @@ func TestCleanOpenRTBRequestsCCPA(t *testing.T) { }, } - results, _, privacyLabels, errs := cleanOpenRTBRequests( + auctionReq := AuctionRequest{ + BidRequest: req, + UserSyncs: &emptyUsersync{}, + Account: accountConfig, + } + + bidderRequests, privacyLabels, errs := cleanOpenRTBRequests( context.Background(), - req, + auctionReq, nil, - &emptyUsersync{}, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, - pbsmetrics.Labels{}, &permissionsMock{personalInfoAllowed: true}, true, - privacyConfig, - &accountConfig) - result := results["appnexus"] + privacyConfig) + result := bidderRequests[0] assert.Nil(t, errs) if test.expectDataScrub { - assert.Equal(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.Equal(t, result.Device.DIDMD5, "", test.description+":Device.DIDMD5") + assert.Equal(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.Equal(t, result.BidRequest.Device.DIDMD5, "", test.description+":Device.DIDMD5") } else { - assert.NotEqual(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.NotEqual(t, result.Device.DIDMD5, "", test.description+":Device.DIDMD5") + assert.NotEqual(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.NotEqual(t, result.BidRequest.Device.DIDMD5, "", test.description+":Device.DIDMD5") } assert.Equal(t, test.expectPrivacyLabels, privacyLabels, test.description+":PrivacyLabels") } @@ -282,12 +295,17 @@ func TestCleanOpenRTBRequestsCCPAErrors(t *testing.T) { err := json.Unmarshal(req.Ext, &reqExtStruct) assert.NoError(t, err, test.description+":marshal_ext") + auctionReq := AuctionRequest{ + BidRequest: req, + UserSyncs: &emptyUsersync{}, + } + privacyConfig := config.Privacy{ CCPA: config.CCPA{ Enforce: true, }, } - _, _, _, errs := cleanOpenRTBRequests(context.Background(), req, &reqExtStruct, &emptyUsersync{}, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, pbsmetrics.Labels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig, &config.Account{}) + _, _, errs := cleanOpenRTBRequests(context.Background(), auctionReq, &reqExtStruct, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) assert.ElementsMatch(t, []error{test.expectError}, errs, test.description) } @@ -322,16 +340,21 @@ func TestCleanOpenRTBRequestsCOPPA(t *testing.T) { req := newBidRequest(t) req.Regs = &openrtb.Regs{COPPA: test.coppa} - results, _, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), req, nil, &emptyUsersync{}, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, pbsmetrics.Labels{}, &permissionsMock{personalInfoAllowed: true}, true, config.Privacy{}, &config.Account{}) - result := results["appnexus"] + auctionReq := AuctionRequest{ + BidRequest: req, + UserSyncs: &emptyUsersync{}, + } + + bidderRequests, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), auctionReq, nil, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, config.Privacy{}) + result := bidderRequests[0] assert.Nil(t, errs) if test.expectDataScrub { - assert.Equal(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.Equal(t, result.User.Yob, int64(0), test.description+":User.Yob") + assert.Equal(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.Equal(t, result.BidRequest.User.Yob, int64(0), test.description+":User.Yob") } else { - assert.NotEqual(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.NotEqual(t, result.User.Yob, int64(0), test.description+":User.Yob") + assert.NotEqual(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.NotEqual(t, result.BidRequest.User.Yob, int64(0), test.description+":User.Yob") } assert.Equal(t, test.expectPrivacyLabels, privacyLabels, test.description+":PrivacyLabels") } @@ -424,16 +447,20 @@ func TestCleanOpenRTBRequestsSChain(t *testing.T) { extRequest = unmarshaledExt } - results, _, _, errs := cleanOpenRTBRequests(context.Background(), req, extRequest, &emptyUsersync{}, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, pbsmetrics.Labels{}, &permissionsMock{}, true, config.Privacy{}, &config.Account{}) - result := results["appnexus"] + auctionReq := AuctionRequest{ + BidRequest: req, + UserSyncs: &emptyUsersync{}, + } + bidderRequests, _, errs := cleanOpenRTBRequests(context.Background(), auctionReq, extRequest, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{}, true, config.Privacy{}) if test.hasError == true { assert.NotNil(t, errs) - assert.Nil(t, result) + assert.Len(t, bidderRequests, 0) } else { + result := bidderRequests[0] assert.Nil(t, errs) - assert.Equal(t, test.outSourceExt, result.Source.Ext, test.description+":Source.Ext") - assert.Equal(t, test.outRequestExt, result.Ext, test.description+":Ext") + assert.Equal(t, test.outSourceExt, result.BidRequest.Source.Ext, test.description+":Source.Ext") + assert.Equal(t, test.outRequestExt, result.BidRequest.Ext, test.description+":Ext") } } } @@ -995,22 +1022,27 @@ func TestCleanOpenRTBRequestsLMT(t *testing.T) { req := newBidRequest(t) req.Device.Lmt = test.lmt + auctionReq := AuctionRequest{ + BidRequest: req, + UserSyncs: &emptyUsersync{}, + } + privacyConfig := config.Privacy{ LMT: config.LMT{ Enforce: test.enforceLMT, }, } - results, _, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), req, nil, &emptyUsersync{}, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, pbsmetrics.Labels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig, &config.Account{}) - result := results["appnexus"] + results, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), auctionReq, nil, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) + result := results[0] assert.Nil(t, errs) if test.expectDataScrub { - assert.Equal(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.Equal(t, result.Device.DIDMD5, "", test.description+":Device.DIDMD5") + assert.Equal(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.Equal(t, result.BidRequest.Device.DIDMD5, "", test.description+":Device.DIDMD5") } else { - assert.NotEqual(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.NotEqual(t, result.Device.DIDMD5, "", test.description+":Device.DIDMD5") + assert.NotEqual(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.NotEqual(t, result.BidRequest.Device.DIDMD5, "", test.description+":Device.DIDMD5") } assert.Equal(t, test.expectPrivacyLabels, privacyLabels, test.description+":PrivacyLabels") } @@ -1148,26 +1180,30 @@ func TestCleanOpenRTBRequestsGDPR(t *testing.T) { }, } - results, _, privacyLabels, errs := cleanOpenRTBRequests( + auctionReq := AuctionRequest{ + BidRequest: req, + UserSyncs: &emptyUsersync{}, + Account: accountConfig, + } + + results, privacyLabels, errs := cleanOpenRTBRequests( context.Background(), - req, + auctionReq, nil, - &emptyUsersync{}, + map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, - pbsmetrics.Labels{}, &permissionsMock{personalInfoAllowed: !test.gdprScrub}, true, - privacyConfig, - &accountConfig) - result := results["appnexus"] + privacyConfig) + result := results[0] assert.Nil(t, errs) if test.gdprScrub { - assert.Equal(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.Equal(t, result.Device.DIDMD5, "", test.description+":Device.DIDMD5") + assert.Equal(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.Equal(t, result.BidRequest.Device.DIDMD5, "", test.description+":Device.DIDMD5") } else { - assert.NotEqual(t, result.User.BuyerUID, "", test.description+":User.BuyerUID") - assert.NotEqual(t, result.Device.DIDMD5, "", test.description+":Device.DIDMD5") + assert.NotEqual(t, result.BidRequest.User.BuyerUID, "", test.description+":User.BuyerUID") + assert.NotEqual(t, result.BidRequest.Device.DIDMD5, "", test.description+":Device.DIDMD5") } assert.Equal(t, test.expectPrivacyLabels, privacyLabels, test.description+":PrivacyLabels") } From 8f45c6db78dee618248d4f112c7d6f1c439638c9 Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Fri, 4 Dec 2020 07:28:14 -0500 Subject: [PATCH 7/9] Merge confict mistake --- exchange/exchange.go | 15 ++++++++------- exchange/utils.go | 8 ++++---- 2 files changed, 12 insertions(+), 11 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 034eb9b67b4..438292063e8 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -92,14 +92,17 @@ func NewExchange(adapters map[openrtb_ext.BidderName]adaptedBidder, cache prebid GDPR: cfg.GDPR, LMT: cfg.LMT, }, + } +} + // AuctionRequest holds the bid request for the auction // and all other information needed to process that request type AuctionRequest struct { BidRequest *openrtb.BidRequest Account config.Account UserSyncs IdFetcher - StartTime time.Time RequestType pbsmetrics.RequestType + StartTime time.Time // LegacyLabels is included here for temporary compatability with cleanOpenRTBRequests // in HoldAuction until we get to factoring it away. Do not use for anything new. @@ -107,15 +110,13 @@ type AuctionRequest struct { } // BidderRequest holds the bidder specific request and all other -// information needed by to process that request. +// information needed to process that bidder request. type BidderRequest struct { BidRequest *openrtb.BidRequest BidderName openrtb_ext.BidderName BidderCoreName openrtb_ext.BidderName BidderLabels pbsmetrics.AdapterLabels } - } -} func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog *DebugLog) (*openrtb.BidResponse, error) { var err error @@ -881,11 +882,11 @@ func buildCacheURL(cache prebid_cache_client.Client, uuid string) string { return strings.TrimPrefix(cacheURL.String(), "//") } -func listBiddersWithRequests(bidders []BidderRequest) []openrtb_ext.BidderName { +func listBiddersWithRequests(bidderRequests []BidderRequest) []openrtb_ext.BidderName { liveAdapters := make([]openrtb_ext.BidderName, len(bidders)) i := 0 - for _, bidder := range bidders { - liveAdapters[i] = bidder.BidderName + for _, bidderRequest := range bidderRequests { + liveAdapters[i] = bidderRequest.BidderName i++ } // Randomize the list of adapters to make the auction more fair diff --git a/exchange/utils.go b/exchange/utils.go index f571650059b..68b7cecbce4 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -111,14 +111,14 @@ func cleanOpenRTBRequests(ctx context.Context, } // bidder level privacy policies - for _, bidder := range bidderRequests { + for _, bidderRequest := range bidderRequests { // CCPA - privacyEnforcement.CCPA = ccpaEnforcer.ShouldEnforce(bidder.BidderName.String()) + privacyEnforcement.CCPA = ccpaEnforcer.ShouldEnforce(bidderRequest.BidderName.String()) // GDPR if gdpr == 1 && gdprEnabled { var publisherID = req.LegacyLabels.PubID - _, geo, id, err := gDPR.PersonalInfoAllowed(ctx, bidder.BidderCoreName, publisherID, consent) + _, geo, id, err := gDPR.PersonalInfoAllowed(ctx, bidderRequest.BidderCoreName, publisherID, consent) privacyEnforcement.GDPRGeo = !geo && err == nil privacyEnforcement.GDPRID = !id && err == nil } else { @@ -126,7 +126,7 @@ func cleanOpenRTBRequests(ctx context.Context, privacyEnforcement.GDPRID = false } - privacyEnforcement.Apply(bidder.BidRequest, ampGDPRException) + privacyEnforcement.Apply(bidderRequest.BidRequest, ampGDPRException) } return From 2868d19dc9a9fdd5aa90947366c4798bf3fc9081 Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Fri, 4 Dec 2020 11:44:33 -0500 Subject: [PATCH 8/9] Fix build error --- exchange/exchange.go | 2 +- exchange/utils.go | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 438292063e8..03ae7a51191 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -883,7 +883,7 @@ func buildCacheURL(cache prebid_cache_client.Client, uuid string) string { } func listBiddersWithRequests(bidderRequests []BidderRequest) []openrtb_ext.BidderName { - liveAdapters := make([]openrtb_ext.BidderName, len(bidders)) + liveAdapters := make([]openrtb_ext.BidderName, len(bidderRequests)) i := 0 for _, bidderRequest := range bidderRequests { liveAdapters[i] = bidderRequest.BidderName diff --git a/exchange/utils.go b/exchange/utils.go index 68b7cecbce4..4d2586db06e 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -212,8 +212,8 @@ func getAuctionBidderRequests(req AuctionRequest, Source: req.LegacyLabels.Source, RType: req.LegacyLabels.RType, Adapter: coreBidder, - PubID: labels.PubID, - CookieFlag: labels.CookieFlag, + PubID: req.LegacyLabels.PubID, + CookieFlag: req.LegacyLabels.CookieFlag, AdapterBids: pbsmetrics.AdapterBidPresent, }, } From 3a398d6e6e7aec738ddb661d9e63e417d018faf7 Mon Sep 17 00:00:00 2001 From: Mansi Nahar Date: Wed, 9 Dec 2020 08:23:31 -0500 Subject: [PATCH 9/9] Remove unused blabels --- exchange/exchange.go | 14 ++++++++------ exchange/utils.go | 1 - exchange/utils_test.go | 13 +++++-------- 3 files changed, 13 insertions(+), 15 deletions(-) diff --git a/exchange/exchange.go b/exchange/exchange.go index 03ae7a51191..c4d25662afc 100644 --- a/exchange/exchange.go +++ b/exchange/exchange.go @@ -144,8 +144,7 @@ func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog * usersyncIfAmbiguous := e.parseUsersyncIfAmbiguous(r.BidRequest) // Slice of BidRequests, each a copy of the original cleaned to only contain bidder data for the named bidder - blabels := make(map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels) - bidderRequests, privacyLabels, errs := cleanOpenRTBRequests(ctx, r, requestExt, blabels, e.gDPR, usersyncIfAmbiguous, e.privacyConfig) + bidderRequests, privacyLabels, errs := cleanOpenRTBRequests(ctx, r, requestExt, e.gDPR, usersyncIfAmbiguous, e.privacyConfig) e.me.RecordRequestPrivacy(privacyLabels) @@ -160,7 +159,7 @@ func (e *exchange) HoldAuction(ctx context.Context, r AuctionRequest, debugLog * // Get currency rates conversions for the auction conversions := e.currencyConverter.Rates() - adapterBids, adapterExtra, anyBidsReturned := e.getAllBids(auctionCtx, bidderRequests, bidAdjustmentFactors, blabels, conversions) + adapterBids, adapterExtra, anyBidsReturned := e.getAllBids(auctionCtx, bidderRequests, bidAdjustmentFactors, conversions) var auc *auction var cacheErrs []error @@ -333,9 +332,12 @@ func (e *exchange) makeAuctionContext(ctx context.Context, needsCache bool) (auc } // This piece sends all the requests to the bidder adapters and gathers the results. -func (e *exchange) getAllBids(ctx context.Context, bidderRequests []BidderRequest, - bidAdjustments map[string]float64, blabels map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, - conversions currencies.Conversions) (map[openrtb_ext.BidderName]*pbsOrtbSeatBid, +func (e *exchange) getAllBids( + ctx context.Context, + bidderRequests []BidderRequest, + bidAdjustments map[string]float64, + conversions currencies.Conversions) ( + map[openrtb_ext.BidderName]*pbsOrtbSeatBid, map[openrtb_ext.BidderName]*seatResponseExtra, bool) { // Set up pointers to the bid results adapterBids := make(map[openrtb_ext.BidderName]*pbsOrtbSeatBid, len(bidderRequests)) diff --git a/exchange/utils.go b/exchange/utils.go index 4d2586db06e..4a1c8bb52b7 100644 --- a/exchange/utils.go +++ b/exchange/utils.go @@ -55,7 +55,6 @@ func BidderToPrebidSChains(req *openrtb_ext.ExtRequest) (map[string]*openrtb_ext func cleanOpenRTBRequests(ctx context.Context, req AuctionRequest, requestExt *openrtb_ext.ExtRequest, - blables map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels, gDPR gdpr.Permissions, usersyncIfAmbiguous bool, privacyConfig config.Privacy) (bidderRequests []BidderRequest, privacyLabels pbsmetrics.PrivacyLabels, errs []error) { diff --git a/exchange/utils_test.go b/exchange/utils_test.go index 5d794013537..2f24af2a06c 100644 --- a/exchange/utils_test.go +++ b/exchange/utils_test.go @@ -92,7 +92,7 @@ func TestCleanOpenRTBRequests(t *testing.T) { } for _, test := range testCases { - bidderRequests, _, err := cleanOpenRTBRequests(context.Background(), test.req, nil, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) + bidderRequests, _, err := cleanOpenRTBRequests(context.Background(), test.req, nil, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) if test.hasError { assert.NotNil(t, err, "Error shouldn't be nil") } else { @@ -247,7 +247,6 @@ func TestCleanOpenRTBRequestsCCPA(t *testing.T) { context.Background(), auctionReq, nil, - map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) @@ -305,7 +304,7 @@ func TestCleanOpenRTBRequestsCCPAErrors(t *testing.T) { Enforce: true, }, } - _, _, errs := cleanOpenRTBRequests(context.Background(), auctionReq, &reqExtStruct, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) + _, _, errs := cleanOpenRTBRequests(context.Background(), auctionReq, &reqExtStruct, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) assert.ElementsMatch(t, []error{test.expectError}, errs, test.description) } @@ -345,7 +344,7 @@ func TestCleanOpenRTBRequestsCOPPA(t *testing.T) { UserSyncs: &emptyUsersync{}, } - bidderRequests, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), auctionReq, nil, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, config.Privacy{}) + bidderRequests, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), auctionReq, nil, &permissionsMock{personalInfoAllowed: true}, true, config.Privacy{}) result := bidderRequests[0] assert.Nil(t, errs) @@ -452,7 +451,7 @@ func TestCleanOpenRTBRequestsSChain(t *testing.T) { UserSyncs: &emptyUsersync{}, } - bidderRequests, _, errs := cleanOpenRTBRequests(context.Background(), auctionReq, extRequest, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{}, true, config.Privacy{}) + bidderRequests, _, errs := cleanOpenRTBRequests(context.Background(), auctionReq, extRequest, &permissionsMock{}, true, config.Privacy{}) if test.hasError == true { assert.NotNil(t, errs) assert.Len(t, bidderRequests, 0) @@ -1033,7 +1032,7 @@ func TestCleanOpenRTBRequestsLMT(t *testing.T) { }, } - results, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), auctionReq, nil, map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) + results, privacyLabels, errs := cleanOpenRTBRequests(context.Background(), auctionReq, nil, &permissionsMock{personalInfoAllowed: true}, true, privacyConfig) result := results[0] assert.Nil(t, errs) @@ -1190,8 +1189,6 @@ func TestCleanOpenRTBRequestsGDPR(t *testing.T) { context.Background(), auctionReq, nil, - - map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels{}, &permissionsMock{personalInfoAllowed: !test.gdprScrub}, true, privacyConfig)