1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-05 20:48:45 +01:00
psalm/src/Psalm/Internal/Analyzer/Statements/Expression/EncapsulatedStringAnalyzer.php

62 lines
2.0 KiB
PHP
Raw Normal View History

2020-05-18 21:13:27 +02:00
<?php
namespace Psalm\Internal\Analyzer\Statements\Expression;
use PhpParser;
use Psalm\Internal\Analyzer\Statements\ExpressionAnalyzer;
use Psalm\Internal\Analyzer\StatementsAnalyzer;
2020-06-23 22:38:59 +02:00
use Psalm\CodeLocation;
2020-05-18 21:13:27 +02:00
use Psalm\Context;
use Psalm\Type;
class EncapsulatedStringAnalyzer
{
public static function analyze(
StatementsAnalyzer $statements_analyzer,
PhpParser\Node\Scalar\Encapsed $stmt,
Context $context
) : bool {
2020-06-23 22:38:59 +02:00
$codebase = $statements_analyzer->getCodebase();
$stmt_type = Type::getString();
2020-05-18 21:13:27 +02:00
foreach ($stmt->parts as $part) {
if (ExpressionAnalyzer::analyze($statements_analyzer, $part, $context) === false) {
return false;
}
2020-06-23 22:38:59 +02:00
$part_type = $statements_analyzer->node_data->getType($part);
if ($part_type) {
$casted_part_type = CastAnalyzer::castStringAttempt(
$statements_analyzer,
$context,
$part_type,
$part
);
2020-06-23 22:38:59 +02:00
if ($codebase->taint
&& $codebase->config->trackTaintsInPath($statements_analyzer->getFilePath())
&& !\in_array('TaintedInput', $statements_analyzer->getSuppressedIssues())
2020-06-23 22:38:59 +02:00
) {
$var_location = new CodeLocation($statements_analyzer, $part);
$new_parent_node = \Psalm\Internal\Taint\TaintNode::getForAssignment('concat', $var_location);
$codebase->taint->addTaintNode($new_parent_node);
$stmt_type->parent_nodes[] = $new_parent_node;
if ($casted_part_type->parent_nodes) {
foreach ($casted_part_type->parent_nodes as $parent_node) {
2020-06-23 22:38:59 +02:00
$codebase->taint->addPath($parent_node, $new_parent_node, 'concat');
}
}
}
2020-05-18 21:13:27 +02:00
}
}
2020-06-23 22:38:59 +02:00
$statements_analyzer->node_data->setType($stmt, $stmt_type);
2020-05-18 21:13:27 +02:00
return true;
}
}