Refactor callback mechanism

Created on 31 October 2024, 5 months ago

Problem/Motivation

Since v0.7.10 klaro has own callback functions onAccept, onDecline and onInit. We need this callbacks for Google Consent Mode v2.

Proposed resolution

Add these options to Klaro Apps.

Remaining tasks

  • Create options and change Klaro App Form
  • Mark the existing hook as deprecated (the current callback was called on every change, so we cannot move the existing callback to the new onAccept, onDecline

User interface changes

Settingsform for Klaro Apps.

Data model changes

Config for Klaro Apps.

✨ Feature request
Status

Active

Version

3.0

Component

Code

Created by

🇩🇪Germany jan kellermann

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @jan kellermann
  • First commit to issue fork.
  • Pipeline finished with Success
    about 2 months ago
    Total: 177s
    #427506
  • 🇧🇪Belgium kensae

    I've added onInit, onAccept and onDecline options to the Klaro App entity and I've updated the form in MR!79

  • 🇲🇾Malaysia ckng

    Tested MR!79 working. Generated the patch file.

  • 🇲🇾Malaysia ckng

    Updated status, as JS logics are missing.

  • 🇲🇾Malaysia ckng

    Updated patch. Passed onInit, onAccept, onDecline to services' config settings.

  • 🇲🇾Malaysia ckng
  • Pipeline finished with Failed
    26 days ago
    Total: 256s
    #444818
  • 🇲🇾Malaysia ckng

    Rebased and rerolled the patch.

  • Pipeline finished with Success
    26 days ago
    Total: 171s
    #444829
  • 🇩🇪Germany jan kellermann

    Big thanks to kensae and ckng. I have to check in the next days and will add some tests for the new options.

  • 🇷🇺Russia niklan Russia, Perm

    I think the update for existing Klaro app entities should also be provided, since the entities now have new properties and the existing configurations are invalid for the new schema. I'm curious about whether this update should be more cautious, considering how long it has been since this issue was created. In its current state, it will overwrite all existing callback data after the update, which could be a bit intrusive. Perhaps only set a default value if no value exists at the time of the update? This way, projects that relied on this merge request until the official release will retain their configuration.

  • 🇩🇪Germany jan kellermann

    I think we cannot write an update hook for old javascript snippets. We have to use both variants in parallel and deprecate the old way in next major release.

  • 🇷🇺Russia niklan Russia, Perm

    Yes, we can't update the existing JS snippet. But, there are other problems related to the new properties:

    1. Shouldn't we provide a proper update for klaro_app entities in order to set default values for newly created properties? I have tested this locally and it looks like Drupal automatically detects this and, on the next configuration export, adds missing properties.
    2. Shouldn't we update the default klaro_app entities (./config/install) to match the schema? Drupal seems to do this at some point, by merging missing properties. But currently, they are becoming out of sync with actual entities, and this might be a problem in certain scenarios.
    3. The description of on_decline should be checked and updated to make it more specific when the callback is called. At the moment, I'm unsure which is correct, but it seems that the behavior is correct, so the description needs to be updated.
  • 🇩🇪Germany jan kellermann

    Thank you, niklan! You are of course absolutely right that we need an update hook for the addition of config entities and that the schema also needs to be updated. (I had understood that we would split the existing scripts into the new areas - which I think is too risky.)

Production build 0.71.5 2024