-
Notifications
You must be signed in to change notification settings - Fork 95
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
Vendors without any purposes #456
Comments
The IAB vendor 279 does not have any consent legal basis purposes, so it is not possible to enable or disable this vendor with consent legal basis. It has legitimate interest purposes and in this case the Vendor Legitimate Interest status will work for this vendor, and the vendor will appears in this vector in |
Thank you for your answer, so another question. How does encoder and this cmp (https://www.uniconsent.com/) managed to save it as both Legitimate Interest and normal consent? |
|
Sorry, mistake in pasting:
|
I think they use |
We reviewed this in the TCF compliance team. It is possible for vendors do not declare any purposes but only special purposes. The behavior of the library is correct. The CMP that you list, if it allows to set purposes for vendors that are not exposing purposes, is not compliant with the TCF policy. This would need to be fixed by the CMP. |
How would you propose the UI should be shown for these vendors? A checkbox / toggle does not make sense as storing the enabled status for that vendor in the TCString is not supported and hence will show this vendor as always “not consented” even if “Consent all” has been chosen. Would not showing a checkbox / toggle make it more transparent for a visitor that this vendor does not request consent? Additionally, I think the library should not allow to set vendor consent for a vendor without purposes, nor should const tcModel = new TCModel(gvl);
tcModel.setAllVendorsAllowed();
tcModel.setAllPurposeConsents();
tcModel.setAllPurposeLegitimateInterests();
tcModel.setAllVendorConsents();
tcModel.setAllVendorLegitimateInterests();
tcModel.setAllSpecialFeatureOptins();
tcModel.cmpId = CMP_ID;
tcModel.cmpVersion = 1;
// Should be false, but currently is true
tcModel.vendorConsents.has(279); Your insights and opinions are highly appreciated. |
Regarding the UI, I remember the some of the CMPs that I am familiar with don't show vendors w/o any purpose consent declared in their UI. Typically they differentiate in the UI between vendors using consent and vendor using LI. In the case of your example that vendor would not show under vendor using consent but will be listed under vendor using LI. The use can toggle the opt out for LI. That vendor's consent signal will always be 0. |
Version
1.5.13
Module (core, cmpapi, cli, stub, or testing)
Core
Describe with reproduction steps – What is the expected behavior?
Hello, wanted to ask about expected behaviour and potentially report a bug.
We have for example this vendor (ID: 279), that doesn't have any purposes, but do have special purposes and legitimate interest. LegInt works normally, but when trying to save normal consent for this vendor, it's not being included in TcString. I use function
tcModel.vendorConsents.set()
, pass this array as value:[279]
, and get this tcstring: CQCQqgAQCQqgAF-feBENAXEgAAAAAAAAAB5YAAAAAAAA.YAAAAAAAAAAA, by using this functionTCString.encode(tcModel);
I saw some people reporting that it's expected behaviour and vendors without purposes should be ignored, but here https://www.uniconsent.com/ and here https://iabtcf.com/#/encode they are being saved into TCstring. So i'm super confused.
So my question is:
How should we treat and handle vendors without purposes, but only with special purposes? Should we have toggle for users to opt-in/out? But if so, how could we implement it into TCstring if it's being ignored during encoding?
The text was updated successfully, but these errors were encountered: