From bcfe9f2a92a8896182b689c77a6e2ad6b90cab0c Mon Sep 17 00:00:00 2001 From: guscarreon Date: Thu, 25 Mar 2021 13:16:48 -0400 Subject: [PATCH] Pubnative: Fix Shared Memory Overwriting (#1760) --- adapters/pubnative/pubnative.go | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/adapters/pubnative/pubnative.go b/adapters/pubnative/pubnative.go index 7d393f8ade9..9144d6ddaae 100644 --- a/adapters/pubnative/pubnative.go +++ b/adapters/pubnative/pubnative.go @@ -94,29 +94,35 @@ func convertImpression(imp *openrtb.Imp) error { } } if imp.Banner != nil { - err := convertBanner(imp.Banner) + bannerCopy, err := convertBanner(imp.Banner) if err != nil { return err } + imp.Banner = bannerCopy } return nil } // make sure that banner has openrtb 2.3-compatible size information -func convertBanner(banner *openrtb.Banner) error { +func convertBanner(banner *openrtb.Banner) (*openrtb.Banner, error) { if banner.W == nil || banner.H == nil || *banner.W == 0 || *banner.H == 0 { if len(banner.Format) > 0 { f := banner.Format[0] - banner.W = &f.W - banner.H = &f.H + + bannerCopy := *banner + + bannerCopy.W = openrtb.Uint64Ptr(f.W) + bannerCopy.H = openrtb.Uint64Ptr(f.H) + + return &bannerCopy, nil } else { - return &errortypes.BadInput{ + return nil, &errortypes.BadInput{ Message: "Size information missing for banner", } } } - return nil + return banner, nil } func (a *PubnativeAdapter) MakeBids(internalRequest *openrtb.BidRequest, externalRequest *adapters.RequestData, response *adapters.ResponseData) (*adapters.BidderResponse, []error) {