X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=PLC%2FMethods%2FAddPersonToSite.py;h=0753e9adf94c6099e335e7eae323ddcb0fba5b33;hb=93c28dd3895303e5f0d52b1f47c68dc34d0a73f5;hp=e4719ab0948c52bd0b3b438c3eb434a0bfebc307;hpb=f8e0c71d96dce99eff25e5bb6bdf941468e897a2;p=plcapi.git diff --git a/PLC/Methods/AddPersonToSite.py b/PLC/Methods/AddPersonToSite.py index e4719ab..0753e9a 100644 --- a/PLC/Methods/AddPersonToSite.py +++ b/PLC/Methods/AddPersonToSite.py @@ -3,7 +3,7 @@ from PLC.Method import Method from PLC.Parameter import Parameter, Mixed from PLC.Persons import Person, Persons from PLC.Sites import Site, Sites -from PLC.Auth import PasswordAuth +from PLC.Auth import Auth class AddPersonToSite(Method): """ @@ -17,7 +17,7 @@ class AddPersonToSite(Method): roles = ['admin'] accepts = [ - PasswordAuth(), + Auth(), Mixed(Person.fields['person_id'], Person.fields['email']), Mixed(Site.fields['site_id'], @@ -25,9 +25,6 @@ class AddPersonToSite(Method): ] returns = Parameter(int, '1 if successful') - event_type = 'AddTo' - object_type = 'Site' - object_ids = [] def call(self, auth, person_id_or_email, site_id_or_login_base): # Get account information @@ -35,14 +32,16 @@ class AddPersonToSite(Method): if not persons: raise PLCInvalidArgument, "No such account" - person = persons.values()[0] + person = persons[0] + PLCCheckLocalPerson(person,"AddPersonToSite") # Get site information sites = Sites(self.api, [site_id_or_login_base]) if not sites: raise PLCInvalidArgument, "No such site" - site = sites.values()[0] + site = sites[0] + PLCCheckLocalSite(site,"AddPersonToSite") if site['site_id'] not in person['site_ids']: site.add_person(person)