expr, $context); $expr_type = $statements_analyzer->node_data->getType($stmt->expr); if ($expr_type) { if ($statements_analyzer->control_flow_graph instanceof \Psalm\Internal\Codebase\TaintFlowGraph && $expr_type->parent_nodes && !\in_array('TaintedInput', $statements_analyzer->getSuppressedIssues()) ) { $arg_location = new CodeLocation($statements_analyzer->getSource(), $stmt->expr); $eval_param_sink = TaintSink::getForMethodArgument( 'eval', 'eval', 0, $arg_location, $arg_location ); $eval_param_sink->taints = [\Psalm\Type\TaintKind::INPUT_TEXT]; $statements_analyzer->control_flow_graph->addSink($eval_param_sink); foreach ($expr_type->parent_nodes as $parent_node) { $statements_analyzer->control_flow_graph->addPath($parent_node, $eval_param_sink, 'arg'); } } } $context->check_classes = false; $context->check_variables = false; } }