-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Escalax Bid Adapter: initial release #12483
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you link the PR on prebid docs in this PR description ?
modules/escalaxBidAdapter.js
Outdated
buildRequests: (validBidRequests, bidderRequest) => { | ||
if (validBidRequests && validBidRequests.length === 0) return []; | ||
const { sourceId, accountId } = validBidRequests[0].params; | ||
const subdomain = validBidRequests[0].params.subdomain; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
here, you use the subdomain of the first bid for the request.
So if bids uses different subdomain, it would be ignored.
I am guessing you want the publisher to use only one value for subdomain among all bids but this forces the publisher to copy paste the same parameter everywhere.
Another solution could be to set up a parameter in the setConfig/setBidderConfig option so the publisher would only have to set the param once and there would not an issue where only the params from the first bid is used.
You can find a simple example of that with Adot bidder which setup a global publisherId :
https://github.com/prebid/Prebid.js/blob/master/modules/adotBidAdapter.md
https://github.com/prebid/Prebid.js/blob/master/modules/adotBidAdapter.js
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JulieLorin I see, that's reasonable
But wouldn't it be more difficult for the publisher to specify an additional code like in adot example with this publisherId
And what i saw in couple of adapters is region
parameter, like here:
Prebid.js/modules/luceadBidAdapter.md
Lines 26 to 40 in 39e6418
const adUnits=[ | |
{ | |
code:'test-div', | |
sizes:[[300,250]], | |
bids:[ | |
{ | |
bidder: 'lucead', | |
params:{ | |
placementId: '1', | |
region: 'us', // optional: 'eu', 'us', 'ap' | |
} | |
} | |
] | |
} | |
]; |
or here:
Prebid.js/modules/precisoBidAdapter.md
Lines 15 to 19 in 39e6418
| Name | Scope | Description | Example | | |
| :------------ | :------- | :------------------------ | :------------------- | | |
| `region` | optional (for prebid.js) | 3 letter country code | "USA" | | |
| `publisherId` | required (for prebid-server) | partner ID provided by preciso | PreTest_0001 | | |
| `traffic` | optional (for prebid.js) | Configures the mediaType that should be used. Values can be banner, native | "banner" | |
We can agree to make a region
parameter instead of subdomain
and a different endpoint url for each such parameter - US, EU
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why don't you detect the user region and fill in your own subdomain instead of putting this on the publisher. Here is some basic logic:
function getContinentFromTimeZone(timeZone) {
// Validate the input timezone
if (typeof timeZone !== 'string') {
throw new Error('Invalid timezone: Timezone must be a string.');
}
// Map timezone region prefixes to continents
const continentMap = {
"Africa": "Africa",
"America": "North America / South America",
"Antarctica": "Antarctica",
"Asia": "Asia",
"Atlantic": "Atlantic Ocean region",
"Australia": "Australia",
"Europe": "Europe",
"Indian": "Indian Ocean region",
"Pacific": "Pacific Ocean region",
};
// Extract the main region from the timezone string
const mainRegion = timeZone.split('/')[0];
// Return the matching continent or a default message
return continentMap[mainRegion] || "Unknown continent";
}
// Example usage:
const userTimeZone = Intl.DateTimeFormat().resolvedOptions().timeZone;
console.log(`User's timezone: ${userTimeZone}`);
console.log(`Continent: ${getContinentFromTimeZone(userTimeZone)}`);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@patmmccann please take a look, i've made some changes regarding to this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks like a good solution to me, thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JulieLorin what do you think?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
that's good enough for me !
Thanks
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Type of change
Bugfix
Feature
New bidder adapter
Updated bidder adapter
Code style update (formatting, local variables)
Refactoring (no functional changes, no api changes)
Build related changes
CI related changes
Does this change affect user-facing APIs or examples documented on http://prebid.org?
Other
Description of change
Other information
prebid.github.io