176b22ead3eecaa7b15c8a340d840191f5530b24
[plcapi.git] / PLC / Methods / UpdatePersonTag.py
1 #
2 # Thierry Parmentelat - INRIA
3 #
4 from PLC.Faults import *
5 from PLC.Method import Method
6 from PLC.Parameter import Parameter, Mixed
7 from PLC.Auth import Auth
8
9 from PLC.PersonTags import PersonTag, PersonTags
10 from PLC.Persons import Person, Persons
11
12 from PLC.AuthorizeHelpers import AuthorizeHelpers
13
14 class UpdatePersonTag(Method):
15     """
16     Updates the value of an existing person setting
17
18     Admins have full access.  Non-admins can change their own tags.
19
20     Returns 1 if successful, faults otherwise.
21     """
22
23     roles = ['admin', 'pi', 'tech', 'user']
24
25     accepts = [
26         Auth(),
27         PersonTag.fields['person_tag_id'],
28         PersonTag.fields['value']
29         ]
30
31     returns = Parameter(int, '1 if successful')
32
33     def call(self, auth, person_tag_id, value):
34         person_tags = PersonTags(self.api, [person_tag_id])
35         if not person_tags:
36             raise PLCInvalidArgument, "No such person setting %r"%person_tag_id
37         person_tag = person_tags[0]
38
39         persons = Persons (self.api, person_tag['person_id'])
40         if not persons:
41             raise PLCInvalidArgument, "No such person %d"%person_tag['person_id']
42         person=persons[0]
43
44         # check authorizations
45         if 'admin' in self.caller['roles']:
46             pass
47         # user can change tags on self
48         elif AuthorizeHelpers.person_may_access_person (self.api, self.caller, person):
49             pass
50         else:
51             raise PLCPermissionDenied, "%s: you can only change your own tags"%self.name
52
53         person_tag['value'] = value
54         person_tag.sync()
55
56         self.object_ids = [person_tag['person_tag_id']]
57         return 1