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

Fix opt out all essential. #5850

Merged
merged 5 commits into from
Mar 6, 2025
Merged

Fix opt out all essential. #5850

merged 5 commits into from
Mar 6, 2025

Conversation

tvandort
Copy link
Contributor

@tvandort tvandort commented Mar 6, 2025

Closes:

Description Of Changes

  1. Fixes TCModelError when opting into some purposes
  2. Opt out of all no longer affects "notice only" notices.
  • Notice-only preferences are preserved when rejecting all other preferences
  • TCF and custom purpose consents are properly separated and handled independently
  • The consent UI correctly reflects and maintains different types of consent preferences
  • The system properly handles mixed scenarios where users opt in/out of both TCF and custom consents

Code Changes

TCF Overlay Component Changes:

  • Added handling for notice-only custom purposes in the handleRejectAll function
  • Modified the logic to preserve notice-only consent preferences when rejecting all other preferences
  • Added support for ConsentMechanism type to better handle different consent types

TCF Purposes Component Changes:

  • Improved the onToggle handler to properly filter between TCF purposes and custom purposes
  • Added type safety for the item parameter in the toggle handler
  • Fixed the logic to prevent mixing TCF and custom purpose consents incorrectly

Test Coverage Improvements:

  • Added new comprehensive test cases for mixed consent scenarios:
  • Testing opt-in to both custom consent and TCF consent
  • Testing opt-out of both custom consent and TCF consent
  • Updated existing tests to properly handle notice-only preferences
  • Added verification of consent cookie states and API request payloads

Documentation Updates:

  • Updated comments to clarify the handling of enabled IDs that could include both TCF and custom enabled IDs
  • Removed a deferred test case that was no longer needed

Steps to Confirm

  1. On TCF experience, add some custom notices

  2. In demo page, open up layer 2, opt in to some custom notices and some TCF purposes in the “Purposes” tab

  3. Open up console

  4. Click “save”

  5. Ensure that there are no errors in the console

  6. On TCF experience, add an essential notice

  7. In demo page, click reject all

  8. See that "Essential" notice is "false" in window.Fides, the cookie, and the modal, if you re-open it. It should remain “true” and toggled on.

Pre-Merge Checklist

  • Issue requirements met
  • All CI pipelines succeeded
  • CHANGELOG.md updated
    • Add a db-migration This indicates that a change includes a database migration label to the entry if your change includes a DB migration
    • Add a high-risk This issue suggests changes that have a high-probability of breaking existing code label to the entry if your change includes a high-risk change (i.e. potential for performance impact or unexpected regression) that should be flagged
  • Followup issues:
    • Followup issues created (include link)
    • No followup issues
  • Database migrations:
    • Ensure that your downrev is up to date with the latest revision on main
    • Ensure that your downgrade() migration is correct and works
      • If a downgrade migration is not possible for this change, please call this out in the PR description!
    • No migrations
  • Documentation:
    • Documentation complete, PR opened in fidesdocs
    • Documentation issue created in fidesdocs
    • If there are any new client scopes created as part of the pull request, remember to update public-facing documentation that references our scope registry
    • No documentation updates required

Copy link

vercel bot commented Mar 6, 2025

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
fides-privacy-center ✅ Ready (Inspect) Visit Preview 💬 Add feedback Mar 6, 2025 10:09pm
1 Skipped Deployment
Name Status Preview Comments Updated (UTC)
fides-plus-nightly ⬜️ Ignored (Inspect) Visit Preview Mar 6, 2025 10:09pm

@gilluminate
Copy link
Contributor

I've thoroughly tested these changes and can confirm that the fixes are working as intended. The system now correctly handles:

  • Notice-only preferences being preserved during reject all operations
  • Proper separation between TCF and custom purpose consents
  • Mixed consent scenarios where users opt in/out of both TCF and custom consents

Co-authored-by: Jason Gill <jason.gill@ethyca.com>
@gilluminate gilluminate merged commit 9b399f8 into main Mar 6, 2025
18 checks passed
@gilluminate gilluminate deleted the fix-opt-out-of-essential branch March 6, 2025 22:20
Copy link

cypress bot commented Mar 6, 2025

fides    Run #12634

Run Properties:  status check passed Passed #12634  •  git commit 9b399f836f: Fix opt out all essential. (#5850)
Project fides
Branch Review main
Run status status check passed Passed #12634
Run duration 00m 50s
Commit git commit 9b399f836f: Fix opt out all essential. (#5850)
Committer Tom Van Dort
View all properties for this run ↗︎

Test results
Tests that failed  Failures 0
Tests that were flaky  Flaky 0
Tests that did not run due to a developer annotating a test with .skip  Pending 0
Tests that did not run due to a failure in a mocha hook  Skipped 0
Tests that passed  Passing 5
View all changes introduced in this branch ↗︎

NevilleS pushed a commit that referenced this pull request Mar 7, 2025
Co-authored-by: eastandwestwind <eastandwestwind@gmail.com>
Co-authored-by: Jason Gill <jason.gill@ethyca.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants