223
227
# Change the ownership of all the files to the right unixid
224
228
logging.debug("chown %s's home directory files to uid %d"
225
229
%(user.login, user.unixid))
226
os.spawnvp(os.P_WAIT, 'chown', ['chown', '-R', '%d:%d' % (user.unixid,
227
user.unixid), userhomedir])
230
os.chown(userhomedir, user.unixid, user.unixid)
231
for root, dirs, files in os.walk(userhomedir):
232
for fsobj in dirs + files:
233
os.chown(os.path.join(root, fsobj), user.unixid, user.unixid)
229
235
# No user jail exists
230
236
# Set up the user's home directory
234
240
# Chmod to rwxr-xr-x (755)
235
241
os.chmod(userhomedir, 0755)
237
make_conf_py(user.login, userdir, user.svn_pass)
243
make_conf_py(user.login, userdir, ivle.conf.jail_system, user.svn_pass)
238
244
make_etc_passwd(user.login, userdir, ivle.conf.jail_system, user.unixid)
240
246
return userhomedir
242
def make_conf_py(username, user_jail_dir, svn_pass):
248
def make_conf_py(username, user_jail_dir, staging_dir, svn_pass):
244
250
Creates (overwriting any existing file, and creating directories) a
245
251
file ${python_site_packages}/ivle/conf/conf.py in a given user's jail.
246
252
username: Username.
247
253
user_jail_dir: User's jail dir, ie. ivle.conf.jail_base + username
248
svn_pass: User's SVN password.
254
staging_dir: The dir with the staging copy of the jail. (With the
255
template conf.py file).
256
svn_pass: As with make_jail. User's SVN password, but if not supplied,
257
will look up in the DB.
259
template_conf_path = os.path.join(staging_dir,
260
ivle.conf.python_site_packages[1:], "ivle/conf/conf.py")
250
261
conf_path = os.path.join(user_jail_dir,
251
262
ivle.conf.python_site_packages[1:], "ivle/conf/conf.py")
252
263
os.makedirs(os.path.dirname(conf_path))
254
# In the "in-jail" version of conf, we don't need MOST of the details
255
# (it would be a security risk to have them here).
256
# So we just write root_dir, and jail_base is "/".
257
# (jail_base being "/" means "jail-relative" paths are relative to "/"
258
# when inside the jail.)
265
# Read the contents of the template conf file
267
template_conf_file = open(template_conf_path, "r")
268
template_conf_data = template_conf_file.read()
269
template_conf_file.close()
271
# Couldn't open template conf.py for some reason
272
# Just treat it as empty file
273
template_conf_data = ("# Warning: Problem building config script.\n"
274
"# Could not find template conf.py file.\n")
260
# XXX: jail_base is wrong and shouldn't be here. Unfortunately, jail code
261
# uses ivle.studpath.url_to_{local,jailpaths}, both of which use
262
# jail_base. Note that they don't use the bits of the return value
263
# that depend on jail_base, so it can be any string.
264
276
conf_file = open(conf_path, "w")
265
conf_file.write("""# IVLE jail configuration
267
# In URL space, where in the site is IVLE located. (All URLs will be prefixed
269
# eg. "/" or "/ivle".
270
root_dir = %(root_dir)r
272
# This value is not relevant inside the jail, but must remain for now. See
273
# the XXX in ivle.makeuser.make_conf_py.
276
# The hostname for serving publicly accessible pages
277
public_host = %(public_host)r
279
# The URL under which the Subversion repositories are located.
280
svn_addr = %(svn_addr)r
282
# The login name for the owner of the jail
285
# The subversion-only password for the owner of the jail
286
svn_pass = %(svn_pass)r
287
""" % {'root_dir': ivle.conf.root_dir,
288
'public_host': ivle.conf.public_host,
289
'svn_addr': ivle.conf.svn_addr,
290
'username': username,
291
'svn_pass': svn_pass,
277
conf_file.write(template_conf_data)
278
conf_file.write("\n# The login name for the owner of the jail\n")
279
conf_file.write("login = %s\n" % repr(username))
280
conf_file.write("\n")
281
conf_file.write("# The subversion-only password for the owner of "
283
conf_file.write("svn_pass = %s\n" % repr(svn_pass))
293
284
conf_file.close()
295
286
# Make this file world-readable