-
Notifications
You must be signed in to change notification settings - Fork 246
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
Leave all IGs for a given domain #475
Comments
When you say "for a given domain", do you mean interest group owner domain and/or the site on which 'joinAdInterestGroup()' was called? |
That would be the origin of the interest group (the domain from where the joinAdInterestGroup is called). |
This line confuses me - the origin of the top-level page where IGs are joined from and the IG owner origin are not necessarily the same. What behavior specifically are you proposing here? Only leaving all IGs from the owner origin joined from the current top-level origin (which would be an entirely novel behavior, not at all like what leaveAdInterestGroup() does), or leaving all IGs from the owner, regardless of what top-level origin they were joined from? I think that if leaveAllAdInterestGroups() were restricted to IGs learned on the current top-level-origin, while leaveAdInterestGroup() was not, there'd be a lot of developer confusion about the very different behaviors of the two methods. |
The functionality I would like to get implemented can be described with a user interaction:
The new functionality would be used as follows in our script:
At the end of this interaction I would expect the user to have 2 joining_origin each with 2 igs: {well-known-advertiser.com:[IG3, IG4], well-known-competitor.com: [IGa, IGb]}. This is similar to the behavior that I understand is implemented when an interest group with |
That's how the execution_mode=groupByOrigin case currently works, actually. If join 5 IGs on site A with execution_mode=groupByOrigin, 3 with some other execution_mode, and then on site B join 1 IG with execution_mode=groupByOrigin, and then leave one of the first 5 IGs from site C, all 5 IGs with that execution mode joined from site A will be left, and the 4 other IGs will remain. If it were left on site A instead, we'd just leave the single IG. So this behavior sounds like it would be entirely different from how leaveAdIG() works with groupByOrigin mode. |
Since the behavior diverges from that of |
Another option would be to make take a parameter to either behave like leaveAdInterestGroup, or in a new manner (Then leaveAdInterestGroup could also be updated to take the same parameter, with a comparable effect). |
I've written a short PR (#829) with the proposed change. Went with clearOriginJoinedAdInterestGroups(). If there's demand for a global variant, we can just call it clearAdInterestGroups(). |
Thanks for the PR, it looks good to me. As for the global version, I did not think about what we could use it for yet. |
* Add clearOriginJoinedAdInterestGroup to spec.bs This adds the explainer changes from explainer PR #829 / issue #475 to the spec. * Update spec.bs Some cleanups - more likely to follow. * Update spec.bs * Update spec.bs * Update spec.bs Fix error? * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs * Update spec.bs
Introduction
The current implementation of FLEDGE does not allow for easy management of IGs on devices. For example, there is no way to know if an IG is present or garbage collected. To make sure that the server side is mostly in sync with the client side we propose to have an API extension to delete all IGs on the device for the current domain with an exception list of IGs we would like to keep.
The scenario is that, at IG registration time on an advertiser website, we plan to delete all IGs on the device that are not part of the current profile. Subsequently, we plan to issue a join request for the IGs based on the new state of the profile. For publisher origin IGs we might not need to clear the IGs.
Motivation
The functionality would help in two ways:
Design / Proposal
We propose to extend the Fledge API to allow for the following at IG registration time on advertiser website
Where the function
leaveAllAdInterestGroups
removes all the interest groups from the current origin domain and owner not matching a name in thelistOfIGNamesToKeep
.Implementation
This function can be cloned and remove the execution_mode restriction with a
listOfNamesToKeep
of IG names and made publicly available to be called just before the joinIG calls. Specifically we can add a lookup into a keep_list in this for loop.Alternative
At a first glance also a call to this function followed by an iteration of calls to this function should be sufficient to support the functionality (while skipping IGs in
listOfIGNamesToKeep
).The text was updated successfully, but these errors were encountered: