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

Validation doesn't allow stored impressions without bidders #2975

Open
muuki88 opened this issue Feb 13, 2024 · 9 comments
Open

Validation doesn't allow stored impressions without bidders #2975

muuki88 opened this issue Feb 13, 2024 · 9 comments

Comments

@muuki88
Copy link
Contributor

muuki88 commented Feb 13, 2024

We faced an issue with stored impressions that are not configured, but requested and thus crash the entire auction.

if (extPrebidBidder == null) {
if (storedAuctionResponse != null) {
return;
} else {
throw new ValidationException("request.imp[%d].ext.prebid.bidder must be defined", impIndex);
}
}

This validation doesn't allow us to create a stored impression that looks like this

{
  "id" : "123/content_1",
  "banner" : {
    "format" : [  ]
  },
  "ext" : {  }
}

instead we have to do something like this

{
  "id" : "123/content_1",
  "banner" : {
    "format" : [ ]
  },
  "ext" : {
    "h5": {} // this bidder does not exist, but tricks the validation
  }
}

Proposal

It would be great to disable certain validations. E.g.

validations:
  allow:
    - empty-stored-impressions
@bretg
Copy link
Collaborator

bretg commented Feb 16, 2024

@muuki88 - maybe we can just drop the whole validation? No clear to me that a validation like this is real valuable because it's already in the DB and this error isn't that much more helpful than just noticing that there aren't any bidders in the auction.

@muuki88
Copy link
Contributor Author

muuki88 commented Feb 16, 2024

That would be even better IMHO. Because this escalates an error ( or purposely configured ad unit ) to the entire auction.

@bretg
Copy link
Collaborator

bretg commented Feb 16, 2024

Care to submit a PR @muuki88 ?

@muuki88
Copy link
Contributor Author

muuki88 commented Feb 16, 2024

Deleting code? Always 😍😎

@bretg bretg moved this from Triage to Ready for Dev in Prebid Server Prioritization Feb 23, 2024
@bretg bretg moved this from Ready for Dev to Community Review in Prebid Server Prioritization Sep 23, 2024
@bretg
Copy link
Collaborator

bretg commented Sep 23, 2024

Would like to discuss with the committee whether we should continue to hard-fail on missing imp[%d].ext.prebid.bidder.

We already have the scenario where bidders get removed due to lack of Purpose 2 consent - it's possible to take the view that the request/storedrequest should be allowed to not contain bidders.

@bretg
Copy link
Collaborator

bretg commented Dec 20, 2024

@muuki88 - is the goal here ultimately to allow the scenario where imps are simply dropped from the auction because there aren't bidders? The team doesn't want to drop the validation just for the case of stored requests because it's the same validation code as incoming requests. One use case I could see is that the adunit is temporarily roadblocked by a sponsorship so doing header bidding auctions on it is useless. Is that your scenario?

@bretg bretg moved this from Community Review to Clarify Request in Prebid Server Prioritization Dec 20, 2024
@muuki88
Copy link
Contributor Author

muuki88 commented Jan 4, 2025

Hi @bretg

is the goal here ultimately to allow the scenario where imps are simply dropped from the auction because there aren't bidders

Exactly.

The team doesn't want to drop the validation just for the case of stored requests because it's the same validation code as incoming requests

Maybe this is a broader topic. I get it that 400 bad requests are technically correct and are very easy to monitor, as the http status code propagates through all systems. From a resilience perspective this is however another beast. A lot of errors could/should be metrics.

One use case I could see is that the adunit is temporarily roadblocked by a sponsorship so doing header bidding auctions on it is useless. Is that your scenario?

Yes, one of them. Also basic bidder filtering ( if there's no previous auction participation ) . The requests will however always go to PBS as it provides analytics & monitoring as well, and the client doesn't now about all things happening server side.

@bretg
Copy link
Collaborator

bretg commented Jan 13, 2025

@muuki88 - seems to me that #3592 is related to this issue. Would the configuration proposal over there address this issue as well?

@muuki88
Copy link
Contributor Author

muuki88 commented Jan 13, 2025

Hi @bretg

I guess so. In the end it's auction failure vs failure metrics.

We are probably moving away from stored impressions for web at some point, so this might be less of an issue for us. So I would be fine with lowering the priority for this one. Or basically treat it as some extension to #3592 as you mentioned.

There are a couple of settings already

settings:
  enforce-valid-account: true

And in the account config

{
  "auction": {
    "bid-validations": {
      "banner-creative-max-size": "warn"
    },
}

Adding more settings would surely be helpful.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Clarify Request
Development

No branches or pull requests

3 participants