<?php /* * This file is part of Twig. * * (c) Fabien Potencier * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Twig\Node; use Twig\Compiler; /** * @author Fabien Potencier <fabien@symfony.com> */ class CheckSecurityNode extends Node { private $usedFilters; private $usedTags; private $usedFunctions; public function __construct(array $usedFilters, array $usedTags, array $usedFunctions) { $this->usedFilters = $usedFilters; $this->usedTags = $usedTags; $this->usedFunctions = $usedFunctions; parent::__construct(); } public function compile(Compiler $compiler) { $tags = $filters = $functions = []; foreach (['tags', 'filters', 'functions'] as $type) { foreach ($this->{'used'.ucfirst($type)} as $name => $node) { if ($node instanceof Node) { ${$type}[$name] = $node->getTemplateLine(); } else { ${$type}[$node] = null; } } } $compiler ->write("\n") ->write("public function checkSecurity()\n") ->write("{\n") ->indent() ->write('static $tags = ')->repr(array_filter($tags))->raw(";\n") ->write('static $filters = ')->repr(array_filter($filters))->raw(";\n") ->write('static $functions = ')->repr(array_filter($functions))->raw(";\n\n") ->write("try {\n") ->indent() ->write("\$this->sandbox->checkSecurity(\n") ->indent() ->write(!$tags ? "[],\n" : "['".implode("', '", array_keys($tags))."'],\n") ->write(!$filters ? "[],\n" : "['".implode("', '", array_keys($filters))."'],\n") ->write(!$functions ? "[]\n" : "['".implode("', '", array_keys($functions))."']\n") ->outdent() ->write(");\n") ->outdent() ->write("} catch (SecurityError \$e) {\n") ->indent() ->write("\$e->setSourceContext(\$this->source);\n\n") ->write("if (\$e instanceof SecurityNotAllowedTagError && isset(\$tags[\$e->getTagName()])) {\n") ->indent() ->write("\$e->setTemplateLine(\$tags[\$e->getTagName()]);\n") ->outdent() ->write("} elseif (\$e instanceof SecurityNotAllowedFilterError && isset(\$filters[\$e->getFilterName()])) {\n") ->indent() ->write("\$e->setTemplateLine(\$filters[\$e->getFilterName()]);\n") ->outdent() ->write("} elseif (\$e instanceof SecurityNotAllowedFunctionError && isset(\$functions[\$e->getFunctionName()])) {\n") ->indent() ->write("\$e->setTemplateLine(\$functions[\$e->getFunctionName()]);\n") ->outdent() ->write("}\n\n") ->write("throw \$e;\n") ->outdent() ->write("}\n\n") ->outdent() ->write("}\n") ; } } class_alias('Twig\Node\CheckSecurityNode', 'Twig_Node_CheckSecurity');
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Expression | Folder | 0755 |
|
|
AutoEscapeNode.php | File | 915 B | 0644 |
|
BlockNode.php | File | 1.06 KB | 0644 |
|
BlockReferenceNode.php | File | 899 B | 0644 |
|
BodyNode.php | File | 397 B | 0644 |
|
CheckSecurityCallNode.php | File | 590 B | 0644 |
|
CheckSecurityNode.php | File | 3.1 KB | 0644 |
|
CheckToStringNode.php | File | 1.22 KB | 0644 |
|
DeprecatedNode.php | File | 1.41 KB | 0644 |
|
DoNode.php | File | 845 B | 0644 |
|
EmbedNode.php | File | 1.43 KB | 0644 |
|
FlushNode.php | File | 700 B | 0644 |
|
ForLoopNode.php | File | 1.56 KB | 0644 |
|
ForNode.php | File | 4.21 KB | 0644 |
|
IfNode.php | File | 1.8 KB | 0644 |
|
ImportNode.php | File | 1.74 KB | 0644 |
|
IncludeNode.php | File | 3.12 KB | 0644 |
|
MacroNode.php | File | 3.21 KB | 0644 |
|
ModuleNode.php | File | 14.78 KB | 0644 |
|
Node.php | File | 5.43 KB | 0644 |
|
NodeCaptureInterface.php | File | 461 B | 0644 |
|
NodeOutputInterface.php | File | 438 B | 0644 |
|
PrintNode.php | File | 936 B | 0644 |
|
SandboxNode.php | File | 1.32 KB | 0644 |
|
SandboxedPrintNode.php | File | 1.45 KB | 0644 |
|
SetNode.php | File | 3.34 KB | 0644 |
|
SetTempNode.php | File | 932 B | 0644 |
|
SpacelessNode.php | File | 1.18 KB | 0644 |
|
TextNode.php | File | 829 B | 0644 |
|
WithNode.php | File | 2.15 KB | 0644 |
|