23
23
# Script to create a new user. This can also be done through the
24
24
# administration interface.
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
29
# Import modules from the website is tricky since they're in the www
31
sys.path.append(os.path.join(os.getcwd(), 'www'))
33
33
import common.makeuser
35
# Requireds and optionals will be used to display the usage message
36
# AND do argument processing
37
# The names here must correspond to the fields in the database.
38
requireds = ["login", "fullname", "rolenm"]
40
('p', 'password', "Cleartext password for this user"),
41
('n', 'nick', "Display name (defaults to <fullname>)"),
42
('e', 'email', "Email address"),
43
('s', 'studentid', "Student ID")
46
if len(sys.argv) <= 3:
47
# Nicely format the usage message using the optionals
48
print ("Usage: python makeuser.py [OPTIONS] %s\n OPTIONS"
49
% ' '.join(['<%s>' % x for x in requireds]))
50
for short, long, desc in optionals:
51
t = " -%s | --%s" % (short, long)
52
print t + (' ' * max(28 - len(t), 2)) + desc
56
print "Must run makeuser.py as root."
59
shorts = ''.join([o[0] + ":" for o in optionals])
60
longs = [o[1] + "=" for o in optionals]
61
opts, args = getopt.gnu_getopt(sys.argv[1:], shorts, longs)
64
# Get the dictionary of fields from opts and args
66
for i in range(0, len(requireds)):
67
user[requireds[i]] = args[i]
68
for short, long, _ in optionals:
70
user[long] = opts['-' + short]
73
user[long] = opts['--' + long]
77
if 'nick' not in user:
78
user['nick'] = user['fullname']
35
if len(sys.argv) <= 1:
36
print "Usage: python makeuser.py <username>"
39
username = sys.argv[1]
81
# Make the user's database entry
82
common.makeuser.make_user_db(**user)
42
common.makeuser.makeuser(username)
83
43
except Exception, message:
84
44
print "Error: " + str(message)
87
print "Successfully created user %s (%s)." % (login, user['fullname'])
47
print "Successfully created user " + username + "."