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

« back to all changes in this revision

Viewing changes to bin/ivle-mountallusers

  • Committer: William Grant
  • Date: 2012-06-28 01:52:02 UTC
  • Revision ID: me@williamgrant.id.au-20120628015202-f6ru7o367gt6nvgz
Hah

Show diffs side-by-side

added added

removed removed

Lines of Context:
20
20
# Author:  William Grant
21
21
# Date:    4/7/2008
22
22
 
23
 
# Script to UnionFS-mount jails for all users on the system.
 
23
# Script to bind-mount jails for all users on the system.
24
24
# Requires root to run.
25
25
 
26
26
import sys
29
29
import optparse
30
30
import logging
31
31
 
 
32
import ivle.config
32
33
import ivle.database
33
 
import ivle.conf
34
34
 
35
35
p = optparse.OptionParser()
36
36
p.add_option('--verbose', '-v', action='store_true')
49
49
                          os.path.basename(sys.argv[0])
50
50
    sys.exit(1)
51
51
 
52
 
store = ivle.database.get_store()
 
52
config = ivle.config.Config()
 
53
store = ivle.database.get_store(config)
53
54
users = store.find(ivle.database.User).order_by(ivle.database.User.login)
54
55
 
55
 
logging.info("mass aufs mount started")
 
56
logging.info("mass bind mount started")
56
57
 
57
58
for user in users:
58
59
    login = user.login
59
60
    # This is where we'll mount to...
60
 
    destdir = os.path.join(ivle.conf.jail_base, login)
 
61
    destdir = os.path.join(config['paths']['jails']['mounts'], login)
61
62
    # ... and this is where we'll get the user bits.
62
 
    srcdir = os.path.join(ivle.conf.jail_src_base, login)
 
63
    srcdir = os.path.join(config['paths']['jails']['src'], login)
63
64
 
64
65
    try:
65
66
        if not options.unmount:
69
70
            if not os.path.exists(destdir):
70
71
                logging.debug("user %s had no mountpoint - creating" % login)
71
72
                os.mkdir(destdir)
72
 
        
73
 
            if os.system('/bin/mount -t aufs -o dirs=%s:%s=ro none %s'
74
 
                             % (srcdir,ivle.conf.jail_system,destdir)) == 0:
75
 
                logging.info("mounted user %s's jail." % login)
76
 
            else:
77
 
                logging.error("failed to mount user %s's jail!" % login)
 
73
            if os.path.exists(os.path.join(destdir, 'lib')):
 
74
                logging.info("%s's jail appears mounted. skipping." % login)
 
75
                continue
 
76
            # Mount read only root template
 
77
            if os.system('/bin/mount --bind -o ro %s %s'
 
78
                    % (config['paths']['jails']['template'], destdir)) == 0:
 
79
                logging.debug("mounted user %s's root template" % login)
 
80
            else:
 
81
                logging.debug("failed to mount %s's root template!" % login)
 
82
                continue
 
83
            # Mount homedir
 
84
            if os.system('/bin/mount --bind %s %s'
 
85
                    % (os.path.join(srcdir,'home'), os.path.join(destdir,'home'))) == 0:
 
86
                logging.debug("mounted user %s's home." % login)
 
87
            else:
 
88
                logging.error("failed to mount user %s's home!" % login)
 
89
                os.system("/bin/umount %s" % destdir)
 
90
                continue
 
91
            # Mount tmp
 
92
            if os.system('/bin/mount --bind %s %s'
 
93
                    % (os.path.join(srcdir,'tmp'), os.path.join(destdir,'tmp'))) == 0:
 
94
                logging.debug("mounted user %s's tmp." % login)
 
95
            else:
 
96
                logging.error("failed to mount user %s's tmp!" % login)
 
97
                os.system("/bin/umount %s" % os.path.join(destdir,'home'))
 
98
                os.system("/bin/umount %s" % destdir)
 
99
                continue
 
100
            logging.info("mounted user %s's jail" % login)
78
101
        else:
79
 
            os.system('/bin/umount ' + destdir)
 
102
            os.system("/bin/umount %s" % os.path.join(destdir,'tmp'))
 
103
            os.system("/bin/umount %s" % os.path.join(destdir,'home'))
 
104
            os.system("/bin/umount %s" % destdir)
80
105
            logging.info("unmounted user %s's jail." % login)
81
106
    except Exception, message:
82
107
        logging.warning(str(message))