MenuUiMenuTreeManipulators.php

Same filename and directory in other branches
  1. 10 core/modules/menu_ui/src/Menu/MenuUiMenuTreeManipulators.php

Namespace

Drupal\menu_ui\Menu

File

core/modules/menu_ui/src/Menu/MenuUiMenuTreeManipulators.php

View source
<?php

namespace Drupal\menu_ui\Menu;

use Drupal\Core\Access\AccessResult;

/**
 * Provides menu tree manipulators to be used when managing menu links.
 */
class MenuUiMenuTreeManipulators {
    
    /**
     * Grants access to a menu tree when used in the menu management form.
     *
     * This manipulator allows access to menu links with inaccessible routes.
     *
     * Example use cases:
     * - A login menu link, using the `user.login` route, is not accessible to a
     *   logged-in user, but the site builder still needs to configure the menu
     *   link.
     * - A site builder wants to create a menu item for a Views page that has not
     *   been created. In this case, there is no access to the route because it
     *   does not exist.
     *
     * @param \Drupal\Core\Menu\MenuLinkTreeElement[] $tree
     *   The menu link tree to manipulate.
     *
     * @return \Drupal\Core\Menu\MenuLinkTreeElement[]
     *   The manipulated menu link tree.
     *
     * @internal
     * This menu tree manipulator is intended for use only in the context of
     * MenuForm because the user permissions to administer links is already
     * checked. Don't use this manipulator in other places.
     *
     * @see \Drupal\Core\Menu\DefaultMenuLinkTreeManipulators::checkAccess()
     * @see \Drupal\menu_ui\MenuForm
     */
    public function checkAccess(array $tree) : array {
        foreach ($tree as $element) {
            $element->access = AccessResult::allowed();
            if ($element->subtree) {
                $element->subtree = $this->checkAccess($element->subtree);
            }
        }
        return $tree;
    }

}

Classes

Title Deprecated Summary
MenuUiMenuTreeManipulators Provides menu tree manipulators to be used when managing menu links.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.