<?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; use Twig\Node\Expression\AbstractExpression; /** * Checks if casting an expression to __toString() is allowed by the sandbox. * * For instance, when there is a simple Print statement, like {{ article }}, * and if the sandbox is enabled, we need to check that the __toString() * method is allowed if 'article' is an object. The same goes for {{ article|upper }} * or {{ random(article) }} * * @author Fabien Potencier <fabien@symfony.com> */ class CheckToStringNode extends AbstractExpression { public function __construct(AbstractExpression $expr) { parent::__construct(['expr' => $expr], [], $expr->getTemplateLine(), $expr->getNodeTag()); } public function compile(Compiler $compiler) { $expr = $this->getNode('expr'); $compiler ->raw('$this->sandbox->ensureToStringAllowed(') ->subcompile($expr) ->raw(', ') ->repr($expr->getTemplateLine()) ->raw(', $this->source)') ; } }
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 |
|