X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddPersonKey.py;h=af701859c0ad3f84c857f629f8e2f876e4f9e51e;hb=bd0cbf4f7f2e4cf7ceda500bfa6f98c0a700018b;hp=b4ba0d3d7cce724fdb141fc1a300d88e56498a6e;hpb=2644b4d4675e890d2f4988c0c44ebc1f2145ea57;p=plcapi.git diff --git a/PLC/Methods/AddPersonKey.py b/PLC/Methods/AddPersonKey.py index b4ba0d3..af70185 100644 --- a/PLC/Methods/AddPersonKey.py +++ b/PLC/Methods/AddPersonKey.py @@ -3,7 +3,9 @@ from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.Keys import Key, Keys from PLC.Persons import Person, Persons -from PLC.Auth import PasswordAuth +from PLC.Auth import Auth + +can_update = lambda (field, value): field in ['key_type','key'] class AddPersonKey(Method): """ @@ -16,34 +18,42 @@ class AddPersonKey(Method): roles = ['admin', 'pi', 'tech', 'user'] + key_fields = dict(filter(can_update, Key.fields.items())) + accepts = [ - PasswordAuth(), + Auth(), Mixed(Person.fields['person_id'], Person.fields['email']), - Key.fields['key_type'], - Key.fields['key'] + key_fields ] returns = Parameter(int, 'New key_id (> 0) if successful') - def call(self, auth, person_id_or_email, key_type, key_value): + def call(self, auth, person_id_or_email, key_fields): + key_fields = dict(filter(can_update, key_fields.items())) + # Get account details - persons = Persons(self.api, [person_id_or_email]).values() + persons = Persons(self.api, [person_id_or_email]) if not persons: raise PLCInvalidArgument, "No such account" person = persons[0] - # If we are not admin, make sure caller is adding a key to their account + if person['peer_id'] is not None: + raise PLCInvalidArgument, "Not a local account" + + # If we are not admin, make sure caller is adding a key to their account if 'admin' not in self.caller['roles']: if person['person_id'] != self.caller['person_id']: raise PLCPermissionDenied, "You may only modify your own keys" - key = Key(self.api) - key['person_id'] = person['person_id'] - key['key_type'] = key_type - key['key'] = key_value + key = Key(self.api, key_fields) key.sync(commit = False) - person.add_key(key, commit = True) - + + # Logging variables + self.event_objects = {'Person': [person['person_id']], + 'Key': [key['key_id']]} + self.message = 'Key %d added to person %d' % \ + (key['key_id'], person['person_id']) + return key['key_id']