Skip to content

Commit

Permalink
improve sql parser & wall
Browse files Browse the repository at this point in the history
  • Loading branch information
wenshao committed Aug 30, 2013
1 parent 3659426 commit ee0a1c4
Show file tree
Hide file tree
Showing 6 changed files with 81 additions and 8 deletions.
2 changes: 1 addition & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
<junit.version>4.11</junit.version>

<gpg.skip>true</gpg.skip>
<javadoc.skip>false</javadoc.skip>
<javadoc.skip>true</javadoc.skip>

<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<jdk.version>1.6</jdk.version>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,8 @@

public class OracleExprParser extends SQLExprParser {



public boolean allowStringAdditive = false;

/**
Expand Down Expand Up @@ -480,12 +482,37 @@ public SQLExpr primary() {
protected SQLExpr methodRest(SQLExpr expr, boolean acceptLPAREN) {
if (acceptLPAREN) {
accept(Token.LPAREN);
if (lexer.token() == Token.PLUS) {
lexer.nextToken();
}

if (lexer.token() == Token.PLUS) {
lexer.nextToken();
accept(Token.RPAREN);
return new OracleOuterExpr(expr);
}

if (expr instanceof SQLIdentifierExpr) {
String methodName = ((SQLIdentifierExpr) expr).getName();
SQLMethodInvokeExpr methodExpr = new SQLMethodInvokeExpr(methodName);
if ("trim".equalsIgnoreCase(methodName)) {
if (identifierEquals("LEADING") //
|| identifierEquals("TRAILING") //
|| identifierEquals("BOTH")
) {
methodExpr.putAttribute("trim_option", lexer.stringVal());
lexer.nextToken();
}
SQLExpr trim_character = this.primary();
trim_character.setParent(methodExpr);
methodExpr.putAttribute("trim_character", trim_character);
accept(Token.FROM);
SQLExpr trim_source = this.expr();
methodExpr.addParameter(trim_source);

accept(Token.RPAREN);
return new OracleOuterExpr(expr);
return primaryRest(methodExpr);
}
}

return super.methodRest(expr, false);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3383,4 +3383,27 @@ public void endVisit(OracleCheck x) {
protected void printCascade() {
print(" CASCADE CONSTRAINTS");
}

@Override
public boolean visit(SQLMethodInvokeExpr x) {
if ("trim".equalsIgnoreCase(x.getMethodName())) {
SQLExpr trim_character = (SQLExpr) x.getAttribute("trim_character");
if (trim_character != null) {
print(x.getMethodName());
print("(");
String trim_option = (String) x.getAttribute("trim_option");
if (trim_option != null && trim_option.length() != 0) {
print(trim_option);
print(' ');
}
trim_character.accept(this);
print(" FROM ");
x.getParameters().get(0).accept(this);
print(")");
return false;
}
}

return super.visit(x);
}
}
10 changes: 10 additions & 0 deletions src/main/java/com/alibaba/druid/wall/WallConfig.java
Original file line number Diff line number Diff line change
Expand Up @@ -108,10 +108,20 @@ public class WallConfig implements WallConfigMBean {
private boolean conditionOpXorAllow = false;
private boolean conditionOpBitwseAllow = true;

private boolean caseConditionAllow = false;

public WallConfig(){

}

public boolean isCaseConditionAllow() {
return caseConditionAllow;
}

public void setCaseConditionAllow(boolean caseConditionAllow) {
this.caseConditionAllow = caseConditionAllow;
}

public boolean isConditionDoubleConstAllow() {
return conditionDoubleConstAllow;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@
import com.alibaba.druid.sql.ast.statement.SQLUpdateStatement;
import com.alibaba.druid.sql.dialect.sqlserver.ast.SQLServerSelectQueryBlock;
import com.alibaba.druid.sql.dialect.sqlserver.ast.expr.SQLServerObjectReferenceExpr;
import com.alibaba.druid.sql.dialect.sqlserver.ast.stmt.SQLServerExecStatement;
import com.alibaba.druid.sql.dialect.sqlserver.ast.stmt.SQLServerInsertStatement;
import com.alibaba.druid.sql.dialect.sqlserver.visitor.SQLServerASTVisitor;
import com.alibaba.druid.sql.dialect.sqlserver.visitor.SQLServerASTVisitorAdapter;
Expand Down Expand Up @@ -152,6 +153,10 @@ public boolean visit(SQLMethodInvokeExpr x) {

return true;
}
@Override
public boolean visit(SQLServerExecStatement x) {
return false;
}

public boolean visit(SQLExprTableSource x) {
WallVisitorUtils.check(this, x);
Expand Down
16 changes: 12 additions & 4 deletions src/main/java/com/alibaba/druid/wall/spi/WallVisitorUtils.java
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ public static void checkSelelct(WallVisitor visitor, SQLSelectQueryBlock x) {
boolean isSimpleConstExpr = false;
SQLExpr first = getFirst(where);

if (first == where) {
if (first == where || first instanceof SQLLiteralExpr) {
isSimpleConstExpr = true;
} else if (first instanceof SQLBinaryOpExpr) {
SQLBinaryOpExpr binaryOpExpr = (SQLBinaryOpExpr) first;
Expand All @@ -278,7 +278,6 @@ public static void checkSelelct(WallVisitor visitor, SQLSelectQueryBlock x) {
addViolation(visitor, ErrorCode.ALWAY_TRUE, "select alway true condition not allow", x);
}
}

}
checkConditionForMultiTenant(visitor, x.getWhere(), x);
} finally {
Expand Down Expand Up @@ -1046,9 +1045,18 @@ public static Object getValue(WallVisitor visitor, SQLExpr x) {
return SQLEvalVisitorUtils.eval(dbType, x, Collections.emptyList(), false);
}

if (x instanceof SQLCaseExpr) {
if (visitor != null && (!visitor.getConfig().isCaseConditionAllow()) && x instanceof SQLCaseExpr) {
SQLCaseExpr caseExpr = (SQLCaseExpr) x;
if (caseExpr.getItems().size() > 0) {

boolean leftIsName = false;
if (caseExpr.getParent() instanceof SQLBinaryOpExpr) {
SQLExpr left = ((SQLBinaryOpExpr) caseExpr.getParent()).getLeft();
if (left instanceof SQLName) {
leftIsName = true;
}
}

if ((!leftIsName) && caseExpr.getItems().size() > 0) {
SQLCaseExpr.Item item = caseExpr.getItems().get(0);
Object conditionVal = getValue(visitor, item.getConditionExpr());
Object itemVal = getValue(visitor, item.getValueExpr());
Expand Down

0 comments on commit ee0a1c4

Please sign in to comment.