ska-referee-test/ref-test/quiz/views.py

90 lines
3.0 KiB
Python
Raw Normal View History

2021-11-28 18:17:50 +00:00
from flask import Blueprint, render_template, request, redirect, jsonify, session, abort
from flask.helpers import url_for
2021-11-25 23:12:20 +00:00
from datetime import datetime
from uuid import uuid4
2021-11-28 18:17:50 +00:00
import os
from json import loads
2021-11-25 23:12:20 +00:00
2021-11-28 18:17:50 +00:00
from main import app, db
from common.security import encrypt
2021-11-28 18:17:50 +00:00
from common.data_tools import generate_questions
views = Blueprint(
'quiz_views',
__name__,
static_url_path='',
template_folder='templates',
static_folder='static'
)
@views.route('/')
@views.route('/home/')
def home():
return render_template('/quiz/index.html')
@views.route('/start/', methods = ['GET', 'POST'])
def start():
from .forms import StartQuiz
form = StartQuiz()
2021-11-25 23:12:20 +00:00
if request.method == 'GET':
return render_template('/quiz/start-quiz.html', form=form)
if request.method == 'POST':
if form.validate_on_submit():
name = {
'first_name': request.form.get('first_name'),
'surname': request.form.get('surname')
}
email = request.form.get('email')
club = request.form.get('club')
test_code = request.form.get('test_code').replace('', '')
user_code = request.form.get('user_code')
user_code = None if user_code == '' else user_code
if not db.tests.find_one({'test_code': test_code}):
return jsonify({'error': 'The exam code you entered is invalid.'}), 400
entry = {
2021-11-25 23:12:20 +00:00
'_id': uuid4().hex,
'name': encrypt(name),
'email': encrypt(email),
'club': encrypt(club),
2021-11-28 18:17:50 +00:00
'test_code': test_code,
2021-11-25 23:12:20 +00:00
'user_code': user_code,
'start_time': datetime.utcnow(),
'status': 'started'
}
if db.entries.insert(entry):
2021-11-28 18:17:50 +00:00
session['_id'] = entry['_id'] # Change this to return _id via JSON so client can access. Client will not be able to decrypt session cookie.
return jsonify({
'success': 'Success! An exam entry was started.',
'_id': entry['_id']
}), 200
2021-11-25 23:12:20 +00:00
else:
errors = [*form.errors]
return jsonify({ 'error': errors}), 400
2021-11-28 18:17:50 +00:00
@views.route('/api/questions/<_id>')
def fetch_questions(_id):
entry = db.entries.find_one({'_id': _id})
if not entry:
return abort(404)
test_code = entry['test_code']
# user_code = entry['user_code'] Implement functionality for adjustments
test = db.tests.find_one({'test_code' : test_code})
dataset = test['dataset']
dataset_path = os.path.join(app.config['DATA_FILE_DIRECTORY'], dataset)
with open(dataset_path, 'r') as data_file:
data = loads(data_file.read())
questions = generate_questions(data)
time_limit = test['time_limit']
return jsonify({
'time_limit': time_limit,
'questions': questions
})
@views.route('/privacy/')
def privacy():
2021-11-25 23:12:20 +00:00
return render_template('/quiz/privacy.html')