Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pubmatic: Bidder Updates #3652

Merged
merged 2 commits into from
Jan 2, 2025
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
import org.apache.commons.collections4.CollectionUtils;
import org.apache.commons.lang3.ObjectUtils;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.tuple.Pair;
import org.prebid.server.bidder.Bidder;
import org.prebid.server.bidder.model.BidderBid;
import org.prebid.server.bidder.model.BidderCall;
Expand All @@ -32,6 +33,8 @@
import org.prebid.server.exception.PreBidException;
import org.prebid.server.json.DecodeException;
import org.prebid.server.json.JacksonMapper;
import org.prebid.server.proto.openrtb.ext.FlexibleExtension;
import org.prebid.server.proto.openrtb.ext.request.ExtApp;
import org.prebid.server.proto.openrtb.ext.request.ExtRequest;
import org.prebid.server.proto.openrtb.ext.request.ExtRequestPrebid;
import org.prebid.server.proto.openrtb.ext.request.pubmatic.ExtImpPubmatic;
Expand Down Expand Up @@ -90,9 +93,12 @@ public Result<List<HttpRequest<BidRequest>>> makeHttpRequests(BidRequest request
String publisherId = null;
PubmaticWrapper wrapper;
final List<String> acat;
final Pair<String, String> displayManagerFields;

try {
acat = extractAcat(request);
wrapper = extractWrapper(request);
displayManagerFields = extractDisplayManagerFields(request);
} catch (IllegalArgumentException e) {
return Result.withError(BidderError.badInput(e.getMessage()));
}
Expand All @@ -110,7 +116,7 @@ public Result<List<HttpRequest<BidRequest>>> makeHttpRequests(BidRequest request

wrapper = merge(wrapper, extImpPubmatic.getWrapper());

validImps.add(modifyImp(imp, impExt));
validImps.add(modifyImp(imp, impExt, displayManagerFields.getLeft(), displayManagerFields.getRight()));
} catch (PreBidException e) {
errors.add(BidderError.badInput(e.getMessage()));
}
Expand All @@ -124,6 +130,30 @@ public Result<List<HttpRequest<BidRequest>>> makeHttpRequests(BidRequest request
return Result.of(Collections.singletonList(makeHttpRequest(modifiedBidRequest)), errors);
}

private Pair<String, String> extractDisplayManagerFields(BidRequest request) {
final Optional<ExtApp> optionalExtApp = Optional.ofNullable(request.getApp())
.map(App::getExt);

return optionalExtApp.map(ExtApp::getPrebid)
.filter(extAppPrebid -> StringUtils.isNoneBlank(extAppPrebid.getSource(), extAppPrebid.getVersion()))
.map(extAppPrebid -> Pair.of(extAppPrebid.getSource(), extAppPrebid.getVersion()))
.or(() -> optionalExtApp
.filter(extApp -> StringUtils.isNoneBlank(
getPropertyValue(extApp, "source"),
getPropertyValue(extApp, "version")))
.map(extApp -> Pair.of(
extApp.getProperty("source").asText(),
extApp.getProperty("version").asText())))
.orElse(Pair.of(null, null));
}

private static String getPropertyValue(FlexibleExtension flexibleExtension, String propertyName) {
return Optional.ofNullable(flexibleExtension.getProperty(propertyName))
.filter(JsonNode::isValueNode)
.map(JsonNode::asText)
.orElse(null);
}
AntoxaAntoxic marked this conversation as resolved.
Show resolved Hide resolved

private List<String> extractAcat(BidRequest request) {
final JsonNode bidderParams = getExtRequestPrebidBidderparams(request);
final JsonNode acatNode = bidderParams != null ? bidderParams.get(ACAT_EXT_REQUEST) : null;
Expand Down Expand Up @@ -191,7 +221,7 @@ private static Integer stripToNull(Integer value) {
return value == null || value == 0 ? null : value;
}

private Imp modifyImp(Imp imp, PubmaticBidderImpExt impExt) {
private Imp modifyImp(Imp imp, PubmaticBidderImpExt impExt, String displayManager, String displayManagerVersion) {
final Banner banner = imp.getBanner();
final ExtImpPubmatic impExtBidder = impExt.getBidder();

Expand All @@ -201,6 +231,12 @@ private Imp modifyImp(Imp imp, PubmaticBidderImpExt impExt) {
.banner(banner != null ? assignSizesIfMissing(banner) : null)
.audio(null)
.bidfloor(resolveBidFloor(impExtBidder.getKadfloor(), imp.getBidfloor()))
.displaymanager(StringUtils.isBlank(imp.getDisplaymanager())
? displayManager
: imp.getDisplaymanager())
.displaymanagerver(StringUtils.isBlank(imp.getDisplaymanagerver())
? displayManagerVersion
: imp.getDisplaymanagerver())
AntoxaAntoxic marked this conversation as resolved.
Show resolved Hide resolved
.ext(!newExt.isEmpty() ? newExt : null);

enrichWithAdSlotParameters(impBuilder, impExtBidder.getAdSlot(), banner);
Expand Down Expand Up @@ -437,9 +473,13 @@ private ExtRequest modifyExtRequest(ExtRequest extRequest, PubmaticWrapper wrapp
extNode.putPOJO(ACAT_EXT_REQUEST, acat);
}

final ExtRequest extRequestWithoutPrebid = extRequest != null
? mapper.fillExtension(ExtRequest.empty(), extRequest.getProperties())
: ExtRequest.empty();

return extNode.isEmpty()
? extRequest
: mapper.fillExtension(extRequest == null ? ExtRequest.empty() : extRequest, extNode);
? extRequestWithoutPrebid
: mapper.fillExtension(extRequestWithoutPrebid, extNode);
AntoxaAntoxic marked this conversation as resolved.
Show resolved Hide resolved
}

private HttpRequest<BidRequest> makeHttpRequest(BidRequest request) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@
import org.prebid.server.bidder.pubmatic.model.response.PubmaticExtBidResponse;
import org.prebid.server.bidder.pubmatic.model.response.VideoCreativeInfo;
import org.prebid.server.proto.openrtb.ext.ExtPrebid;
import org.prebid.server.proto.openrtb.ext.request.ExtApp;
import org.prebid.server.proto.openrtb.ext.request.ExtAppPrebid;
import org.prebid.server.proto.openrtb.ext.request.ExtRequest;
import org.prebid.server.proto.openrtb.ext.request.ExtRequestPrebid;
import org.prebid.server.proto.openrtb.ext.request.pubmatic.ExtImpPubmatic;
Expand Down Expand Up @@ -198,9 +200,7 @@ public void makeHttpRequestsShouldReturnBidRequestExtIfAcatFieldIsValidAndTrimWh
final Result<List<HttpRequest<BidRequest>>> result = target.makeHttpRequests(bidRequest);

// then
final ExtRequest expectedExtRequest = ExtRequest.of(ExtRequestPrebid.builder()
.bidderparams(pubmaticNode)
.build());
final ExtRequest expectedExtRequest = ExtRequest.empty();
expectedExtRequest.addProperty("acat",
mapper.createArrayNode().add("te st Value").add("test Value").add("Value"));

Expand Down Expand Up @@ -884,6 +884,54 @@ public void makeHttpRequestsShouldSetAppPublisherIdIfSiteIsNull() {
.containsExactly("pub id");
}

@Test
public void makeHttpRequestsShouldSetDisplayManagerFieldsFromAppExtPrebid() {
// given
final ExtApp extApp = ExtApp.of(ExtAppPrebid.of("ext-prebid-source", "ext-prebid-version"), null);
extApp.addProperty("source", TextNode.valueOf("ext-source"));
extApp.addProperty("version", TextNode.valueOf("ext-version"));

final BidRequest bidRequest = givenBidRequest(
bidRequestBuilder -> bidRequestBuilder.app(App.builder().ext(extApp).build()),
identity(),
identity());

// when
final Result<List<HttpRequest<BidRequest>>> result = target.makeHttpRequests(bidRequest);

// then
assertThat(result.getErrors()).isEmpty();
assertThat(result.getValue())
.extracting(HttpRequest::getPayload)
.flatExtracting(BidRequest::getImp)
.extracting(Imp::getDisplaymanager, Imp::getDisplaymanagerver)
.containsExactly(tuple("ext-prebid-source", "ext-prebid-version"));
}

@Test
public void makeHttpRequestsShouldSetDisplayManagerFieldsFromAppExt() {
// given
final ExtApp extApp = ExtApp.of(ExtAppPrebid.of("ext-prebid-source", null), null);
extApp.addProperty("source", TextNode.valueOf("ext-source"));
extApp.addProperty("version", TextNode.valueOf("ext-version"));

final BidRequest bidRequest = givenBidRequest(
bidRequestBuilder -> bidRequestBuilder.app(App.builder().ext(extApp).build()),
identity(),
identity());

// when
final Result<List<HttpRequest<BidRequest>>> result = target.makeHttpRequests(bidRequest);

// then
assertThat(result.getErrors()).isEmpty();
assertThat(result.getValue())
.extracting(HttpRequest::getPayload)
.flatExtracting(BidRequest::getImp)
.extracting(Imp::getDisplaymanager, Imp::getDisplaymanagerver)
.containsExactly(tuple("ext-source", "ext-version"));
}

@Test
public void makeHttpRequestsShouldSUpdateAppPublisherIdExtPublisherIdIsPresent() {
// given
Expand Down Expand Up @@ -1279,7 +1327,11 @@ private static ExtRequest expectedBidRequestExt(ExtRequest originalExtRequest,
final ObjectNode wrapperNode = mapper.createObjectNode()
.set("wrapper", mapper.valueToTree(PubmaticWrapper.of(wrapperProfile, wrapperVersion)));

return jacksonMapper.fillExtension(originalExtRequest, wrapperNode);
final ExtRequest extRequestWithoutPrebid = jacksonMapper.fillExtension(
ExtRequest.empty(),
originalExtRequest.getProperties());

return jacksonMapper.fillExtension(extRequestWithoutPrebid, wrapperNode);
}

private static BidRequest givenBidRequest(UnaryOperator<BidRequest.BidRequestBuilder> bidRequestCustomizer,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,22 +48,6 @@
"gdpr": 0
},
"ext": {
"prebid": {
"server": {
"externalurl": "http://localhost:8080",
"gvlid": 1,
"datacenter": "local",
"endpoint": "/openrtb2/auction"
},
"bidderparams": {
"pubmatic": {
"acat": [
"testValue1",
"testValue2"
]
}
}
},
"acat": [
"testValue1",
"testValue2"
Expand Down
Loading