1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.mask.distsql.parser.core;
19
20 import org.apache.shardingsphere.database.connector.core.metadata.database.enums.QuoteCharacter;
21 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementBaseVisitor;
22 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.AlgorithmDefinitionContext;
23 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.AlterMaskRuleContext;
24 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.ColumnDefinitionContext;
25 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.CountMaskRuleContext;
26 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.CreateMaskRuleContext;
27 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.DatabaseNameContext;
28 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.DropMaskRuleContext;
29 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.MaskRuleDefinitionContext;
30 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.PropertiesDefinitionContext;
31 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.PropertyContext;
32 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.ShowMaskAlgorithmPluginsContext;
33 import org.apache.shardingsphere.distsql.parser.autogen.MaskDistSQLStatementParser.ShowMaskRulesContext;
34 import org.apache.shardingsphere.distsql.segment.AlgorithmSegment;
35 import org.apache.shardingsphere.distsql.statement.type.ral.queryable.show.ShowPluginsStatement;
36 import org.apache.shardingsphere.distsql.statement.type.rql.rule.database.CountRuleStatement;
37 import org.apache.shardingsphere.mask.distsql.segment.MaskColumnSegment;
38 import org.apache.shardingsphere.mask.distsql.segment.MaskRuleSegment;
39 import org.apache.shardingsphere.mask.distsql.statement.AlterMaskRuleStatement;
40 import org.apache.shardingsphere.mask.distsql.statement.CreateMaskRuleStatement;
41 import org.apache.shardingsphere.mask.distsql.statement.DropMaskRuleStatement;
42 import org.apache.shardingsphere.mask.distsql.statement.ShowMaskRulesStatement;
43 import org.apache.shardingsphere.sql.parser.api.ASTNode;
44 import org.apache.shardingsphere.sql.parser.api.visitor.SQLVisitor;
45 import org.apache.shardingsphere.sql.parser.statement.core.segment.dal.FromDatabaseSegment;
46 import org.apache.shardingsphere.sql.parser.statement.core.segment.generic.DatabaseSegment;
47 import org.apache.shardingsphere.sql.parser.statement.core.util.IdentifierValueUtils;
48 import org.apache.shardingsphere.sql.parser.statement.core.value.identifier.IdentifierValue;
49
50 import java.util.Properties;
51 import java.util.stream.Collectors;
52
53
54
55
56 public final class MaskDistSQLStatementVisitor extends MaskDistSQLStatementBaseVisitor<ASTNode> implements SQLVisitor<ASTNode> {
57
58 @Override
59 public ASTNode visitCreateMaskRule(final CreateMaskRuleContext ctx) {
60 return new CreateMaskRuleStatement(null != ctx.ifNotExists(), ctx.maskRuleDefinition().stream().map(each -> (MaskRuleSegment) visit(each)).collect(Collectors.toList()));
61 }
62
63 @Override
64 public ASTNode visitAlterMaskRule(final AlterMaskRuleContext ctx) {
65 return new AlterMaskRuleStatement(ctx.maskRuleDefinition().stream().map(each -> (MaskRuleSegment) visit(each)).collect(Collectors.toList()));
66 }
67
68 @Override
69 public ASTNode visitDropMaskRule(final DropMaskRuleContext ctx) {
70 return new DropMaskRuleStatement(null != ctx.ifExists(), ctx.ruleName().stream().map(IdentifierValueUtils::getValue).collect(Collectors.toList()));
71 }
72
73 @Override
74 public ASTNode visitShowMaskRules(final ShowMaskRulesContext ctx) {
75 return new ShowMaskRulesStatement(null == ctx.RULE() ? null : IdentifierValueUtils.getValue(ctx.ruleName()),
76 null == ctx.databaseName() ? null : new FromDatabaseSegment(ctx.FROM().getSymbol().getStartIndex(), (DatabaseSegment) visit(ctx.databaseName())));
77 }
78
79 @Override
80 public ASTNode visitCountMaskRule(final CountMaskRuleContext ctx) {
81 return new CountRuleStatement(null == ctx.databaseName() ? null : new FromDatabaseSegment(ctx.FROM().getSymbol().getStartIndex(), (DatabaseSegment) visit(ctx.databaseName())), "MASK");
82 }
83
84 @Override
85 public ASTNode visitMaskRuleDefinition(final MaskRuleDefinitionContext ctx) {
86 return new MaskRuleSegment(IdentifierValueUtils.getValue(ctx.ruleName()), ctx.columnDefinition().stream().map(each -> (MaskColumnSegment) visit(each)).collect(Collectors.toList()));
87 }
88
89 @Override
90 public ASTNode visitColumnDefinition(final ColumnDefinitionContext ctx) {
91 return new MaskColumnSegment(IdentifierValueUtils.getValue(ctx.columnName()), (AlgorithmSegment) visit(ctx.algorithmDefinition()));
92 }
93
94 @Override
95 public ASTNode visitAlgorithmDefinition(final AlgorithmDefinitionContext ctx) {
96 return new AlgorithmSegment(IdentifierValueUtils.getValue(ctx.algorithmTypeName()), getProperties(ctx.propertiesDefinition()));
97 }
98
99 private Properties getProperties(final PropertiesDefinitionContext ctx) {
100 Properties result = new Properties();
101 if (null == ctx || null == ctx.properties()) {
102 return result;
103 }
104 for (PropertyContext each : ctx.properties().property()) {
105 result.setProperty(QuoteCharacter.unwrapAndTrimText(each.key.getText()), QuoteCharacter.unwrapAndTrimText(each.value.getText()));
106 }
107 return result;
108 }
109
110 @Override
111 public ASTNode visitDatabaseName(final DatabaseNameContext ctx) {
112 return new DatabaseSegment(ctx.getStart().getStartIndex(), ctx.getStop().getStopIndex(), new IdentifierValue(ctx.getText()));
113 }
114
115 @Override
116 public ASTNode visitShowMaskAlgorithmPlugins(final ShowMaskAlgorithmPluginsContext ctx) {
117 return new ShowPluginsStatement("MASK_ALGORITHM");
118 }
119 }