|
@@ -172,16 +172,26 @@ class StatsDatabase:
|
|
|
field_types = self.get_field_types('ip_mac', 'ip_ttl', 'ip_ports', 'ip_protocols', 'ip_statistics', 'ip_mac')
|
|
|
conditions = []
|
|
|
for key, op, value in param_op_val:
|
|
|
+
|
|
|
if isinstance(value, pp.ParseResults):
|
|
|
-
|
|
|
- rvalue = self._execute_query_list(value)
|
|
|
-
|
|
|
-
|
|
|
- if op is not "in" and value[0] in ['most_used', 'least_used', 'all']:
|
|
|
- raise QueryExecutionException("The extractor '" + value[0] + "' may return more than one result!")
|
|
|
-
|
|
|
-
|
|
|
- value = map(lambda x: str(x[0]), rvalue)
|
|
|
+ if value[0] == "list":
|
|
|
+
|
|
|
+ value = value[1:]
|
|
|
+
|
|
|
+
|
|
|
+ if op is not "in":
|
|
|
+ raise QueryExecutionException("List values require the usage of the 'in' operator!")
|
|
|
+ else:
|
|
|
+
|
|
|
+ rvalue = self._execute_query_list(value)
|
|
|
+
|
|
|
+
|
|
|
+ if op is not "in" and value[0] in ['most_used', 'least_used', 'all']:
|
|
|
+ raise QueryExecutionException("The extractor '" + value[0] +
|
|
|
+ "' may return more than one result!")
|
|
|
+
|
|
|
+
|
|
|
+ value = map(lambda x: str(x[0]), rvalue)
|
|
|
else:
|
|
|
|
|
|
value = [value]
|