mirror of
https://github.com/github/codeql.git
synced 2026-05-03 12:45:27 +02:00
Merge pull request #6319 from haby0/java/MyBatisSqlInjection
[Java] CWE-089 MyBatis Mapper Sql Injection
This commit is contained in:
@@ -24,3 +24,81 @@ private class SqlSinkCsv extends SinkModelCsv {
|
||||
]
|
||||
}
|
||||
}
|
||||
|
||||
/** The class `org.apache.ibatis.session.Configuration`. */
|
||||
class IbatisConfiguration extends RefType {
|
||||
IbatisConfiguration() { this.hasQualifiedName("org.apache.ibatis.session", "Configuration") }
|
||||
}
|
||||
|
||||
/**
|
||||
* The method `getVariables()` declared in `org.apache.ibatis.session.Configuration`.
|
||||
*/
|
||||
class IbatisConfigurationGetVariablesMethod extends Method {
|
||||
IbatisConfigurationGetVariablesMethod() {
|
||||
this.getDeclaringType() instanceof IbatisConfiguration and
|
||||
this.hasName("getVariables") and
|
||||
this.getNumberOfParameters() = 0
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis select.
|
||||
*/
|
||||
private class IbatisSelectAnnotationType extends AnnotationType {
|
||||
IbatisSelectAnnotationType() { this.hasQualifiedName("org.apache.ibatis.annotations", "Select") }
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis delete.
|
||||
*/
|
||||
private class IbatisDeleteAnnotationType extends AnnotationType {
|
||||
IbatisDeleteAnnotationType() { this.hasQualifiedName("org.apache.ibatis.annotations", "Delete") }
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis insert.
|
||||
*/
|
||||
private class IbatisInsertAnnotationType extends AnnotationType {
|
||||
IbatisInsertAnnotationType() { this.hasQualifiedName("org.apache.ibatis.annotations", "Insert") }
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis update.
|
||||
*/
|
||||
private class IbatisUpdateAnnotationType extends AnnotationType {
|
||||
IbatisUpdateAnnotationType() { this.hasQualifiedName("org.apache.ibatis.annotations", "Update") }
|
||||
}
|
||||
|
||||
/**
|
||||
* An Ibatis SQL operation annotation.
|
||||
*/
|
||||
class IbatisSqlOperationAnnotation extends Annotation {
|
||||
IbatisSqlOperationAnnotation() {
|
||||
this.getType() instanceof IbatisSelectAnnotationType or
|
||||
this.getType() instanceof IbatisDeleteAnnotationType or
|
||||
this.getType() instanceof IbatisInsertAnnotationType or
|
||||
this.getType() instanceof IbatisUpdateAnnotationType
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets this annotation's SQL statement string.
|
||||
*/
|
||||
string getSqlValue() {
|
||||
result = this.getAValue("value").(CompileTimeConstantExpr).getStringValue()
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Methods annotated with `@org.apache.ibatis.annotations.Select` or `@org.apache.ibatis.annotations.Delete`
|
||||
* or `@org.apache.ibatis.annotations.Update` or `@org.apache.ibatis.annotations.Insert`.
|
||||
*/
|
||||
class MyBatisSqlOperationAnnotationMethod extends Method {
|
||||
MyBatisSqlOperationAnnotationMethod() {
|
||||
this.getAnAnnotation() instanceof IbatisSqlOperationAnnotation
|
||||
}
|
||||
}
|
||||
|
||||
/** The interface `org.apache.ibatis.annotations.Param`. */
|
||||
class TypeParam extends Interface {
|
||||
TypeParam() { this.hasQualifiedName("org.apache.ibatis.annotations", "Param") }
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user