X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Fmethods%2FUpdate.py;h=507509cd4bd53e8a7e13c27dde4d7e72274fd1f8;hb=834c2d04d922f2ac5d67b5b45b4aac69435ae3e7;hp=e0b1003e3d719982e88796ccb2f2692d3e8f6a08;hpb=cf630d87d633f3861e3ac8a50433fa29ca46a74e;p=sfa.git diff --git a/sfa/methods/Update.py b/sfa/methods/Update.py index e0b1003e..507509cd 100644 --- a/sfa/methods/Update.py +++ b/sfa/methods/Update.py @@ -4,12 +4,13 @@ from sfa.trust.credential import Credential from sfa.storage.parameter import Parameter + class Update(Method): """ Update an object in the registry. Currently, this only updates the PLC information associated with the record. The SFA fields (name, type, GID) are fixed. - + @param cred credential string specifying rights of the caller @param record a record dictionary to be updated @@ -17,25 +18,26 @@ class Update(Method): """ interfaces = ['registry'] - + accepts = [ Parameter(dict, "Record dictionary to be updated"), Parameter(str, "Credential string"), - ] + ] returns = Parameter(int, "1 if successful") - + def call(self, record_dict, creds): # validate the cred valid_creds = self.api.auth.checkCredentials(creds, "update") - + # verify permissions - hrn = record_dict.get('hrn', '') + hrn = record_dict.get('hrn', '') self.api.auth.verify_object_permission(hrn) - + # log - origin_hrn = Credential(string=valid_creds[0]).get_gid_caller().get_hrn() - self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s"%(self.api.interface, origin_hrn, hrn, self.name)) - - return self.api.manager.Update(self.api, record_dict) + origin_hrn = Credential( + string=valid_creds[0]).get_gid_caller().get_hrn() + self.api.logger.info("interface: %s\tcaller-hrn: %s\ttarget-hrn: %s\tmethod-name: %s" % + (self.api.interface, origin_hrn, hrn, self.name)) + return self.api.manager.Update(self.api, record_dict)