You are here

public function TwigSandboxPolicy::checkMethodAllowed in Drupal 8

Same name and namespace in other branches
  1. 9 core/lib/Drupal/Core/Template/TwigSandboxPolicy.php \Drupal\Core\Template\TwigSandboxPolicy::checkMethodAllowed()
  2. 10 core/lib/Drupal/Core/Template/TwigSandboxPolicy.php \Drupal\Core\Template\TwigSandboxPolicy::checkMethodAllowed()

File

core/lib/Drupal/Core/Template/TwigSandboxPolicy.php, line 85

Class

TwigSandboxPolicy
Default sandbox policy for Twig templates.

Namespace

Drupal\Core\Template

Code

public function checkMethodAllowed($obj, $method) {
  foreach ($this->whitelisted_classes as $class => $key) {
    if ($obj instanceof $class) {
      return TRUE;
    }
  }

  // Return quickly for an exact match of the method name.
  if (isset($this->whitelisted_methods[$method])) {
    return TRUE;
  }

  // If the method name starts with a whitelisted prefix, allow it.
  // Note: strpos() is between 3x and 7x faster than preg_match in this case.
  foreach ($this->whitelisted_prefixes as $prefix) {
    if (strpos($method, $prefix) === 0) {
      return TRUE;
    }
  }
  throw new \Twig_Sandbox_SecurityError(sprintf('Calling "%s" method on a "%s" object is not allowed.', $method, get_class($obj)));
}