34
34
from ivle.config import Config
35
35
from ivle.database import get_store, ProjectGroup, User
36
36
import ivle.makeuser
40
format='%(asctime)s %(levelname)s %(message)s',
44
JUNK_DIRECTORY_SUFFIX = (
37
# Python 2.5's shutil.rmtree follows symlinks!
38
from ivle.util import safe_rmtree
40
junk_directory_suffix = (
45
41
'-removed-%s' % datetime.datetime.now().strftime('%Y%m%d-%H%M%S'))
48
43
def get_junk_dir(path):
49
return os.path.normpath(path) + JUNK_DIRECTORY_SUFFIX
44
return os.path.normpath(path) + junk_directory_suffix
52
46
def junk(parent, name):
53
47
"""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))
48
os.makedirs(get_junk_dir(parent))
57
50
os.path.join(parent, name),
58
51
os.path.join(get_junk_dir(parent), name))
61
def refresh_filesystem(config, store):
62
active_users = store.find(User, state=u'enabled').order_by(User.login)
64
logging.info("Refreshing active user jails.")
65
for user in active_users:
66
ivle.makeuser.make_jail(user, config)
69
login for login in os.listdir(config['paths']['jails']['src'])
70
if not (login.startswith('__') and login.endswith('__')))
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)
77
repo_root = config['paths']['svn']['repo_path']
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')))
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)
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)
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')))
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.semester,
102
group.name]) for group in store.find(ProjectGroup))
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)
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)
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)
125
if __name__ == '__main__':
127
store = get_store(config)
128
refresh_filesystem(config, store)
55
store = get_store(config)
57
active_users = store.find(User, state=u'enabled').order_by(User.login)
59
print >>sys.stderr, "Refreshing active user jails..."
60
for user in active_users:
61
ivle.makeuser.make_jail(user, config)
64
login for login in os.listdir(config['paths']['jails']['src'])
65
if not (login.startswith('__') and login.endswith('__')))
67
print >>sys.stderr, "Junking extra user jails..."
68
for jail in present_jails - set(user.login for user in active_users):
70
junk(config['paths']['jails']['src'], jail)
72
repo_root = config['paths']['svn']['repo_path']
74
print >>sys.stderr, "Creating missing Subversion user repositories..."
75
present_user_repos= set(
76
login for login in os.listdir(os.path.join(repo_root, 'users')))
78
for repo in set(user.login for user in active_users) - present_user_repos:
80
ivle.makeuser.make_svn_repo(
81
os.path.join(repo_root, 'users', repo), throw_on_error=True)
83
print >>sys.stderr, "Junking extra Subversion user repositories..."
84
for repo in present_user_repos - set(user.login for user in active_users):
86
junk(os.path.join(repo_root, 'users'), repo)
89
print >>sys.stderr, "Creating missing Subversion group repositories..."
90
present_group_repos = set(
91
group for group in os.listdir(os.path.join(repo_root, 'groups')))
93
active_group_identifiers = set("_".join(
94
[group.project_set.offering.subject.short_name,
95
group.project_set.offering.semester.year,
96
group.project_set.offering.semester.semester,
97
group.name]) for group in store.find(ProjectGroup))
99
for repo in active_group_identifiers - present_group_repos:
101
ivle.makeuser.make_svn_repo(
102
os.path.join(repo_root, 'groups', repo), throw_on_error=True)
104
print >>sys.stderr, "Junking extra Subversion user repositories..."
105
for repo in present_group_repos - active_group_identifiers:
107
junk(os.path.join(repo_root, 'groups'), repo)
110
print >>sys.stderr, "Rebuilding Subversion user configuration..."
111
ivle.makeuser.rebuild_svn_config(store, config)
112
print >>sys.stderr, "Rebuilding Subversion group configuration..."
113
ivle.makeuser.rebuild_svn_group_config(store, config)