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

« back to all changes in this revision

Viewing changes to bin/ivle-enrolallusers

  • Committer: William Grant
  • Date: 2009-12-02 05:13:18 UTC
  • mfrom: (1328 trunk)
  • mto: This revision was merged to the branch mainline in revision 1353.
  • Revision ID: grantw@unimelb.edu.au-20091202051318-delr1lu69zri05gz
MergeĀ fromĀ trunk.

Show diffs side-by-side

added added

removed removed

Lines of Context:
34
34
import optparse
35
35
import logging
36
36
 
37
 
import ivle.db
 
37
import ivle.config
 
38
import ivle.database
38
39
import ivle.pulldown_subj
39
40
 
40
41
p = optparse.OptionParser()
54
55
    print >> sys.stderr, "%s must be run as root" % sys.argv[0]
55
56
    sys.exit(1)
56
57
 
57
 
try:
58
 
    db = ivle.db.DB()
59
 
    if options.user is None:
60
 
        users = db.get_users()
61
 
    else:
62
 
        users = [db.get_user(options.user)]
63
 
    def repack(user):
64
 
        return (user.login, user.unixid)
65
 
    uids = dict(map(repack,users))
66
 
except Exception, message:
67
 
    logging.error(str(message))
68
 
    sys.exit(1)
 
58
config = ivle.config.Config()
 
59
store = ivle.database.get_store(config)
 
60
 
 
61
if options.user is None:
 
62
    users = store.find(ivle.database.User).order_by(ivle.database.User.login)
 
63
else:
 
64
    users = [ivle.database.User.get_by_login(store, options.user)]
69
65
 
70
66
if options.user is None:
71
67
    logging.info("enrolment started")
76
72
    logging.error("Year must be numeric")
77
73
    sys.exit(1)
78
74
 
79
 
users.sort(key=lambda user: user.login)
 
75
options.year = None if options.year is None else unicode(options.year)
 
76
 
80
77
for user in users:
81
78
    try:
82
79
        # Get all subjects this user is enrolled in, and add them to the DB if
83
80
        # they match one of our local subject codes
84
 
        res = ivle.pulldown_subj.enrol_user(user.login, options.year)
 
81
        res = ivle.pulldown_subj.enrol_user(config, store, user, options.year)
85
82
        logging.info("Enrolled user %s in %d subject%s." % (user.login, res,
86
83
                        '' if res == 1 else 's'))
87
84
    except Exception, message:
88
85
        logging.warning(str(message))
89
86
        continue
90
87
    
 
88
store.commit()
91
89
logging.info("enrolment completed successfully")