diff --git a/src/Access/UwNodeAccessCheck.php b/src/Access/UwNodeAccessCheck.php index af8a0b17da5e28f95454ab58baf4bec94ead3d9c..da03a673e63d9e167b7a03db44f0958b917169d7 100644 --- a/src/Access/UwNodeAccessCheck.php +++ b/src/Access/UwNodeAccessCheck.php @@ -55,6 +55,11 @@ class UwNodeAccessCheck implements AccessInterface { } } + // Role Expire config: admin/config/system/role-expire. + if ($route_name === 'role_expire.config') { + return $account->hasPermission('administer role expire configuration') ? AccessResult::allowed() : AccessResult::forbidden(); + } + // Get the node object, which is in the route match variable. $node = $route_match->getParameter('node'); diff --git a/src/Routing/UwNodeAccessRouteSubscriber.php b/src/Routing/UwNodeAccessRouteSubscriber.php index 1327c205f8fff1850c48670a9bf7520c2e3c870c..1ad413f7b2e906164968b5e149643855993f904f 100644 --- a/src/Routing/UwNodeAccessRouteSubscriber.php +++ b/src/Routing/UwNodeAccessRouteSubscriber.php @@ -22,6 +22,8 @@ class UwNodeAccessRouteSubscriber extends RouteSubscriberBase { 'entity.node.delete_form', // Menu link edit pages. 'menu_ui.link_edit', + // Role Expire config: admin/config/system/role-expire. + 'role_expire.config', ]; foreach ($access_route_names as $route_name) { if ($route = $collection->get($route_name)) { diff --git a/uw_cfg_common.permissions.yml b/uw_cfg_common.permissions.yml index 35b905c1b759a6d4b603e450698e186d428aa0eb..690230c45a4162ca9cb6e4a59735019be359d4a9 100644 --- a/uw_cfg_common.permissions.yml +++ b/uw_cfg_common.permissions.yml @@ -1,6 +1,10 @@ 'access content access form': title: 'Access content access form' description: 'Allows access to the content access form.' +'administer role expire configuration': + title: 'Administer role expire configuration' + description: 'Allows access to admin/config/system/role-expire.' + restrict access: true 'bypass home page protection': title: 'Bypass home page protection' description: 'Allows taking actions that are not normally allowed for the home page, such as unpublishing.'