from django.utils import simplejson
from django.conf import settings
from django.http import Http404, HttpResponseForbidden
+from django.views.decorators.cache import never_cache
from django.views.decorators.csrf import csrf_exempt
from .models import Submission, DEBUG_KEY, exercises
return globals()['form_' + WTEM_CONTEST_STAGE](request, key)
def form_before(request, key):
- return render(request, 'wtem/main_before.html')
+ try:
+ submission = Submission.objects.get(key = key)
+ except:
+ return render(request, 'wtem/key_not_found_before.html')
+ else:
+ return render(request, 'wtem/main_before.html')
def form_after(request, key):
return render(request, 'wtem/main_after.html')
+@never_cache
@csrf_exempt
def form_during(request, key):
if WTEM_CONTEST_STAGE != 'during':
- if request.META['REMOTE_ADDR'] != getattr(settings, 'WTEM_CONTEST_IP_ALLOW', 'xxx'):
+ if request.META['REMOTE_ADDR'] not in getattr(settings, 'WTEM_CONTEST_IP_ALLOW', []):
return HttpResponseForbidden('Not allowed')
try:
if settings.DEBUG and key == DEBUG_KEY:
submission = Submission.create(first_name = 'Debug', last_name = 'Debug', email = 'debug@debug.com', key = DEBUG_KEY)
else:
- raise Http404
+ return render(request, 'wtem/key_not_found.html')
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