~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to ivle/webapp/admin/user.py

Merged from new-dispatch branch.
This branch is now a child of new-dispatch (until that branch is merged with
    trunk).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# IVLE - Informatics Virtual Learning Environment
 
2
# Copyright (C) 2007-2009 The University of Melbourne
 
3
#
 
4
# This program is free software; you can redistribute it and/or modify
 
5
# it under the terms of the GNU General Public License as published by
 
6
# the Free Software Foundation; either version 2 of the License, or
 
7
# (at your option) any later version.
 
8
#
 
9
# This program is distributed in the hope that it will be useful,
 
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
12
# GNU General Public License for more details.
 
13
#
 
14
# You should have received a copy of the GNU General Public License
 
15
# along with this program; if not, write to the Free Software
 
16
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
17
 
 
18
# Author: Matt Giuca, Will Grant
 
19
 
 
20
from ivle.webapp.base.rest import JSONRESTView
 
21
from ivle.webapp.base.xhtml import XHTMLView
 
22
from ivle.webapp.base.plugins import ViewPlugin, MediaPlugin
 
23
from ivle.webapp.errors import NotFound, Unauthorized
 
24
import ivle.database
 
25
import ivle.util
 
26
 
 
27
# List of fields returned as part of the user JSON dictionary
 
28
# (as returned by the get_user action)
 
29
user_fields_list = (
 
30
    "login", "state", "unixid", "email", "nick", "fullname",
 
31
    "rolenm", "studentid", "acct_exp", "pass_exp", "last_login",
 
32
    "svn_pass"
 
33
)
 
34
 
 
35
class UserRESTView(JSONRESTView):
 
36
    """
 
37
    A REST interface to the user object.
 
38
    """
 
39
    def __init__(self, req, login):
 
40
        super(UserRESTView, self).__init__(self, req, login)
 
41
        self.context = ivle.database.User.get_by_login(req.store, login)
 
42
        if self.context is None:
 
43
            raise NotFound()
 
44
 
 
45
    def GET(self, req):
 
46
        # XXX Check Caps
 
47
        user = ivle.util.object_to_dict(user_fields_list, self.context)
 
48
        # Convert time stamps to nice strings
 
49
        for k in 'pass_exp', 'acct_exp', 'last_login':
 
50
            if user[k] is not None:
 
51
                user[k] = unicode(user[k])
 
52
 
 
53
        user['local_password'] = self.context.passhash is not None
 
54
        return user
 
55
 
 
56
    def PATCH(self, req, data):
 
57
        # XXX Check Caps
 
58
        # XXX Admins can set extra fields
 
59
        # Note: Cannot change password here (use change_password named op)
 
60
 
 
61
        for f in user_fields_list:
 
62
            try:
 
63
                field = data[f]
 
64
                if isinstance(field, str):
 
65
                    field = unicode(field)
 
66
                setattr(self.context, f, field)
 
67
            except KeyError:
 
68
                continue
 
69
 
 
70
class UserSettingsView(XHTMLView):
 
71
    template = 'user-settings.html'
 
72
    appname = 'settings'
 
73
 
 
74
    def __init__(self, req, login):
 
75
        self.context = ivle.database.User.get_by_login(req.store, login)
 
76
        if self.context is None:
 
77
            raise NotFound()
 
78
 
 
79
        if req.user is None or (req.user is not self.context and
 
80
                                req.user.rolenm != 'admin'):
 
81
            raise Unauthorized()
 
82
 
 
83
    def populate(self, req, ctx):
 
84
        self.plugin_scripts[Plugin] = ['settings.js']
 
85
        req.scripts_init = ['revert_settings']
 
86
 
 
87
        ctx['login'] = self.context.login
 
88
 
 
89
class Plugin(ViewPlugin, MediaPlugin):
 
90
    """
 
91
    The Plugin class for the user plugin.
 
92
    """
 
93
    # Magic attribute: urls
 
94
    # Sequence of pairs/triples of
 
95
    # (regex str, handler class, kwargs dict)
 
96
    # The kwargs dict is passed to the __init__ of the view object
 
97
    urls = [
 
98
        ('~:login/+settings', UserSettingsView),
 
99
        ('api/~:login', UserRESTView),
 
100
    ]
 
101
 
 
102
    media = 'user-media'