2
# IVLE - Informatics Virtual Learning Environment
3
# Copyright (C) 2007-2008 The University of Melbourne
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.
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.
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
19
# Program: RemakeAllUsers
23
# Script to rebuild jails for users on the system.
24
# One can specify a single username, or that all should be rebuilt.
25
# Requires root to run.
35
p = optparse.OptionParser()
36
p.add_option('--verbose', '-v', action='store_true')
37
p.add_option('--all', '-a', action='store_true')
38
options, arguments = p.parse_args()
40
level = logging.DEBUG if options.verbose else logging.WARNING
42
logging.basicConfig(format='%(asctime)s %(levelname)s %(message)s',
47
print >> sys.stderr, "%s must be run as root" % \
48
os.path.basename(sys.argv[0])
56
if len(arguments) == 0:
57
print >> sys.stderr, "must be run with -a or a username"
59
list = [db.get_user(arguments[0])]
60
res = db.get_all('login', ['login', 'unixid'])
62
return (flds['login'], flds['unixid'])
63
uids = dict(map(repack,res))
64
except Exception, message:
65
logging.error(str(message))
68
logging.info("rebuild started")
70
list.sort(key=lambda user: user.login)
75
# Resolve the user's login into a UID
79
raise Exception("user %s does not have a unixid in the database"
81
# Remake the user's jail
82
ivle.makeuser.make_jail(login, uid)
83
except Exception, message:
84
logging.warning(str(message))
87
logging.debug("recreated user %s's jail." % login)
89
logging.info("rebuild completed successfully")