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

« back to all changes in this revision

Viewing changes to bin/ivle-refreshfilesystem

  • 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:
18
18
 
19
19
"""Refresh parts of the filesystem that are generated from the database.
20
20
 
21
 
In particular, the Subversion authorisation files are rewritten.
 
21
In particular:
 
22
 - missing user jails are created
 
23
 - missing user and group Subversion repositories are created
 
24
 - the Subversion password file is updated
 
25
 - the Subversion authorisation files are rewritten
22
26
"""
23
27
 
24
 
import sys
 
28
import datetime
 
29
import logging
 
30
import os
 
31
import os.path
 
32
import shutil
25
33
 
26
34
from ivle.config import Config
27
 
from ivle.database import get_store
 
35
from ivle.database import get_store, ProjectGroup, User
28
36
import ivle.makeuser
29
37
 
30
 
config = Config()
31
 
store = get_store(config)
32
 
 
33
 
print >>sys.stderr, "Rebuilding Subversion user configuration..."
34
 
ivle.makeuser.rebuild_svn_config(store, config)
35
 
print >>sys.stderr, "Rebuilding Subversion group configuration..."
36
 
ivle.makeuser.rebuild_svn_group_config(store, config)
37
 
 
38
 
 
 
38
 
 
39
logging.basicConfig(
 
40
    format='%(asctime)s %(levelname)s %(message)s',
 
41
    level=logging.INFO)
 
42
 
 
43
 
 
44
JUNK_DIRECTORY_SUFFIX = (
 
45
    '-removed-%s' % datetime.datetime.now().strftime('%Y%m%d-%H%M%S'))
 
46
 
 
47
 
 
48
def get_junk_dir(path):
 
49
    return os.path.normpath(path) + JUNK_DIRECTORY_SUFFIX
 
50
 
 
51
 
 
52
def junk(parent, name):
 
53
    """Move the named directory into a junk directory alongside the parent."""
 
54
    if not os.path.exists(get_junk_dir(parent)):
 
55
        os.makedirs(get_junk_dir(parent))
 
56
    shutil.move(
 
57
        os.path.join(parent, name),
 
58
        os.path.join(get_junk_dir(parent), name))
 
59
 
 
60
 
 
61
def refresh_filesystem(config, store):
 
62
    active_users = store.find(User, state=u'enabled').order_by(User.login)
 
63
 
 
64
    logging.info("Refreshing active user jails.")
 
65
    for user in active_users:
 
66
        ivle.makeuser.make_jail(user, config)
 
67
 
 
68
    present_jails = set(
 
69
        login for login in os.listdir(config['paths']['jails']['src'])
 
70
        if not (login.startswith('__') and login.endswith('__')))
 
71
 
 
72
    logging.info("Junking extra user jails...")
 
73
    for jail in present_jails - set(user.login for user in active_users):
 
74
        logging.info(' - %s' % jail)
 
75
        junk(config['paths']['jails']['src'], jail)
 
76
 
 
77
    repo_root = config['paths']['svn']['repo_path']
 
78
 
 
79
    logging.info("Creating missing Subversion user repositories.")
 
80
    present_user_repos = set(
 
81
        login for login in os.listdir(os.path.join(repo_root, 'users')))
 
82
 
 
83
    for repo in set(user.login for user in active_users) - present_user_repos:
 
84
        logging.info(' - %s' % repo)
 
85
        ivle.makeuser.make_svn_repo(
 
86
            os.path.join(repo_root, 'users', repo), throw_on_error=True)
 
87
 
 
88
    logging.info("Junking extra Subversion user repositories.")
 
89
    for repo in present_user_repos - set(user.login for user in active_users):
 
90
        logging.info(' - %s' % repo)
 
91
        junk(os.path.join(repo_root, 'users'), repo)
 
92
 
 
93
 
 
94
    logging.info("Creating missing Subversion group repositories.")
 
95
    present_group_repos = set(
 
96
        group for group in os.listdir(os.path.join(repo_root, 'groups')))
 
97
 
 
98
    active_group_identifiers = set("_".join(
 
99
        [group.project_set.offering.subject.short_name,
 
100
         group.project_set.offering.semester.year,
 
101
         group.project_set.offering.semester.url_name,
 
102
         group.name]) for group in store.find(ProjectGroup))
 
103
 
 
104
    for repo in active_group_identifiers - present_group_repos:
 
105
        logging.info(' - %s' % repo)
 
106
        ivle.makeuser.make_svn_repo(
 
107
            os.path.join(repo_root, 'groups', repo), throw_on_error=True)
 
108
 
 
109
    logging.info("Junking extra Subversion user repositories.")
 
110
    for repo in present_group_repos - active_group_identifiers:
 
111
        logging.info(' - %s' % repo)
 
112
        junk(os.path.join(repo_root, 'groups'), repo)
 
113
 
 
114
 
 
115
    logging.info("Rebuild Subversion password file.")
 
116
    for user in store.find(User, state=u'enabled'):
 
117
        ivle.makeuser.make_svn_auth(
 
118
            store, user.login, config, throw_on_error=True)
 
119
    logging.info("Rebuilding Subversion user configuration.")
 
120
    ivle.makeuser.rebuild_svn_config(store, config)
 
121
    logging.info("Rebuilding Subversion group configuration.")
 
122
    ivle.makeuser.rebuild_svn_group_config(store, config)
 
123
 
 
124
 
 
125
if __name__ == '__main__':
 
126
    config = Config()
 
127
    store = get_store(config)
 
128
    refresh_filesystem(config, store)