Deprecate the 'roles' property of text formats and remove it from the UI

Created on 25 August 2020, about 4 years ago
Updated 28 March 2024, 8 months ago

Problem/Motivation

The roles property of text formats was thought to be a convenience originally, but it has become more of a nuisance by now.

First of all, there is 🐛 [PP-1] FilterFormat should add the roles as config dependencies Postponed . In particular, in #39 there it is made clear that having those roles there introduces a circular dependency between text formats and roles.

Furthermore, the roles are not included when exporting text formats, which leads to unintentional diffs in version control. This has long been a problem for custom sites owners, but has also struck core development: #3086965: Allow embedding media in CKEditor in Umami removed the roles property from the Basic HTML and Full HTML formats in Umami, as those were re-exported for the patch there. The Restricted HTML format in Umami and all three formats in Standard still have the roles in there, however. This inconsistency is unfortunate and should be resolved one way or the other. But instead of manually re-introducing the roles where they were removed, let's go ahead and remove them everywhere.

And if we are not using it in core and both for profiles/distributions as well as for custom sites the trend has strongly gone in favor of automatically exporting configuration over handcrafting it, we might as well deprecate it so we can resolve 🐛 [PP-1] FilterFormat should add the roles as config dependencies Postponed in Drupal 10.

Proposed resolution

Remove the roles property from all filters in core. The respective roles in Umami and Standard already have the proper permissions, so this will not be a functional change.

Subsequently add a deprecation notice in FilterFormat::get() and FilterFormat::set() for the roles property.

Remaining tasks

User interface changes

None.

API changes

None.

Data model changes

The roles property of text formats will be deprecated.

📌 Task
Status

Needs work

Version

11.0 🔥

Component
Filter 

Last updated about 4 hours ago

No maintainer
Created by

🇩🇪Germany tstoeckler Essen, Germany

