* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Bridge\Twig\Extension; use Symfony\Component\HttpKernel\Controller\ControllerReference; use Symfony\Component\HttpKernel\Fragment\FragmentHandler; use Twig\Extension\AbstractExtension; use Twig\TwigFunction; /** * Provides integration with the HttpKernel component. * * @author Fabien Potencier */ class HttpKernelExtension extends AbstractExtension { private $handler; public function __construct(FragmentHandler $handler) { $this->handler = $handler; } public function getFunctions() { return array( new TwigFunction('render', array($this, 'renderFragment'), array('is_safe' => array('html'))), new TwigFunction('render_*', array($this, 'renderFragmentStrategy'), array('is_safe' => array('html'))), new TwigFunction('controller', array($this, 'controller')), ); } /** * Renders a fragment. * * @param string|ControllerReference $uri A URI as a string or a ControllerReference instance * @param array $options An array of options * * @return string The fragment content * * @see FragmentHandler::render() */ public function renderFragment($uri, $options = array()) { $strategy = isset($options['strategy']) ? $options['strategy'] : 'inline'; unset($options['strategy']); return $this->handler->render($uri, $strategy, $options); } /** * Renders a fragment. * * @param string $strategy A strategy name * @param string|ControllerReference $uri A URI as a string or a ControllerReference instance * @param array $options An array of options * * @return string The fragment content * * @see FragmentHandler::render() */ public function renderFragmentStrategy($strategy, $uri, $options = array()) { return $this->handler->render($uri, $strategy, $options); } public function controller($controller, $attributes = array(), $query = array()) { return new ControllerReference($controller, $attributes, $query); } /** * {@inheritdoc} */ public function getName() { return 'http_kernel'; } }