You are here

function security_review_check_admin_permissions in Security Review 7

Same name and namespace in other branches
  1. 6 security_review.inc \security_review_check_admin_permissions()

Look for admin permissions granted to untrusted roles.

1 call to security_review_check_admin_permissions()
SecurityReviewTestCase::testCheckResults in tests/security_review.test
1 string reference to 'security_review_check_admin_permissions'
_security_review_security_checks in ./security_review.inc
Core Security Review's checks.

File

./security_review.inc, line 463
Stand-alone security checks and review system.

Code

function security_review_check_admin_permissions() {
  $result = TRUE;
  $check_result_value = array();
  $untrusted_roles = security_review_untrusted_roles();

  // Collect permissions marked as for trusted users only.
  $all_permissions = module_invoke_all('permission');
  $all_keys = array_keys($all_permissions);

  // Get permissions for untrusted roles.
  $untrusted_permissions = user_role_permissions($untrusted_roles);
  foreach ($untrusted_permissions as $rid => $permissions) {
    $intersect = array_intersect($all_keys, array_keys($permissions));
    foreach ($intersect as $permission) {
      if (!empty($all_permissions[$permission]['restrict access'])) {
        $check_result_value[$rid][] = $permission;
      }
    }
  }
  if (!empty($check_result_value)) {
    $result = FALSE;
  }
  return array(
    'result' => $result,
    'value' => $check_result_value,
  );
}