DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
PrivilegeNode.cs
Go to the documentation of this file.
1 //
2 // Copyright 2010-2015 Deveel
3 //
4 // Licensed under the Apache License, Version 2.0 (the "License");
5 // you may not use this file except in compliance with the License.
6 // You may obtain a copy of the License at
7 //
8 // http://www.apache.org/licenses/LICENSE-2.0
9 //
10 // Unless required by applicable law or agreed to in writing, software
11 // distributed under the License is distributed on an "AS IS" BASIS,
12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 // See the License for the specific language governing permissions and
14 // limitations under the License.
15 //
16 
17 using System;
18 using System.Collections.Generic;
19 using System.Linq;
20 
21 namespace Deveel.Data.Sql.Parser {
23  static PrivilegeNode() {
24  All = new PrivilegeNode {Privilege = "ALL"};
25  }
26 
27  public string Privilege { get; private set; }
28 
29  public IEnumerable<string> Columns { get; private set; }
30 
31  public static PrivilegeNode All { get; private set; }
32 
33  protected override ISqlNode OnChildNode(ISqlNode node) {
34  if (node is SqlKeyNode) {
35  Privilege = ((SqlKeyNode) node).Text;
36  } else if (node.NodeName.Equals("update_priv")) {
37  Privilege = "UPDATE";
38  GetPrivilegeWithColumns(node);
39  } else if (node.NodeName.Equals("select_priv")) {
40  Privilege = "SELECT";
41  GetPrivilegeWithColumns(node);
42  } else if (node.NodeName.Equals("reference_priv")) {
43  Privilege = "REFERENCE";
44  GetPrivilegeWithColumns(node);
45  }
46 
47  return base.OnChildNode(node);
48  }
49 
50  private void GetPrivilegeWithColumns(ISqlNode node) {
51  foreach (var childNode in node.ChildNodes) {
52  if (childNode.NodeName.Equals("column_list_opt"))
53  GetColumns(childNode);
54  }
55  }
56 
57  private void GetColumns(ISqlNode node) {
58  var childNode = node.ChildNodes.FirstOrDefault();
59  if (childNode == null)
60  return;
61 
62  var list = new List<string>();
63  foreach (var idNode in childNode.ChildNodes) {
64  if (idNode is IdentifierNode)
65  list.Add(((IdentifierNode)idNode).Text);
66  }
67 
68  Columns = list.AsEnumerable();
69  }
70  }
71 }
This is a simple identifier within a SQL grammar.
Defines the contract for nodes in an AST model for a SQL grammar analysis and parsing.
Definition: ISqlNode.cs:25
Represents a keyword found during the compilation of a source text.
Definition: SqlKeyNode.cs:25
string NodeName
Gets the name of the node analyzed from the parser.
Definition: ISqlNode.cs:29
void GetPrivilegeWithColumns(ISqlNode node)
IEnumerable< ISqlNode > ChildNodes
Gets a read-only enumeration of the children nodes, if any.
Definition: ISqlNode.cs:39
override ISqlNode OnChildNode(ISqlNode node)
During the initialization of the node from the parser, this method is called for every child node add...
The default implementation of ISqlNode, that is a node in the text analysis parsing of SQL commands...
Definition: SqlNode.cs:32