This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
symfony/src/Symfony/Bundle/TwigBundle/Extension/SecurityExtension.php
Fabien Potencier 055b6e4d6e made a big refactoring of the templating sub-framework
* better separation of concerns
 * made TwigBundle independant of the PHP Engine from FrameworkBundle (WIP)
 * removed one layer of abstraction in the Templating component (renderers)
 * made it easier to create a new Engine for any templating library
 * made engines lazy-loaded (PHP engine for instance is not started if you only use Twig)
 * reduces memory footprint (if you only use one engine)
 * reduces size of compiled classes.php cache file
2011-01-15 07:43:05 +01:00

60 lines
1.3 KiB
PHP

<?php
namespace Symfony\Bundle\TwigBundle\Extension;
use Symfony\Bundle\TwigBundle\TokenParser\IfRoleTokenParser;
use Symfony\Component\Security\SecurityContext;
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien.potencier@symfony-project.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
/**
* SecurityExtension exposes security context features.
*
* @author Fabien Potencier <fabien.potencier@symfony-project.com>
*/
class SecurityExtension extends \Twig_Extension
{
protected $context;
public function __construct(SecurityContext $context = null)
{
$this->context = $context;
}
public function vote($role, $object = null, $field = null)
{
if (null === $this->context) {
return false;
}
return $this->context->vote($role, $object, $field);
}
/**
* {@inheritdoc}
*/
public function getFunctions()
{
return array(
'has_role' => new \Twig_Function_Method($this, 'vote'),
);
}
/**
* Returns the name of the extension.
*
* @return string The extension name
*/
public function getName()
{
return 'security';
}
}