X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/06a981042354beffa32620e52f2c7b1971549c17..b99b619fb5c4504bc8a21e5c9f92a72d84638836:/wtem/views.py diff --git a/wtem/views.py b/wtem/views.py index bfce3c9..278ddc3 100644 --- a/wtem/views.py +++ b/wtem/views.py @@ -3,17 +3,16 @@ import os from django.shortcuts import render from django.utils import simplejson from django.conf import settings -from django.http import Http404 +from django.http import Http404, HttpResponseForbidden +from django.views.decorators.csrf import csrf_exempt -from .models import Submission, DEBUG_KEY +from .models import Submission, DEBUG_KEY, exercises from .forms import WTEMForm WTEM_CONTEST_STAGE = getattr(settings, 'WTEM_CONTEST_STAGE', 'before') -def main(request): - pass - +@csrf_exempt def form(request, key): return globals()['form_' + WTEM_CONTEST_STAGE](request, key) @@ -23,11 +22,12 @@ def form_before(request, key): def form_after(request, key): return render(request, 'wtem/main_after.html') +@csrf_exempt def form_during(request, key): if WTEM_CONTEST_STAGE != 'during': if request.META['REMOTE_ADDR'] != getattr(settings, 'WTEM_CONTEST_IP_ALLOW', 'xxx'): - raise Http404 + return HttpResponseForbidden('Not allowed') try: submission = Submission.objects.get(key = key) @@ -36,18 +36,12 @@ def form_during(request, key): submission = Submission.create(first_name = 'Debug', last_name = 'Debug', email = 'debug@debug.com', key = DEBUG_KEY) else: raise Http404 - - ## @@ move this out of the view - f = file(os.path.dirname(__file__) + '/fixtures/exercises.json') - exercises = simplejson.loads(f.read()) - f.close() - if request.method == 'GET': - return render(request, 'wtem/main.html', dict(exercises = exercises)) + return render(request, 'wtem/main.html', dict(exercises = exercises, end_time = submission.end_time)) elif request.method == 'POST': form = WTEMForm(request.POST, request.FILES, instance = submission) if form.is_valid(): form.save() - return render(request, 'wtem/thanks.html') + return render(request, 'wtem/thanks.html', dict(end_time = submission.end_time)) else: raise Exception