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

« back to all changes in this revision

Viewing changes to bin/ivle-enrolallusers

  • Committer: me at id
  • Date: 2009-01-15 00:37:10 UTC
  • mto: This revision was merged to the branch mainline in revision 1090.
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:branches%2Fstorm:1141
ivle.database.User: Add an authenticate() method, and a hash_password()
     staticmethod to replace the auth functions in ivle.db.

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