X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=rest%2F__init__.py;h=a8565963546a762a88ad2672103e85d694b25f0a;hb=f3986ca10595bec2c5559c9bc6fb034be4cbd2d8;hp=bdf3ee0812d241bd91cb9d88bb72fd91f7f6da4d;hpb=d09e3b74f294d4d712ac5ef4abeeb0a18e4b11b9;p=unfold.git diff --git a/rest/__init__.py b/rest/__init__.py index bdf3ee08..a8565963 100644 --- a/rest/__init__.py +++ b/rest/__init__.py @@ -40,10 +40,36 @@ class ObjectRequest(object): self.filters['disabled'] = '0' self.filters['gateway_type'] = 'sfa' self.filters['platform'] = '!myslice' + #elif(self.type.startswith('local:')): + elif ':' in self.type: + table = self.type.split(':') + prefix = table[0] + table = table[1] + + if prefix is 'local': + # XXX TODO: find a generic Query to get the fields like + # select column.name from local:object where table == local:user + table = self.type.split(':') + table = table[1] + if table == "user": + self.id = table + '_id' + self.fields = ['user_id', 'email', 'password', 'config','status']; + elif table == "account": + # XXX TODO: Multiple key for account = (platform_id, user_id) + self.id = "platform_id, user_id" + self.fields = ['platform_id', 'user_id', 'auth_type', 'config']; + elif table == "platform": + self.id = 'platform' + self.fields = ['platform', 'platform_longname', 'platform_url', 'platform_description','gateway_type']; + else: + # If we use prefix, set the key without the prefix then add it again + self.type = table + self.setKey() + self.setLocalFields() + self.type = prefix + ':' + table else : self.setKey() self.setLocalFields() - def setKey(self): # What about key formed of multiple fields??? @@ -94,7 +120,7 @@ class ObjectRequest(object): def get(self): query = Query.get(self.type) - if (self.id not in self.fields) : + if (self.id is not None) and (self.id not in self.fields) : query.select(self.fields + [self.id]) else : query.select(self.fields) @@ -106,7 +132,11 @@ class ObjectRequest(object): query = Query.create(self.type) # No filters for create if self.params : - query.set(self.params) + for p in self.params : + for k,v in p.iteritems() : + print "param: %s : %s" % (k,v) + query.set({k : v}) + print "query = ",query else: raise Exception, "Params are required for create" return execute_query(self.request, query) @@ -114,15 +144,19 @@ class ObjectRequest(object): def update(self): query = Query.update(self.type) query = self.applyFilters(query, True) - print ">>>>>",self.params - + if self.params : - query.set({ 'resource' : self.params}) -# for param in self.params : - + for p in self.params : + for k,v in p.iteritems() : + print "param: %s : %s" % (k,v) + query.set({k : v}) + print "query = ",query else: raise Exception, "Params are required for update" - + + if self.id is not None: + query.select(self.id) + return execute_query(self.request, query) def delete(self): @@ -131,7 +165,7 @@ class ObjectRequest(object): if self.filters : query.set(self.filters) else: - raise Exception, "Filters are required for update" + raise Exception, "Filters are required for delete" return execute_query(self.request, query) def json(self):