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

« back to all changes in this revision

Viewing changes to www/auth/guest_auth.py

  • Committer: David Coles
  • Date: 2009-08-06 04:04:37 UTC
  • Revision ID: coles.david@gmail.com-20090806040437-a8k5jhkkf2ixud5a
Add a rather lenient RLIMIT_NPROC that will prevent simple fork bombs (hopefully accidental...) from taking down a server.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# IVLE - Informatics Virtual Learning Environment
2
 
# Copyright (C) 2007-2008 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
 
# Module: Guest Authenticate
19
 
# Author: Matt Giuca
20
 
# Date:   21/2/2008
21
 
 
22
 
# Pluggable authentication module for LDAP servers.
23
 
# This module is part-test part-something-you-may-want.
24
 
# If enabled, it allows "external auth" against an account "guest" with
25
 
# password "guest".
26
 
# It may be called with a None user, and will return a guest User object,
27
 
# which will mean it gets put in the database.
28
 
# Thus it behaves similarly to a module which retrieves user details from an
29
 
# external source like LDAP.
30
 
# This module is NOT active implicitly - it must be specified in the
31
 
# "auth_modules" config string.
32
 
 
33
 
from autherror import AuthError
34
 
from common.user import User
35
 
from common.caps import Role
36
 
 
37
 
# XXX: What to put here
38
 
GUEST_UID = 4000
39
 
 
40
 
def auth(dbconn, login, password, user):
41
 
    """
42
 
    A plugin auth function, as described above.
43
 
    This one authenticates against a "guest"/"guest" account.
44
 
    Returns user if successful. Raises AuthError if unsuccessful.
45
 
    Returns a new User object if user is None.
46
 
    """
47
 
    if login != "guest" or password != "guest":
48
 
        raise AuthError()
49
 
 
50
 
    if user is not None:
51
 
        return user
52
 
 
53
 
    # Create a guest user
54
 
    return User(login="guest", fullname="Guest Account", nick="Guest",
55
 
        role=Role.ANYONE, state="no_agreement", unixid=GUEST_UID)