mirror of
https://github.com/github/codeql.git
synced 2026-05-04 13:15:21 +02:00
New model: SQL injection in MyBatis annotations
This commit is contained in:
@@ -40,3 +40,119 @@ class IbatisConfigurationGetVariablesMethod extends Method {
|
||||
getNumberOfParameters() = 0
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis select.
|
||||
*/
|
||||
private class IbatisSelectAnnotationType extends AnnotationType {
|
||||
IbatisSelectAnnotationType() {
|
||||
this.hasQualifiedName("org.apache.ibatis.annotations", "Select") or
|
||||
this.getAnAnnotation().getType() instanceof IbatisSelectAnnotationType
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis delete.
|
||||
*/
|
||||
private class IbatisDeleteAnnotationType extends AnnotationType {
|
||||
IbatisDeleteAnnotationType() {
|
||||
this.hasQualifiedName("org.apache.ibatis.annotations", "Delete") or
|
||||
this.getAnAnnotation().getType() instanceof IbatisDeleteAnnotationType
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis insert.
|
||||
*/
|
||||
private class IbatisInsertAnnotationType extends AnnotationType {
|
||||
IbatisInsertAnnotationType() {
|
||||
this.hasQualifiedName("org.apache.ibatis.annotations", "Insert") or
|
||||
this.getAnAnnotation().getType() instanceof IbatisInsertAnnotationType
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An annotation type that identifies Ibatis update.
|
||||
*/
|
||||
private class IbatisUpdateAnnotationType extends AnnotationType {
|
||||
IbatisUpdateAnnotationType() {
|
||||
this.hasQualifiedName("org.apache.ibatis.annotations", "Update") or
|
||||
this.getAnAnnotation().getType() instanceof IbatisUpdateAnnotationType
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Ibatis sql operation annotation.
|
||||
*/
|
||||
abstract class IbatisSqlOperationAnnotation extends Annotation {
|
||||
abstract string getSqlValue();
|
||||
}
|
||||
|
||||
/**
|
||||
* A `@org.apache.ibatis.annotations.Select` annotation.
|
||||
*/
|
||||
private class IbatisSelectAnnotation extends IbatisSqlOperationAnnotation {
|
||||
IbatisSelectAnnotation() { this.getType() instanceof IbatisSelectAnnotationType }
|
||||
|
||||
string getSelectValue() {
|
||||
result = this.getValue("value").(CompileTimeConstantExpr).getStringValue() or
|
||||
result =
|
||||
this.getValue("value").(ArrayInit).getInit(_).(CompileTimeConstantExpr).getStringValue()
|
||||
}
|
||||
|
||||
override string getSqlValue() { result = getSelectValue() }
|
||||
}
|
||||
|
||||
/**
|
||||
* A `@org.apache.ibatis.annotations.Delete` annotation.
|
||||
*/
|
||||
private class IbatisDeleteAnnotation extends IbatisSqlOperationAnnotation {
|
||||
IbatisDeleteAnnotation() { this.getType() instanceof IbatisDeleteAnnotationType }
|
||||
|
||||
string getDeleteValue() {
|
||||
result = this.getValue("value").(CompileTimeConstantExpr).getStringValue() or
|
||||
result =
|
||||
this.getValue("value").(ArrayInit).getInit(_).(CompileTimeConstantExpr).getStringValue()
|
||||
}
|
||||
|
||||
override string getSqlValue() { result = getDeleteValue() }
|
||||
}
|
||||
|
||||
/**
|
||||
* A `@org.apache.ibatis.annotations.Insert` annotation.
|
||||
*/
|
||||
private class IbatisInsertAnnotation extends IbatisSqlOperationAnnotation {
|
||||
IbatisInsertAnnotation() { this.getType() instanceof IbatisInsertAnnotationType }
|
||||
|
||||
string getInsertValue() {
|
||||
result = this.getValue("value").(CompileTimeConstantExpr).getStringValue() or
|
||||
result =
|
||||
this.getValue("value").(ArrayInit).getInit(_).(CompileTimeConstantExpr).getStringValue()
|
||||
}
|
||||
|
||||
override string getSqlValue() { result = getInsertValue() }
|
||||
}
|
||||
|
||||
/**
|
||||
* A `@org.apache.ibatis.annotations.Update` annotation.
|
||||
*/
|
||||
private class IbatisUpdateAnnotation extends IbatisSqlOperationAnnotation {
|
||||
IbatisUpdateAnnotation() { this.getType() instanceof IbatisUpdateAnnotationType }
|
||||
|
||||
string getUpdateValue() {
|
||||
result = this.getValue("value").(CompileTimeConstantExpr).getStringValue() or
|
||||
result =
|
||||
this.getValue("value").(ArrayInit).getInit(_).(CompileTimeConstantExpr).getStringValue()
|
||||
}
|
||||
|
||||
override string getSqlValue() { result = getUpdateValue() }
|
||||
}
|
||||
|
||||
// Mybatis uses sql operation to annotate the method of interacting with the database.
|
||||
class MybatisSqlOperationAnnotationMethod extends Method {
|
||||
MybatisSqlOperationAnnotationMethod() {
|
||||
exists(IbatisSqlOperationAnnotation isoa |
|
||||
this.getAnAnnotation() = isoa
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user