134
by mattgiuca
Added module: common/makeuser.py. Creates a new user jail by hardlinking the |
1 |
#!/usr/bin/env python
|
2 |
# IVLE - Informatics Virtual Learning Environment
|
|
3 |
# Copyright (C) 2007-2008 The University of Melbourne
|
|
4 |
#
|
|
5 |
# This program is free software; you can redistribute it and/or modify
|
|
6 |
# it under the terms of the GNU General Public License as published by
|
|
7 |
# the Free Software Foundation; either version 2 of the License, or
|
|
8 |
# (at your option) any later version.
|
|
9 |
#
|
|
10 |
# This program is distributed in the hope that it will be useful,
|
|
11 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
12 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
13 |
# GNU General Public License for more details.
|
|
14 |
#
|
|
15 |
# You should have received a copy of the GNU General Public License
|
|
16 |
# along with this program; if not, write to the Free Software
|
|
17 |
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
18 |
||
19 |
# Program: MakeUser
|
|
20 |
# Author: Matt Giuca
|
|
21 |
# Date: 9/1/2008
|
|
22 |
||
23 |
# Script to create a new user. This can also be done through the
|
|
24 |
# administration interface.
|
|
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
25 |
# This script wraps common.makeuser.
|
26 |
# It also creates a unix account which common.makeuser does not.
|
|
27 |
# (This script may not be appropriate for production on a multi-node
|
|
28 |
# environment).
|
|
134
by mattgiuca
Added module: common/makeuser.py. Creates a new user jail by hardlinking the |
29 |
|
30 |
import sys |
|
31 |
import os |
|
32 |
import os.path |
|
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
33 |
import pwd |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
34 |
import getopt |
134
by mattgiuca
Added module: common/makeuser.py. Creates a new user jail by hardlinking the |
35 |
# Import modules from the website is tricky since they're in the www
|
36 |
# directory.
|
|
37 |
sys.path.append(os.path.join(os.getcwd(), 'www')) |
|
38 |
import conf |
|
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
39 |
import common.makeuser, common.db |
40 |
||
41 |
# Requireds and optionals will be used to display the usage message
|
|
42 |
# AND do argument processing
|
|
43 |
# The names here must correspond to the fields in the database.
|
|
44 |
requireds = ["login", "fullname", "rolenm"] |
|
45 |
optionals = [ |
|
46 |
('p', 'password', "Cleartext password for this user"), |
|
47 |
('n', 'nick', "Display name (defaults to <fullname>)"), |
|
48 |
('e', 'email', "Email address"), |
|
481
by stevenbird
reverted change that added a command-line flag to specify that an account should be enabled as this bypasses creating the jail |
49 |
('s', 'studentid', "Student ID") |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
50 |
]
|
51 |
||
52 |
if len(sys.argv) <= 3: |
|
53 |
# Nicely format the usage message using the optionals
|
|
54 |
print ("Usage: python makeuser.py [OPTIONS] %s\n OPTIONS" |
|
55 |
% ' '.join(['<%s>' % x for x in requireds])) |
|
56 |
for short, long, desc in optionals: |
|
57 |
t = " -%s | --%s" % (short, long) |
|
58 |
print t + (' ' * max(28 - len(t), 2)) + desc |
|
59 |
sys.exit(1) |
|
134
by mattgiuca
Added module: common/makeuser.py. Creates a new user jail by hardlinking the |
60 |
|
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
61 |
if os.getuid() != 0: |
62 |
print "Must run makeuser.py as root." |
|
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
63 |
sys.exit(1) |
64 |
||
65 |
shorts = ''.join([o[0] + ":" for o in optionals]) |
|
66 |
longs = [o[1] + "=" for o in optionals] |
|
67 |
opts, args = getopt.gnu_getopt(sys.argv[1:], shorts, longs) |
|
68 |
opts = dict(opts) |
|
69 |
||
70 |
# Get the dictionary of fields from opts and args
|
|
480
by stevenbird
doc/setup/install_proc.txt |
71 |
user = {} |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
72 |
for i in range(0, len(requireds)): |
480
by stevenbird
doc/setup/install_proc.txt |
73 |
user[requireds[i]] = args[i] |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
74 |
for short, long, _ in optionals: |
75 |
try: |
|
480
by stevenbird
doc/setup/install_proc.txt |
76 |
user[long] = opts['-' + short] |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
77 |
except KeyError: |
78 |
try: |
|
480
by stevenbird
doc/setup/install_proc.txt |
79 |
user[long] = opts['--' + long] |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
80 |
except KeyError: |
81 |
pass
|
|
480
by stevenbird
doc/setup/install_proc.txt |
82 |
login = user['login'] |
83 |
if 'nick' not in user: |
|
84 |
user['nick'] = user['fullname'] |
|
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
85 |
|
474
by mattgiuca
makeuser.py: Uncommented a try block I commented out. |
86 |
try: |
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
87 |
# Resolve the user's username into a UID
|
88 |
# Create the user if it does not exist
|
|
89 |
try: |
|
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
90 |
(_,_,uid,_,_,_,_) = pwd.getpwnam(login) |
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
91 |
except KeyError: |
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
92 |
if os.system("useradd '%s'" % login) != 0: |
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
93 |
raise Exception("Failed to add Unix user account") |
94 |
try: |
|
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
95 |
(_,_,uid,_,_,_,_) = pwd.getpwnam(login) |
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
96 |
except KeyError: |
97 |
raise Exception("Failed to add Unix user account") |
|
480
by stevenbird
doc/setup/install_proc.txt |
98 |
user['unixid'] = uid |
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
99 |
# Make the user's jail
|
472
by mattgiuca
db.py: No longer exceptions if password is not supplied. |
100 |
common.makeuser.make_jail(login, uid) |
412
by mattgiuca
lib/common/makeuser: Removed function makeuser. This top-level function is too |
101 |
# Make the user's database entry
|
480
by stevenbird
doc/setup/install_proc.txt |
102 |
common.makeuser.make_user_db(**user) |
474
by mattgiuca
makeuser.py: Uncommented a try block I commented out. |
103 |
except Exception, message: |
104 |
print "Error: " + str(message) |
|
105 |
sys.exit(1) |
|
134
by mattgiuca
Added module: common/makeuser.py. Creates a new user jail by hardlinking the |
106 |
|
480
by stevenbird
doc/setup/install_proc.txt |
107 |
print "Successfully created user %s (%s)." % (login, user['fullname']) |