X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddPCU.py;h=3c46194668fcf3c37dc98f274264573af8112045;hb=d910a6190fec258ddbf0e26d01539839ac3fdc76;hp=8c47ade122a0334fbe357dabfe9f4bb19b09c6ce;hpb=f34d2986c1897c30ebbac1344f3d289b935382ea;p=plcapi.git diff --git a/PLC/Methods/AddPCU.py b/PLC/Methods/AddPCU.py index 8c47ade..3c46194 100644 --- a/PLC/Methods/AddPCU.py +++ b/PLC/Methods/AddPCU.py @@ -2,11 +2,11 @@ from PLC.Faults import * from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.PCUs import PCU, PCUs -from PLC.Auth import PasswordAuth +from PLC.Auth import Auth from PLC.Sites import Site, Sites can_update = lambda (field, value): field in \ - ['hostname', 'ip', 'protocol', + ['ip', 'hostname', 'protocol', 'username', 'password', 'model', 'notes'] @@ -23,22 +23,23 @@ class AddPCU(Method): roles = ['admin', 'pi', 'tech'] - update_fields = dict(filter(can_update, PCU.fields.items())) + pcu_fields = dict(filter(can_update, PCU.fields.items())) accepts = [ - PasswordAuth(), + Auth(), Mixed(Site.fields['site_id'], Site.fields['login_base']), - update_fields + pcu_fields ] returns = Parameter(int, 'New pcu_id (> 0) if successful') + - def call(self, auth, site_id_or_login_base, pcu_fields = {}): + def call(self, auth, site_id_or_login_base, pcu_fields): pcu_fields = dict(filter(can_update, pcu_fields.items())) # Get associated site details - sites = Sites(self.api, [site_id_or_login_base]).values() + sites = Sites(self.api, [site_id_or_login_base]) if not sites: raise PLCInvalidArgument, "No such site" site = sites[0] @@ -51,4 +52,10 @@ class AddPCU(Method): pcu['site_id'] = site['site_id'] pcu.sync() + # Logging variables + self.event_objects = {'Site': [site['site_id']], + 'PCU': [pcu['pcu_id']]} + self.message = 'PCU %d added site %s' % \ + (pcu['pcu_id'], site['site_id']) + return pcu['pcu_id']