Live updates comments and jobs are added and updated live.
  • Needs release note

    The major change should have a special release note written to summarize the importance of the change. See Write a release note for an issue.

  • Needs change record

    A change record needs to be drafted before an issue is committed. Note: Change records used to be called change notifications.

  • Needs issue summary update

    Issue summaries save everyone time if they are kept up-to-date. See Update issue summary task instructions.

Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇫🇷France andypost

    NW for deprecation message

  • Status changed to Needs review over 1 year ago
  • last update over 1 year ago
    29,503 pass, 12 fail
  • 🇮🇳India karishmaamin

    Re-rolled patch at #33 against 11.x-dev

  • First commit to issue fork.
  • Pipeline finished with Failed
    10 months ago
    Total: 515s
    #72489
  • 🇫🇷France andypost

    needs to change deprecation message and not clear about upgrade path

  • Pipeline finished with Canceled
    10 months ago
    Total: 169s
    #72707
  • Pipeline finished with Failed
    10 months ago
    Total: 607s
    #72709
  • Pipeline finished with Failed
    10 months ago
    #72723
  • Pipeline finished with Failed
    10 months ago
    Total: 737s
    #72776
  • Pipeline finished with Failed
    10 months ago
    #72793
  • Pipeline finished with Success
    10 months ago
    Total: 530s
    #72802
  • 🇬🇷Greece dimitriskr

    Tests finally pass

    NR for what's currently in the MR and NW for the upgrade path

  • 🇬🇷Greece dimitriskr

    Updated remaining tasks in IS. CR needs update for updating drupal versions in body

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Nice work here, @dimitriskr! But rather than expecting deprecations in tests, we should be updating the tests to not create text formats with the roles property anymore.

    The default config of install profiles has been updated already, we just need to do the same for config in tests 😊

    This blocks 🐛 [PP-1] FilterFormat should add the roles as config dependencies Postponed .

  • 🇬🇷Greece dimitriskr

    Thanks for the review Wim! One question. In some previous issues regarding deprecation, it had to have one test that would test that the deprecation message would pop up.

    I'll remove the deprecated config from the test configuration but shouldn't exist one test to test the deprecation message? (by creating a separate test module with the deprecated config for this exact purpose)

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    it had to have one test that would test that the deprecation message would pop up.

    That's right.

    I'll remove the deprecated config from the test configuration but shouldn't exist one test to test the deprecation message? (by creating a separate test module with the deprecated config for this exact purpose)

    Yes, this is the way 😊👍

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
  • 🇬🇷Greece dimitriskr

    Alright, I'll continue on this.

    And what about the upgrade path? Don't we need to change the configuration of the existing installations?
    I was thinking about a hook_post_update (since it's configuration) and load all filters and remove the roles property. Would this be enough?

    If there is an example on testing the upgrade path, I could add this too.

  • Pipeline finished with Failed
    9 months ago
    Total: 170s
    #97571
  • 🇬🇷Greece dimitriskr

    I've removed the expectDeprecation calls in the tests, as also remove the roles property in the formats

    I've kept it in \Drupal\Tests\ckeditor5\Kernel\SmartDefaultSettingsTest since it loads config from a folder called ckeditor4_config and don't want to mess up anything there. If it's ok to remove it, let me know.

    The deprecation message testing already exists in \Drupal\Tests\filter\Kernel\FilterLegacyTest

  • Pipeline finished with Failed
    9 months ago
    Total: 992s
    #97577
  • 🇨🇭Switzerland berdir Switzerland

    > And what about the upgrade path? Don't we need to change the configuration of the existing installations?

    No, because as stored configuration, the property isn't there anyway, This only affects default config files, and you can't files in an update function.

    > I've kept it in \Drupal\Tests\ckeditor5\Kernel\SmartDefaultSettingsTest since it loads config from a folder called ckeditor4_config and don't want to mess up anything there. If it's ok to remove it, let me know.

    I think it's fine to change that. the roles/permission are not actually tested by that test I think, they look like they were copy pasted from standard profile (an old, ckeditor4 version of them). You most likely don't even need to add any permissions, unlike some of the other tests I commented on.

  • Pipeline finished with Failed
    9 months ago
    Total: 203s
    #97619
  • Pipeline finished with Failed
    9 months ago
    Total: 512s
    #97625
  • 🇬🇷Greece dimitriskr

    The failures in the Functional Tests mean that the test user has no access in ckeditor5.upload_image so it cannot upload the image.

    We have to set to the user the permission to use the text format, with maybe the following? Otherwise the tests will fail. (tested locally)

        $format_permission = FilterFormat::load('basic_html')->getPermissionName();
        user_role_grant_permissions(RoleInterface::AUTHENTICATED_ID, [$format_permission]);
    

    Or, if we move the calls of $this->createBasicFormat(); to setUp() (since it's called in every test method + in inherited ImageUploadAccessTest), we can add the permission as parameter in drupalCreateUser()

    As for the FunctionalJavascript fails, I have no idea what is going on.

  • Pipeline finished with Failed
    9 months ago
    #97641
  • Assigned to wim leers
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    @Berdir++ in #53 😊

    #54: I'll debug this. Thanks for pushing it so far already! 🙏

  • Pipeline finished with Failed
    9 months ago
    Total: 500s
    #98571
  • Issue was unassigned.
  • Status changed to Needs review 9 months ago
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    As far as I'm concerned, this is now RTBC-worthy. Updated the change record .

    Hoping @Berdir will RTBC 😇

  • Pipeline finished with Success
    9 months ago
    Total: 484s
    #98611
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Actually, I have two more questions:

    1. The issue summary says we need an update path. But … do we? Whenever the "Roles" checkboxes for text formats are used in the UI, the granted permissions already are already updated on the Role entities. So AFAICT there's nothing to be done? → tagged for this
    2. Deprecating the role property is one thing, but what about the UI part? What about functional tests that are relying on the checkboxes? Keeping them around for Drupal 10.x makes sense (to avoid a BC break), but in Drupal 11, they should disappear? Seems like we need a follow-up issue for that? Or do we consider that a natural consequence of this disappearing as soon as Drupal 11 actually removes the roles property?
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Finally, closed #2569741 in favor of this, see explanation at #2569741-57: [PP-1] FilterFormat should add the roles as config dependencies .

  • 🇬🇷Greece dimitriskr

    Thanks Wim for taking care of this, it was getting difficult for me

    1. I put the upgrade path to the tasks, since I thought it was necessary. Since #53, it was made clear it's not necessary, so we can remove it

    2. Is it possible to point a URL to /admin/people/permissions, in the filter module permissions so they can be set directly from there? Or just tell people that in Drupal 11, in order to set permissions for the text formats, you must go to the URL above, in the release notes. And add a note in the current field that in 11 this will change

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    #59:

    1. 👍 Thanks for confirming! Updated issue summary.
    2. We should not modify the UI with warnings about what will change — that'd certainly cause a usability regression.

      On second thought … I don't think we need special consideration for this — literally EVERYTHING ELSE in Drupal requires going to the "permission" UI. This is the only inconsistency left AFAIK.

    That means this now is truly RTBC-worthy! 😊

  • 🇬🇷Greece dimitriskr

    dimitriskr changed the visibility of the branch 11.x to hidden.

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Subsequently add a deprecation notice in FilterFormat::get() and FilterFormat::set() for the roles property.

    This part is missing. But … I'd argue it's not necessary, since FilterFormat::postSave() will still trigger a deprecation notice. It might be a slightly nicer/clearer way for contributed/custom module maintainers to be notified though?

  • 🇨🇭Switzerland berdir Switzerland

    I think the UI question is entirely disconnected from this issue. It's only related because it requires special workarounds to not trigger the deprecation because config entity forms by default just throw everything the form defines directly onto the entity. We could in theory revert this change in D11, it would just set an undefined property on the object but won't do anything with it (like many, many other form elements)

    I do agree that this is special, but who can access which text format is IMHO such a central question that I definitely see this being useful here. That said, we have a pattern now with a permissions local task on e.g. node types that we could also use for this, it would be a bit overkill as it's always going to be a single permission only though.

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    That's really helpful, @Berdir — and I'd forgotten about the "permissions local task" pattern! 👍

    You've convinced me that this issue is indeed 100% independent of any UI impact. Which means it's definitely in an RTBC'able state 🥳

  • First commit to issue fork.
  • Pipeline finished with Canceled
    9 months ago
    #99749
  • Pipeline finished with Canceled
    9 months ago
    #99750
  • Pipeline finished with Canceled
    9 months ago
    Total: 11s
    #99751
  • 🇺🇸United States smustgrave

    Applied the suggestions by @Wim Leers.

    Will this need an upgrade path though to remove roles key from existing config?

  • Pipeline finished with Success
    9 months ago
    Total: 494s
    #99753
  • 🇩🇪Germany tstoeckler Essen, Germany

    @Wim Leers summoned me to take another look at this. Really looks great, have no objections. I did review all the changes since my last patch and they are all fine, but since I did author a good chunk of what is still in the current patch, not going to RTBC as people do sometimes get very sensitive with that. Total endorsement of this landing, though, would really love to see this in for all kinds of reasons! Thanks everyone for pushing this along and AFAICT very close to the finish line.

  • Status changed to RTBC 9 months ago
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    #66: it's deprecated, not removed. See #53 for why that is not necessary.

    #67: We're more pragmatic than that at this point 😄 It's been a long time since you touched this, plus I reviewed YOUR changes, so if you can review mine and @dimitriskr's , then … there's no reason you cannot RTBC this! As @alexpott likes to say (paraphrasing)
    : "why would you not be allowed to RTBC it if you happen to have the expertise to thoroughly review this particular area?" 😊

    … and in that same vein: I've re-reviewed everything and only made trivial tests-only changes to the CKEditor 5 tests, to ensure that @group legacy only appears in the sole legacy test.

    Let's get this done! 😄

  • 🇩🇪Germany tstoeckler Essen, Germany

    Awesome, thanks!

    Yeah, I totally agree, just want to avoid getting into arguments with people...

    But then RTBC++, I guess ;-)

  • Status changed to Needs review 9 months ago
  • 🇬🇧United Kingdom catch

    One small and one slightly larger question on the MR - would be good to document this in the issue summary and we probably need an explicit follow-up to track removal.

    This is one where I think we should deprecate for removal in Drupal 11 since we're maintaining a non-trivial bc layer and at worst this will affect shipped config.

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    @catch See my comment on the MR — I'd be fine with removing this UI, I just figured we're trying to minimize change for site builders during the D10 cycle too. Happy to do so though — it'd mean a more consistent UX anyway, so I sort of see the appeal: consistent UX and less code complexity!

  • Status changed to Needs work 9 months ago
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    @catch in Drupal Slack:

    I think we should and can get rid of the UI in a minor. Will need a change record/release note.

    So: let's do that! (Separate change record for the UI change 🙏)

    @dimitriskr: Are you interested in making that part happen? :D

  • 🇬🇷Greece dimitriskr

    Sure, I can give it a go!

    Could you also update the remaining tasks in IS?

  • 🇬🇷Greece dimitriskr

    #62 📌 Deprecate the 'roles' property of text formats Needs review Do we still need this?

  • Pipeline finished with Failed
    9 months ago
    #101734
  • Pipeline finished with Failed
    9 months ago
    #101739
  • Pipeline finished with Failed
    9 months ago
    #101779
  • 🇬🇷Greece dimitriskr

    I've pushed some code changes.
    There needs to be a change at \Drupal\Tests\ckeditor5\FunctionalJavascript\CKEditor5TestBase::createNewTextFormat in order to grant the required permission to the current user to allow using each text format. I guess that will make CKEditor5 tests pass and the whole pipeline go green

  • Pipeline finished with Failed
    9 months ago
    Total: 901s
    #102170
  • Pipeline finished with Success
    9 months ago
    Total: 482s
    #102195
  • 🇬🇷Greece dimitriskr

    Tests now pass :)

  • Assigned to wim leers
  • Status changed to Needs review 9 months ago
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Thanks! Will review 🤓

  • 🇺🇸United States smustgrave

    @Wim Leers just following up if you had a chance to review this one? Think it would be a good thing for 11.x

  • Status changed to Needs work 8 months ago
  • 🇨🇭Switzerland berdir Switzerland

    Posted a review.

    FWIW, I still think that the UI change should be a separate issue even if it adds a bit of technical dept on the form.

    I always thought this is pretty convenient, because setting correct permissions is pretty much mandatory for a new filter format. Without this, it will not show up for users and there is no indication or feedback that you need to go to a completely different section of the UI to then grant users the permission to actually use this format.

    IMHO we need some sort of replacement for that (a message maybe, or the mentioned permissions local task, but unlike bundles, saving does not bring us to a page where we'd see that local task). I think this change needs a UX review (and that's exactly why it should IMHO be separate from the technical change).

Production build 0.71.5 2024