Skip to content
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 @@ -88,7 +88,7 @@ public Result<List<HttpRequest<BidRequest>>> makeHttpRequests(BidRequest request
}
}

final BidRequest modifiedRequest = modifyRequest(request, publisherId, errors);
final BidRequest modifiedRequest = modifyRequest(request, publisherId);
final List<HttpRequest<BidRequest>> requests = groupedImps.values().stream()
.map(imps -> modifiedRequest.toBuilder().imp(imps).build())
.map(finalRequest -> BidderUtil.defaultRequest(
Expand Down Expand Up @@ -153,11 +153,11 @@ private Price convertBidFloor(Price bidFloorPrice, BidRequest bidRequest) {
return Price.of(DEFAULT_BIDDER_CURRENCY, BidderUtil.roundFloor(convertedPrice));
}

private BidRequest modifyRequest(BidRequest request, String publisherId, List<BidderError> errors) {
private BidRequest modifyRequest(BidRequest request, String publisherId) {
return request.toBuilder()
.site(modifySite(request.getSite(), publisherId))
.app(modifyApp(request.getApp(), publisherId))
.ext(modifyExtRequest(request.getExt(), errors))
.ext(modifyExtRequest(request.getExt()))
.build();
}

Expand Down Expand Up @@ -185,18 +185,9 @@ private static Publisher modifyPublisher(Publisher publisher, String id) {
.build();
}

private ExtRequest modifyExtRequest(ExtRequest extRequest, List<BidderError> errors) {
private ExtRequest modifyExtRequest(ExtRequest extRequest) {
final ExtRequest modifiedExtRequest = extRequest == null ? ExtRequest.empty() : extRequest;
final InsticatorExtRequest existingInsticator;

try {
existingInsticator = mapper.mapper().convertValue(
modifiedExtRequest.getProperty(INSTICATOR_FIELD),
InsticatorExtRequest.class);
} catch (IllegalArgumentException e) {
errors.add(BidderError.badInput(e.getMessage()));
return modifiedExtRequest;
}
final InsticatorExtRequest existingInsticator = getInsticatorExtRequest(modifiedExtRequest);

modifiedExtRequest.addProperty(
INSTICATOR_FIELD,
Expand All @@ -205,14 +196,24 @@ private ExtRequest modifyExtRequest(ExtRequest extRequest, List<BidderError> err
return modifiedExtRequest;
}

private InsticatorExtRequest getInsticatorExtRequest(ExtRequest modifiedExtRequest) {
try {
return mapper.mapper().convertValue(
modifiedExtRequest.getProperty(INSTICATOR_FIELD),
InsticatorExtRequest.class);
} catch (IllegalArgumentException e) {
return null;
}
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please, rollback this part of change. We need to inform about this error.


private static InsticatorExtRequest buildInsticator(InsticatorExtRequest existingInsticator) {
if (existingInsticator == null || CollectionUtils.isEmpty(existingInsticator.getCaller())) {
return InsticatorExtRequest.of(Collections.singletonList(DEFAULT_INSTICATOR_CALLER));
}

final List<InsticatorExtRequestCaller> callers = new ArrayList<>(existingInsticator.getCaller());
callers.add(DEFAULT_INSTICATOR_CALLER);
return InsticatorExtRequest.of(callers);
return InsticatorExtRequest.of(Collections.unmodifiableList(callers));
}

private static MultiMap makeHeaders(Device device) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -366,6 +366,35 @@ public void makeHttpRequestsShouldAddsToExtRequestInsticatorDefaultCaller() {
.containsExactly(expectedExtRequest);
}

@Test
public void makeHttpRequestsShouldAddsToExtRequestInsticatorDefaultCallerWhenExistingInsticatorCanNotBeParsed() {
// given
final ExtRequest givenExtRequest = ExtRequest.empty();
givenExtRequest.addProperty("insticator", mapper.createArrayNode());
final BidRequest bidRequest = givenBidRequest(imp -> imp.id("givenImp"))
.toBuilder()
.ext(givenExtRequest)
.build();

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

//then
assertThat(result.getErrors()).isEmpty();

final ExtRequest expectedExtRequest = ExtRequest.empty();
expectedExtRequest.addProperty("insticator",
mapper.createObjectNode().set("caller",
mapper.createArrayNode().add(mapper.createObjectNode()
.put("name", "Prebid-Server")
.put("version", "n/a"))));

assertThat(result.getValue()).hasSize(1)
.extracting(HttpRequest::getPayload)
.flatExtracting(BidRequest::getExt)
.containsExactly(expectedExtRequest);
}

@Test
public void makeHttpRequestsShouldModifyAppWithPublisherIdOfTheFirstImp() {
// given
Expand Down
Loading