X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=engine%2Fmanifoldquery.py;h=ab09bfe7c84ec0dd750f0301d980f0d2036bca62;hb=bab62cfb3e8bd2769ad19ed5e9d70d4d407d95ed;hp=ce9f3ea4847ee8cdd6d1e41bcd643e1485409c54;hpb=171b1ca63f0b8ad399fbb063a018513b8e4ea03b;p=unfold.git diff --git a/engine/manifoldquery.py b/engine/manifoldquery.py index ce9f3ea4..ab09bfe7 100644 --- a/engine/manifoldquery.py +++ b/engine/manifoldquery.py @@ -1,8 +1,8 @@ import json +import uuid -# xxx php has uniqid, need to find a module for that -counter=1 -def uniqid (): global counter; counter += 1; return counter +def uniqid (): + return uuid.uuid4().hex class ManifoldQuery: @@ -47,15 +47,12 @@ class ManifoldQuery: return """ new Query('%(a)s', '%(m)s', '%(t)s', %(f)s, %(p)s, %(c)s, %(unique)s, '%(uuid)s', %(aq)s, %(sq)s)"""%locals() - # 4amine - # xxx - # this should build an object from a dict as received from javascript - # to see an example just look at the server's output - # incoming POST + # this builds a ManifoldQuery object from a dict as received from javascript through its ajax request + # e.g. here's what I captured from the server's output + # incoming POST def fill_from_dict (self, d): - print d for key in d.keys(): - for arg in ['action', 'method', 'filters', 'fields', 'timestamp', 'params']: + for arg in ['action', 'method', 'filters', 'fields', 'timestamp', 'params']: if arg in key: # dirty hack around fields; fields must be a list if arg == 'fields': @@ -63,4 +60,86 @@ class ManifoldQuery: else: setattr(self, arg, d[key]) break - + + + + def analyze_subqueries(self): + analyzed_query = ManifoldQuery() + analyzed_query.uuid = self.uuid + analyzed_query.action = self.action + analyzed_query.method = self.method + analyzed_query.timestamp = self.timestamp + + # analyse query filters + # filter syntax : ['key', 'oparation', 'value'] + for filter in self.filters: + key = filter[0] + operation = filter[1] + value = filter[2] + if '.' in key: + method = key.split('.')[0] + field = key.split('.')[1] + if not analyzed_query.subqueries[method]: + subquery = ManifoldQuery() + subquery.action = self.action + subquery.method = method + subquery.timestamp = self.timestamp + analyzed_query.subqueries[method] = subquery + + analyzed_query.subqueries[method].filters.append([field, operation, value]) + else: + analyzed_query.filters.append(filter) + + # analyse query params + # params syntax : params = {'param1': value1, 'param2': value2, ...} + for param in self.params.keys(): + if '.' in param: + method = param.split('.')[0] + field = param.split('.')[1] + if not analyzed_query.subqueries[method]: + subquery = ManifoldQuery() + subquery.action = self.action + subquery.method = method + subquery.timestamp = self.timestamp + analyzed_query.subqueries[method] = subquery + + analyzed_query.subqueries[method].params[field] = self.params[param] + else: + analyzed_query.params[param] = self.params[param] + + # analyse query fields + # fields syntax: fields = [element1, element2, ....] + for element in self.fields: + if '.' in element: + method = element.split('.')[0] + field = element.split('.')[1] + if not analyzed_query.subqueries[method]: + subquery = ManifoldQuery() + subquery.action = self.action + subquery.method = method + subquery.timestamp = self.timestamp + analyzed_query.subqueries[method] = subquery + + analyzed_query.subqueries[method].fields.append(field) + else: + analyzed_query.fields.append(element) + + + # default subqueries + if analyzed_query.method == 'slice': + if not analyzed_query.subqueries['resource']: + subquery = ManifoldQuery() + subquery.action = self.action + subquery.method = method + subquery.timestamp = self.timestamp + analyzed_query.subqueries['resource'] = subquery + + if not analyzed_query.subqueries['lease']: + subquery = ManifoldQuery() + subquery.action = self.action + subquery.method = method + subquery.timestamp = self.timestamp + analyzed_query.subqueries['lease'] = subquery + + + self.analyzed_query = analyzed_query