Files
codeql/java/ql/test/library-tests/dataflow/call-sensitivity/flow.ql

27 lines
740 B
Plaintext

/**
* @kind path-problem
*/
import java
import semmle.code.java.dataflow.DataFlow
import codeql.dataflow.test.ProvenancePathGraph
import semmle.code.java.dataflow.ExternalFlow
import ShowProvenance<interpretModelForTest/2, Flow::PathNode, Flow::PathGraph>
module Config implements DataFlow::ConfigSig {
predicate isSource(DataFlow::Node src) { src.asExpr() instanceof ClassInstanceExpr }
predicate isSink(DataFlow::Node sink) {
exists(MethodCall ma |
ma.getMethod().hasName("sink") and
ma.getAnArgument() = sink.asExpr()
)
}
}
module Flow = DataFlow::Global<Config>;
from Flow::PathNode source, Flow::PathNode sink
where Flow::flowPath(source, sink)
select source, source, sink, "$@", sink, sink.toString()