mirror of
https://github.com/github/codeql.git
synced 2025-12-17 01:03:14 +01:00
139 lines
4.4 KiB
Plaintext
139 lines
4.4 KiB
Plaintext
private import python
|
|
private import semmle.python.dataflow.new.FlowSummary
|
|
private import semmle.python.ApiGraphs
|
|
|
|
/**
|
|
* This module ensures that the `callStep` predicate in
|
|
* our type tracker implelemtation does not refer to the
|
|
* `getACall` predicate on `SummarizedCallable`.
|
|
*/
|
|
module RecursionGuard {
|
|
private import semmle.python.dataflow.new.internal.TypeTrackerSpecific as TT
|
|
|
|
private class RecursionGuard extends SummarizedCallable {
|
|
RecursionGuard() { this = "RecursionGuard" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result.getFunction().asCfgNode().(NameNode).getId() = this and
|
|
(TT::callStep(_, _) implies any())
|
|
}
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
none()
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() { result.asExpr().(Name).getId() = this }
|
|
}
|
|
}
|
|
|
|
private class SummarizedCallableIdentity extends SummarizedCallable {
|
|
SummarizedCallableIdentity() { this = "identity" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result.getFunction().asCfgNode().(NameNode).getId() = this
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() { result.asExpr().(Name).getId() = this }
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
input = "Argument[0]" and
|
|
output = "ReturnValue" and
|
|
preservesValue = true
|
|
}
|
|
}
|
|
|
|
// For lambda flow to work, implement lambdaCall and lambdaCreation
|
|
private class SummarizedCallableApplyLambda extends SummarizedCallable {
|
|
SummarizedCallableApplyLambda() { this = "apply_lambda" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result.getFunction().asCfgNode().(NameNode).getId() = this
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() { result.asExpr().(Name).getId() = this }
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
input = "Argument[1]" and
|
|
output = "Argument[0].Parameter[0]" and
|
|
preservesValue = true
|
|
or
|
|
input = "Argument[0].ReturnValue" and
|
|
output = "ReturnValue" and
|
|
preservesValue = true
|
|
}
|
|
}
|
|
|
|
private class SummarizedCallableReversed extends SummarizedCallable {
|
|
SummarizedCallableReversed() { this = "list_reversed" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result.getFunction().asCfgNode().(NameNode).getId() = this
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() { result.asExpr().(Name).getId() = this }
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
input = "Argument[0].ListElement" and
|
|
output = "ReturnValue.ListElement" and
|
|
preservesValue = true
|
|
}
|
|
}
|
|
|
|
private class SummarizedCallableMap extends SummarizedCallable {
|
|
SummarizedCallableMap() { this = "list_map" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result.getFunction().asCfgNode().(NameNode).getId() = this
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() { result.asExpr().(Name).getId() = this }
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
input = "Argument[1].ListElement" and
|
|
output = "Argument[0].Parameter[0]" and
|
|
preservesValue = true
|
|
or
|
|
input = "Argument[0].ReturnValue" and
|
|
output = "ReturnValue.ListElement" and
|
|
preservesValue = true
|
|
}
|
|
}
|
|
|
|
private class SummarizedCallableAppend extends SummarizedCallable {
|
|
SummarizedCallableAppend() { this = "append_to_list" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result.getFunction().asCfgNode().(NameNode).getId() = this
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() { result.asExpr().(Name).getId() = this }
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
input = "Argument[0]" and
|
|
output = "ReturnValue" and
|
|
preservesValue = false
|
|
or
|
|
input = "Argument[1]" and
|
|
output = "ReturnValue.ListElement" and
|
|
preservesValue = true
|
|
}
|
|
}
|
|
|
|
private class SummarizedCallableJsonLoads extends SummarizedCallable {
|
|
SummarizedCallableJsonLoads() { this = "json.loads" }
|
|
|
|
override DataFlow::CallCfgNode getACall() {
|
|
result = API::moduleImport("json").getMember("loads").getACall()
|
|
}
|
|
|
|
override DataFlow::ArgumentNode getACallback() {
|
|
result = API::moduleImport("json").getMember("loads").getAValueReachableFromSource()
|
|
}
|
|
|
|
override predicate propagatesFlow(string input, string output, boolean preservesValue) {
|
|
input = "Argument[0]" and
|
|
output = "ReturnValue.ListElement" and
|
|
preservesValue = true
|
|
}
|
|
}
|