MenuLinkContentAccessControlHandler does not allow "view" access without admin permission, making these entities inaccessible via REST, JSON API and GraphQL

Created on 12 October 2017, about 8 years ago
Updated 5 February 2023, over 2 years ago

Menu link 'view' permission is set to 'Administer Menu' which does not allow for exposing menu links via the jsonapi module (e.g. /jsonapi/menu_link_content/menu_link_content). Should permission instead be granted to access those links based on ability to access the linked resources?

πŸ“Œ Task
Status

Needs work

Version

10.1 ✨

Component
Menu link contentΒ  β†’

Last updated 3 months ago

Created by

πŸ‡ΊπŸ‡ΈUnited States cachesclay

Live updates comments and jobs are added and updated live.
  • Contributed project blocker

    It denotes an issue that prevents porting of a contributed project to the stable version of Drupal due to missing APIs, regressions, and so on.

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.

  • Status changed to Needs review over 2 years ago
  • Status changed to Needs work over 2 years ago
  • πŸ‡¬πŸ‡§United Kingdom marekgti

    Modified #82 patch to allow unrouted links that starts with "/"

  • πŸ‡³πŸ‡±Netherlands Lendude Amsterdam

    Closed πŸ› Custom menu item entity reference is not accessible to anonymous user Closed: duplicate as a duplicate of this. Discussed with @catch in #bugsmash and the possible problems with entity references should probably be handled here too.

  • πŸ‡¨πŸ‡¦Canada Austin986

    Patch #85 not working on Drupal 10.0.9.
    It says patch can not be applied.
    Any idea?

  • πŸ‡¨πŸ‡¦Canada Austin986

    Patch #85's compatible version for Drupal 10.1.x.

  • πŸ‡¨πŸ‡¦Canada Austin986

    Patch #88 still not working if paragraph is a part of extra field of meu item.
    Because it tries to check permission to access entity.menu_link_content.canonical, and it seems there is no way to set custom permission for entity.menu_link_content.canonical, without any additional module installed.

    This patch simply ignores all access permission for "view" case, to make sure all menu items are visible.

    PLEASE DO NOT USE THIS PATCH, if you need menu item specific permission set up.

  • last update over 2 years ago
    29,378 pass
  • last update over 2 years ago
    Custom Commands Failed
  • πŸ‡§πŸ‡ͺBelgium tim-diels Belgium πŸ‡§πŸ‡ͺ

    @Lendude regarding "Discussed with @catch in #bugsmash and the possible problems with entity references should probably be handled here too." ... Could you give some more info on what needs to be done to get this issue moving again?

  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    @Lendude & @Voleger, we just came to this issue from here: #2925283: New fields visibility and access β†’

    TL;DR: Due to this, entity reference (revision) contents are not visible for guests within the Menu (example: Mega Menu implementation using Paragraphs). Workaround: Use paragraphs_type_permissions submodule, which seems to override this using hook_ENTITY_TYPE_permission()

    Still we'd like to help fixing this in core, so we can remove the workaround.

    You have both invested a lot of time here and I think you're aware of what has to be done to finish this. What ca we do?
    We can reroll the MR against 11.x and 10.3.x but then we should try to finish it and hot have it around for years again... any feedback?

    The MR still seems good, a clear improvement and has a lot of positive feedback.

  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    Here's the current state of the MR339 which still works fine against 10.2.x, 10.3.x and eventually 11.x (haven't tried). Great work @voleger!

  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica
  • Pipeline finished with Failed
    over 1 year ago
    Total: 1080s
    #151787
  • πŸ‡ΊπŸ‡¦Ukraine voleger Ukraine, Rivne

    rest and json_api integration tests are failing

  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    Test are failing because the new link to user/1 is missing in the menu tests. So that should be a very easy fix.

    See this link for all tests that are failing.

  • πŸ‡©πŸ‡ͺGermany Grevil

    Not as simple as it seems. The expected cache tags are invalid, since we are swapping the "https://nl.wikipedia.org/wiki/Llama" link with a cacheable internal link to user:1 out. We can implement a dirty workaround and manually prepend the new cache to "getExpectedCacheTags()", but then the test will just throw an error later on.

    To be honest, the current test changes generally seem really rushed. Simply replacing a remote link string with an internal link inside already existing tests / test bases without changing anything else just doesn't feel right. It also looks like we removed testing for external links entirely?

    I'd say we revert the current test changes and create dedicated tests for internal menu links (json and rest) additionally to the already existing external link tests. Only problem being, that the test structure seems quite complex, so this will probably need quite a bit of work...

    Really unsure about this. Does anybody else have an idea? Maybe there is a super simple way to test this, and we only need to add a quick test without changing any existing tests / test bases?

  • Pipeline finished with Failed
    over 1 year ago
    Total: 1016s
    #159564
  • Pipeline finished with Canceled
    over 1 year ago
    Total: 61s
    #159596
  • Pipeline finished with Canceled
    over 1 year ago
    Total: 149s
    #159601
  • Pipeline finished with Canceled
    over 1 year ago
    Total: 252s
    #159602
  • Pipeline finished with Canceled
    over 1 year ago
    Total: 966s
    #159610
  • Pipeline finished with Failed
    over 1 year ago
    Total: 1420s
    #159627
  • πŸ‡©πŸ‡ͺGermany Grevil

    I reverted the test changes and created a new test class inside the jsonapi space. Unsure, whether to create a REST test class as well. But I don't think we should adjust the rest test base, how we did it in "MenuLinkContentResourceTestBase.php" originally, which I reverted here: https://git.drupalcode.org/project/drupal/-/merge_requests/339/diffs?com....

    Unfortunately, now the old "MenuLinkContentTest" fails. Here, it expects a 403 status code, but it actually receives an unexpected 200 status code. This might show, that the current MR needs some refactoring? I am not sure. These tests are highly complex with many dependencies.

  • Pipeline finished with Failed
    over 1 year ago
    Total: 3348s
    #159694
  • Pipeline finished with Failed
    about 1 year ago
    Total: 441s
    #296828
  • Pipeline finished with Failed
    about 1 year ago
    Total: 397s
    #296833
  • Pipeline finished with Failed
    about 1 year ago
    Total: 502s
    #296856
  • Pipeline finished with Failed
    about 1 year ago
    Total: 504s
    #296905
  • Pipeline finished with Failed
    about 1 year ago
    Total: 420s
    #296913
  • Pipeline finished with Failed
    about 1 year ago
    #296923
  • Pipeline finished with Failed
    about 1 year ago
    #296948
  • Pipeline finished with Failed
    about 1 year ago
    Total: 467s
    #298007
  • Pipeline finished with Failed
    about 1 year ago
    Total: 434s
    #298109
  • Pipeline finished with Failed
    about 1 year ago
    Total: 467s
    #298114
  • Pipeline finished with Success
    about 1 year ago
    Total: 442s
    #298169
  • Pipeline finished with Failed
    about 1 year ago
    Total: 547s
    #299023
  • Pipeline finished with Failed
    about 1 year ago
    Total: 698s
    #304136
  • Pipeline finished with Failed
    about 1 year ago
    Total: 431s
    #304223
  • Pipeline finished with Failed
    about 1 year ago
    Total: 712s
    #306633
  • Pipeline finished with Failed
    about 1 year ago
    Total: 640s
    #307015
  • Pipeline finished with Failed
    about 1 year ago
    Total: 1021s
    #307171
  • Pipeline finished with Failed
    about 1 year ago
    Total: 485s
    #307186
  • Pipeline finished with Success
    about 1 year ago
    Total: 448s
    #307201
  • Pipeline finished with Failed
    about 1 year ago
    Total: 840s
    #307254
  • Pipeline finished with Failed
    about 1 year ago
    Total: 405s
    #307330
  • Pipeline finished with Failed
    about 1 year ago
    Total: 459s
    #307486
  • Pipeline finished with Failed
    about 1 year ago
    Total: 606s
    #307500
  • Pipeline finished with Failed
    about 1 year ago
    #310289
  • Pipeline finished with Failed
    about 1 year ago
    Total: 431s
    #312679
  • Pipeline finished with Success
    about 1 year ago
    Total: 441s
    #312722
  • Pipeline finished with Success
    about 1 year ago
    Total: 708s
    #313906
  • Pipeline finished with Success
    about 1 year ago
    Total: 478s
    #313953
  • Pipeline finished with Failed
    about 1 year ago
    Total: 655s
    #313959
  • Pipeline finished with Success
    about 1 year ago
    Total: 7435s
    #315909
  • Pipeline finished with Success
    about 1 year ago
    Total: 723s
    #316060
  • Pipeline finished with Success
    about 1 year ago
    Total: 523s
    #316096
  • Pipeline finished with Canceled
    12 months ago
    #320643
  • Pipeline finished with Success
    12 months ago
    Total: 210s
    #320662
  • Pipeline finished with Failed
    12 months ago
    Total: 435s
    #327016
  • Pipeline finished with Failed
    12 months ago
    Total: 487s
    #327033
  • Pipeline finished with Failed
    12 months ago
    Total: 337s
    #327042
  • Pipeline finished with Failed
    12 months ago
    Total: 474s
    #327052
  • Pipeline finished with Failed
    10 months ago
    Total: 137s
    #371093
  • Status changed to Needs review 10 months ago
  • πŸ‡©πŸ‡ͺGermany Anybody Porta Westfalica

    Attached Drupal 11.1 compatible patch. Would still be great, if someone could finish the great work done here already to get this fixed. Any hero present to move this over the finish line?

  • The Needs Review Queue Bot β†’ tested this issue. It fails the Drupal core commit checks. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide β†’ to find step-by-step guides for working with issues.

  • Pipeline finished with Failed
    10 months ago
    Total: 812s
    #383966
  • Pipeline finished with Canceled
    10 months ago
    Total: 69s
    #383973
  • Pipeline finished with Failed
    10 months ago
    Total: 1515s
    #383975
  • Pipeline finished with Failed
    10 months ago
    Total: 942s
    #383996
  • Pipeline finished with Failed
    10 months ago
    Total: 951s
    #384146
  • Pipeline finished with Failed
    10 months ago
    Total: 875s
    #387546
  • Pipeline finished with Failed
    10 months ago
    Total: 854s
    #387571
  • Pipeline finished with Canceled
    10 months ago
    Total: 388s
    #387585
  • Pipeline finished with Canceled
    10 months ago
    Total: 396s
    #387589
  • Pipeline finished with Failed
    10 months ago
    Total: 691s
    #387598
  • Pipeline finished with Failed
    10 months ago
    Total: 602s
    #387602
  • Pipeline finished with Failed
    10 months ago
    Total: 593s
    #387607
  • Pipeline finished with Failed
    10 months ago
    Total: 478s
    #387613
  • Pipeline finished with Success
    10 months ago
    Total: 1031s
    #387615
  • Pipeline finished with Failed
    8 months ago
    Total: 130s
    #436557
  • Pipeline finished with Failed
    8 months ago
    Total: 135s
    #436562
  • Pipeline finished with Failed
    8 months ago
    Total: 461s
    #436588
  • Status changed to Needs work 8 months ago
  • πŸ‡©πŸ‡ͺGermany Grevil

    Alright, that should be it. Test is still failing, so leaving this at "Needs work" for now.

    Current MR as patch attached.

  • πŸ‡©πŸ‡ͺGermany Grevil

    Maybe we could get a subsystem maintainer to have a look at the tests, since nobody dares to do the final refinement and this is open for a while now?

  • πŸ‡³πŸ‡±Netherlands bbrala Netherlands

    I'll try and dive into this sometime soon.

    One thing that I did notice, there were some conceirns in #77, are those valid or handled?

  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Issue summary should be complete, helps reviewer and sub-maintainers quickly understand.

  • Pipeline finished with Failed
    7 months ago
    Total: 52s
    #453042
  • Pipeline finished with Success
    7 months ago
    Total: 246s
    #453048
  • Pipeline finished with Skipped
    6 months ago
    #484778
  • Pipeline finished with Success
    5 months ago
    Total: 649s
    #503737
  • Pipeline finished with Skipped
    5 months ago
    #503747
  • πŸ‡­πŸ‡ΊHungary lbesenyei

    #102 works for our project.

  • Pipeline finished with Failed
    4 months ago
    #529400
  • Pipeline finished with Failed
    24 days ago
    Total: 3545s
    #613554
  • Pipeline finished with Failed
    18 days ago
    Total: 130s
    #619390
  • Pipeline finished with Failed
    18 days ago
    Total: 512s
    #619396
  • Pipeline finished with Failed
    17 days ago
    Total: 227s
    #620268
  • Pipeline finished with Failed
    17 days ago
    Total: 509s
    #620421
  • Pipeline finished with Failed
    17 days ago
    Total: 747s
    #620451
Production build 0.71.5 2024