QueryParser.py 2.1 KB

123456789101112131415161718192021222324252627282930313233343536
  1. import pyparsing as pp
  2. class QueryParser:
  3. def __init__(self):
  4. # TODO: Try to disallow invalid combinations
  5. # TODO: Have tests for invalid combinations
  6. # TODO: allow lists as input, like: ipaddress(macaddress in [1,2,3])
  7. extractor = pp.Keyword("random") ^ pp.Keyword("first") ^ pp.Keyword("last")
  8. selector = pp.Keyword("most_used") ^ pp.Keyword("least_used") ^ pp.Keyword("avg") ^ pp.Keyword("all")
  9. attribute = pp.Keyword("ipaddress") ^ pp.Keyword("macaddress") ^ pp.Keyword("portnumber") ^\
  10. pp.Keyword("protocolname") ^ pp.Keyword("ttlvalue") ^ pp.Keyword("mssvalue") ^\
  11. pp.Keyword("winsize") ^ pp.Keyword("ipclass") ^ pp.Keyword("pktssent") ^\
  12. pp.Keyword("pktsreceived") ^ pp.Keyword("mss") ^ pp.Keyword("kbytesreceived") ^\
  13. pp.Keyword("kbytessent")
  14. simple_selector_query = selector + pp.Suppress("(") + attribute + pp.Suppress(")")
  15. param_selectors = pp.Keyword("ipaddress").setParseAction(pp.replaceWith("ipaddress_param")) ^\
  16. pp.Keyword("macaddress").setParseAction(pp.replaceWith("macaddress_param"))
  17. operators = pp.Literal("<=") ^ pp.Literal("<") ^ pp.Literal("=") ^\
  18. pp.Literal(">=") ^ pp.Literal(">") ^ pp.CaselessLiteral("in")
  19. expr = pp.Forward()
  20. comparison = pp.Group(attribute + operators + (pp.Word(pp.alphanums + ".:") ^ expr))
  21. parameterized_query = param_selectors + pp.Suppress("(") + pp.Group(pp.delimitedList(comparison)) + pp.Suppress(")")
  22. # parameterized_query = param_selectors + pp.Suppress("(") + comparison + pp.Suppress(")")
  23. all_selector_queries = (simple_selector_query ^ parameterized_query)
  24. extractor_selector_query = extractor + pp.Suppress("(") + all_selector_queries + pp.Suppress(")")
  25. named_query = (extractor_selector_query ^ all_selector_queries)
  26. expr << pp.Group(named_query)
  27. self.full_query = named_query + pp.Suppress(";")
  28. def parse_query(self, querystring: str) -> pp.ParseResults:
  29. return self.full_query.parseString(querystring)