mirror of
https://github.com/github/codeql.git
synced 2025-12-21 03:06:31 +01:00
Refactor CWE-089 Sql queries
This commit is contained in:
@@ -25,28 +25,27 @@ class UncontrolledStringBuilderSource extends DataFlow::ExprNode {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class UncontrolledStringBuilderSourceFlowConfig extends TaintTracking::Configuration {
|
private module UncontrolledStringBuilderSourceFlowConfig implements DataFlow::ConfigSig {
|
||||||
UncontrolledStringBuilderSourceFlowConfig() {
|
predicate isSource(DataFlow::Node src) { src instanceof UncontrolledStringBuilderSource }
|
||||||
this = "SqlConcatenated::UncontrolledStringBuilderSourceFlowConfig"
|
|
||||||
}
|
|
||||||
|
|
||||||
override predicate isSource(DataFlow::Node src) { src instanceof UncontrolledStringBuilderSource }
|
predicate isSink(DataFlow::Node sink) { sink instanceof QueryInjectionSink }
|
||||||
|
|
||||||
override predicate isSink(DataFlow::Node sink) { sink instanceof QueryInjectionSink }
|
predicate isBarrier(DataFlow::Node node) {
|
||||||
|
|
||||||
override predicate isSanitizer(DataFlow::Node node) {
|
|
||||||
node.getType() instanceof PrimitiveType or node.getType() instanceof BoxedType
|
node.getType() instanceof PrimitiveType or node.getType() instanceof BoxedType
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
module UncontrolledStringBuilderSourceFlow =
|
||||||
|
TaintTracking::Make<UncontrolledStringBuilderSourceFlowConfig>;
|
||||||
|
|
||||||
from QueryInjectionSink query, Expr uncontrolled
|
from QueryInjectionSink query, Expr uncontrolled
|
||||||
where
|
where
|
||||||
(
|
(
|
||||||
builtFromUncontrolledConcat(query.asExpr(), uncontrolled)
|
builtFromUncontrolledConcat(query.asExpr(), uncontrolled)
|
||||||
or
|
or
|
||||||
exists(StringBuilderVar sbv, UncontrolledStringBuilderSourceFlowConfig conf |
|
exists(StringBuilderVar sbv |
|
||||||
uncontrolledStringBuilderQuery(sbv, uncontrolled) and
|
uncontrolledStringBuilderQuery(sbv, uncontrolled) and
|
||||||
conf.hasFlow(DataFlow::exprNode(sbv.getToStringCall()), query)
|
UncontrolledStringBuilderSourceFlow::hasFlow(DataFlow::exprNode(sbv.getToStringCall()), query)
|
||||||
)
|
)
|
||||||
) and
|
) and
|
||||||
not queryTaintedBy(query, _, _)
|
not queryTaintedBy(query, _, _)
|
||||||
|
|||||||
@@ -15,26 +15,29 @@
|
|||||||
import semmle.code.java.Expr
|
import semmle.code.java.Expr
|
||||||
import semmle.code.java.dataflow.FlowSources
|
import semmle.code.java.dataflow.FlowSources
|
||||||
import semmle.code.java.security.SqlInjectionQuery
|
import semmle.code.java.security.SqlInjectionQuery
|
||||||
import DataFlow::PathGraph
|
|
||||||
|
|
||||||
class LocalUserInputToQueryInjectionFlowConfig extends TaintTracking::Configuration {
|
private module LocalUserInputToQueryInjectionFlowConfig implements DataFlow::ConfigSig {
|
||||||
LocalUserInputToQueryInjectionFlowConfig() { this = "LocalUserInputToQueryInjectionFlowConfig" }
|
predicate isSource(DataFlow::Node src) { src instanceof LocalUserInput }
|
||||||
|
|
||||||
override predicate isSource(DataFlow::Node src) { src instanceof LocalUserInput }
|
predicate isSink(DataFlow::Node sink) { sink instanceof QueryInjectionSink }
|
||||||
|
|
||||||
override predicate isSink(DataFlow::Node sink) { sink instanceof QueryInjectionSink }
|
predicate isBarrier(DataFlow::Node node) {
|
||||||
|
|
||||||
override predicate isSanitizer(DataFlow::Node node) {
|
|
||||||
node.getType() instanceof PrimitiveType or node.getType() instanceof BoxedType
|
node.getType() instanceof PrimitiveType or node.getType() instanceof BoxedType
|
||||||
}
|
}
|
||||||
|
|
||||||
override predicate isAdditionalTaintStep(DataFlow::Node node1, DataFlow::Node node2) {
|
predicate isAdditionalFlowStep(DataFlow::Node node1, DataFlow::Node node2) {
|
||||||
any(AdditionalQueryInjectionTaintStep s).step(node1, node2)
|
any(AdditionalQueryInjectionTaintStep s).step(node1, node2)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
module LocalUserInputToQueryInjectionFlow =
|
||||||
|
TaintTracking::Make<LocalUserInputToQueryInjectionFlowConfig>;
|
||||||
|
|
||||||
|
import LocalUserInputToQueryInjectionFlow::PathGraph
|
||||||
|
|
||||||
from
|
from
|
||||||
DataFlow::PathNode source, DataFlow::PathNode sink, LocalUserInputToQueryInjectionFlowConfig conf
|
LocalUserInputToQueryInjectionFlow::PathNode source,
|
||||||
where conf.hasFlowPath(source, sink)
|
LocalUserInputToQueryInjectionFlow::PathNode sink
|
||||||
|
where LocalUserInputToQueryInjectionFlow::hasFlowPath(source, sink)
|
||||||
select sink.getNode(), source, sink, "This query depends on a $@.", source.getNode(),
|
select sink.getNode(), source, sink, "This query depends on a $@.", source.getNode(),
|
||||||
"user-provided value"
|
"user-provided value"
|
||||||
|
|||||||
Reference in New Issue
Block a user