views.py 2.65 KB
Newer Older
1
import logging
2 3 4
import json
import re
from urlparse import urlparse
5
from collections import namedtuple, defaultdict
6

7

David Baumgold committed
8
from edxmako.shortcuts import render_to_string
9

10
from django.contrib.auth.decorators import login_required
11 12
from django.contrib.auth.models import User
from django.http import HttpResponse, Http404
13
from django.views.decorators.csrf import requires_csrf_token
14

15 16
from licenses.models import CourseSoftware
from licenses.models import get_courses_licenses, get_or_create_license, get_license
17 18


19
log = logging.getLogger("edx.licenses")
20 21


22
License = namedtuple('License', 'software serial')
23 24


25 26 27
def get_licenses_by_course(user, courses):
    licenses = get_courses_licenses(user, courses)
    licenses_by_course = defaultdict(list)
28

29 30 31 32
    # create missing licenses and group by course_id
    for software, license in licenses.iteritems():
        if license is None:
            licenses[software] = get_or_create_license(user, software)
33

34 35 36
        course_id = software.course_id
        serial = license.serial if license else None
        licenses_by_course[course_id].append(License(software, serial))
37

38 39 40 41 42 43
    # render elements
    data_by_course = {}
    for course_id, licenses in licenses_by_course.iteritems():
        context = {'licenses': licenses}
        template = 'licenses/serial_numbers.html'
        data_by_course[course_id] = render_to_string(template, context)
44

45
    return data_by_course
46 47


48
@login_required
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
@requires_csrf_token
def user_software_license(request):
    if request.method != 'POST' or not request.is_ajax():
        raise Http404

    # get the course id from the referer
    url_path = urlparse(request.META.get('HTTP_REFERER', '')).path
    pattern = re.compile('^/courses/(?P<id>[^/]+/[^/]+/[^/]+)/.*/?$')
    match = re.match(pattern, url_path)

    if not match:
        raise Http404
    course_id = match.groupdict().get('id', '')

    user_id = request.session.get('_auth_user_id')
    software_name = request.POST.get('software')
    generate = request.POST.get('generate', False) == 'true'

    try:
        software = CourseSoftware.objects.get(name=software_name,
                                              course_id=course_id)
    except CourseSoftware.DoesNotExist:
        raise Http404

73 74 75 76
    try:
        user = User.objects.get(id=user_id)
    except User.DoesNotExist:
        raise Http404
77 78

    if generate:
79
        software_license = get_or_create_license(user, software)
80
    else:
81
        software_license = get_license(user, software)
82

83 84
    if software_license:
        response = {'serial': software_license.serial}
85 86 87 88
    else:
        response = {'error': 'No serial number found'}

    return HttpResponse(json.dumps(response), mimetype='application/json')