/** * @param Permitable $permitable * @return array of all module permissions data * Example of a return just for the accounts module. * Normally all the applicable modules permissions * would be returned in the array. * @code <?php $compareData = array( 'AccountsModule' => array( 'CREATE' => array( 'explicit' => null, 'inherited' => null, ), 'CHANGE_OWNER' => array( 'explicit' => null, 'inherited' => null, ), 'CHANGE_PERMISSIONS' => array( 'explicit' => null, 'inherited' => null, ), 'DELETE' => array( 'explicit' => null, 'inherited' => null, ), 'READ' => array( 'explicit' => null, 'inherited' => null, ), 'WRITE' => array( 'explicit' => null, 'inherited' => null, ), ), ); ?> * @endcode */ public static function getAllModulePermissionsDataByPermitable(Permitable $permitable) { $data = array(); try { $data = PermissionsCache::getAllModulePermissionsDataByPermitable($permitable); } catch (NotFoundException $e) { $modules = Module::getModuleObjects(); $permissions = PermissionsUtil::getPermissions(); foreach ($modules as $module) { if ($module instanceof SecurableModule) { $moduleClassName = get_class($module); $moduleName = $module->getName(); $item = NamedSecurableItem::getByName($moduleClassName); if (!empty($permissions)) { foreach ($permissions as $permission) { $explicit = PermissionsUtil::resolveExplicitOrInheritedPermission($item->getExplicitActualPermissions($permitable), $permission); $inherited = PermissionsUtil::resolveExplicitOrInheritedPermission($item->getInheritedActualPermissions($permitable), $permission); $actual = PermissionsUtil::resolveActualPermission($item->getActualPermissions($permitable), $permission); $data[$moduleClassName][$permission] = array('explicit' => PermissionsUtil::resolvePermissionForData($explicit), 'inherited' => PermissionsUtil::resolvePermissionForData($inherited), 'actual' => PermissionsUtil::resolvePermissionForData($actual)); } } } } PermissionsCache::cacheAllModulePermissionsDataByPermitables($permitable, $data); } return $data; }