addPolicy(new PluginRequiredPolicy($request)); // Managers and site admin have access to plugins. We'll have to define // differentiated policies for those roles in a policy set. $pluginAccessPolicy = new PolicySet(PolicySet::COMBINING_PERMIT_OVERRIDES); $pluginAccessPolicy->setEffectIfNoPolicyApplies(AuthorizationPolicy::AUTHORIZATION_DENY); // // Managerial role // if (isset($roleAssignments[Role::ROLE_ID_MANAGER])) { if ($accessMode & self::ACCESS_MODE_MANAGE) { // Managers have edit settings access mode... $managerPluginAccessPolicy = new PolicySet(PolicySet::COMBINING_DENY_OVERRIDES); $managerPluginAccessPolicy->addPolicy(new RoleBasedHandlerOperationPolicy($request, Role::ROLE_ID_MANAGER, $roleAssignments[Role::ROLE_ID_MANAGER])); // ...only to context-level plugins. $managerPluginAccessPolicy->addPolicy(new PluginLevelRequiredPolicy($request, true)); $pluginAccessPolicy->addPolicy($managerPluginAccessPolicy); } } // // Site administrator role // if (isset($roleAssignments[Role::ROLE_ID_SITE_ADMIN])) { // Site admin have access to all plugins... $siteAdminPluginAccessPolicy = new PolicySet(PolicySet::COMBINING_DENY_OVERRIDES); $siteAdminPluginAccessPolicy->addPolicy(new RoleBasedHandlerOperationPolicy($request, Role::ROLE_ID_SITE_ADMIN, $roleAssignments[Role::ROLE_ID_SITE_ADMIN])); if ($accessMode & self::ACCESS_MODE_MANAGE) { // ...of site level only. $siteAdminPluginAccessPolicy->addPolicy(new PluginLevelRequiredPolicy($request, false)); } $pluginAccessPolicy->addPolicy($siteAdminPluginAccessPolicy); } $this->addPolicy($pluginAccessPolicy); } } if (!PKP_STRICT_MODE) { class_alias('\PKP\security\authorization\PluginAccessPolicy', '\PluginAccessPolicy'); define('ACCESS_MODE_MANAGE', PluginAccessPolicy::ACCESS_MODE_MANAGE); define('ACCESS_MODE_ADMIN', PluginAccessPolicy::ACCESS_MODE_ADMIN); }