Commit f1ad393f by Piotr Mitros

Course admins can now access student grades by going to profile/[userid]

--HG--
branch : visible-grades
parent c7c71c94
...@@ -153,7 +153,7 @@ def user_groups(user): ...@@ -153,7 +153,7 @@ def user_groups(user):
cache_expiration = 60 * 60 # one hour cache_expiration = 60 * 60 # one hour
# Kill caching on dev machines -- we switch groups a lot # Kill caching on dev machines -- we switch groups a lot
if "dev" not in setting.DEFAULT_GROUPS: if "dev" not in settings.DEFAULT_GROUPS:
group_names = cache.get(fasthash(key)) group_names = cache.get(fasthash(key))
else: else:
group_names = None group_names = None
......
...@@ -34,7 +34,7 @@ etree.set_default_parser(etree.XMLParser(dtd_validation=False, load_dtd=False, ...@@ -34,7 +34,7 @@ etree.set_default_parser(etree.XMLParser(dtd_validation=False, load_dtd=False,
template_imports={'urllib':urllib} template_imports={'urllib':urllib}
def get_grade(request, problem, cache): def get_grade(user, problem, cache):
## HACK: assumes max score is fixed per problem ## HACK: assumes max score is fixed per problem
id = problem.get('id') id = problem.get('id')
correct = 0 correct = 0
...@@ -43,7 +43,7 @@ def get_grade(request, problem, cache): ...@@ -43,7 +43,7 @@ def get_grade(request, problem, cache):
if id not in cache: if id not in cache:
module = StudentModule(module_type = 'problem', # TODO: Move into StudentModule.__init__? module = StudentModule(module_type = 'problem', # TODO: Move into StudentModule.__init__?
module_id = id, module_id = id,
student = request.user, student = user,
state = None, state = None,
grade = 0, grade = 0,
max_grade = None, max_grade = None,
...@@ -76,7 +76,8 @@ def profile(request, student_id = None): ...@@ -76,7 +76,8 @@ def profile(request, student_id = None):
if student_id == None: if student_id == None:
student = request.user student = request.user
else: else:
if 'course_admin' not in content.user_groups(request.user): print content_parser.user_groups(request.user)
if 'course_admin' not in content_parser.user_groups(request.user):
raise Http404 raise Http404
student = User.objects.get( id = int(student_id)) student = User.objects.get( id = int(student_id))
...@@ -104,7 +105,7 @@ def profile(request, student_id = None): ...@@ -104,7 +105,7 @@ def profile(request, student_id = None):
scores=[] scores=[]
if len(problems)>0: if len(problems)>0:
for p in problems: for p in problems:
(correct,total) = get_grade(request, p, response_by_id) (correct,total) = get_grade(student, p, response_by_id)
# id = p.get('id') # id = p.get('id')
# correct = 0 # correct = 0
# if id in response_by_id: # if id in response_by_id:
......
...@@ -106,5 +106,5 @@ def add_user_to_group(group, user): ...@@ -106,5 +106,5 @@ def add_user_to_group(group, user):
def remove_user_from_group(group, user): def remove_user_from_group(group, user):
utg = UserTestGroup.objects.get(name = group) utg = UserTestGroup.objects.get(name = group)
utg.users.add(User.objects.get(username = user)) utg.users.remove(User.objects.get(username = user))
utg.save() utg.save()
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment