168 lines
8.7 KiB
Python
168 lines
8.7 KiB
Python
"""
|
|
Project: PARTS Website
|
|
Author: Edward Middleton-Smith
|
|
Precision And Research Technology Systems Limited
|
|
|
|
Technology: App Routing
|
|
Feature: Dog - Assessment Routes
|
|
|
|
Description:
|
|
Dog Assessments Page Controller.
|
|
"""
|
|
|
|
# IMPORTS
|
|
# internal
|
|
from business_objects.api import API
|
|
from business_objects.dog.command import Command
|
|
from business_objects.dog.assessment import Assessment
|
|
from business_objects.dog.assessment_command_modality_link import Assessment_Command_Modality_Link
|
|
from business_objects.dog.assessment_response import Assessment_Response
|
|
from business_objects.dog.distraction import Distraction
|
|
from datastores.datastore_dog import DataStore_Dog
|
|
from forms.dog.assessment import Filters_Assessment
|
|
from helpers.helper_app import Helper_App
|
|
from models.model_view_dog_assessment import Model_View_Dog_Assessment
|
|
from models.model_view_home import Model_View_Home
|
|
import lib.argument_validation as av
|
|
# external
|
|
from flask import Flask, render_template, jsonify, request, render_template_string, send_from_directory, redirect, url_for, session, Blueprint, current_app, flash
|
|
from flask_mail import Mail, Message
|
|
from extensions import db, oauth, mail
|
|
from urllib.parse import quote_plus, urlencode
|
|
from authlib.integrations.flask_client import OAuth
|
|
from authlib.integrations.base_client import OAuthError
|
|
from urllib.parse import quote, urlparse, parse_qs
|
|
import json
|
|
import base64
|
|
import hmac
|
|
import hashlib
|
|
import datetime
|
|
from altcha import ChallengeOptions, create_challenge, verify_solution
|
|
|
|
|
|
routes_dog_assessment = Blueprint('routes_dog_assessment', __name__)
|
|
|
|
|
|
@routes_dog_assessment.route(Model_View_Dog_Assessment.HASH_PAGE_DOG_ASSESSMENTS, methods=['GET'])
|
|
def assessments():
|
|
Helper_App.console_log('assessments')
|
|
Helper_App.console_log(f'request_args: {request.args}')
|
|
try:
|
|
form_filters = Filters_Assessment.from_json(request.args)
|
|
except Exception as e:
|
|
Helper_App.console_log(f'Error: {e}')
|
|
form_filters = Filters_Assessment()
|
|
Helper_App.console_log(f'form_filters={form_filters}')
|
|
model = Model_View_Dog_Assessment(form_filters_old = form_filters)
|
|
if not model.is_user_logged_in:
|
|
return redirect(url_for('routes_core_home.home'))
|
|
Helper_App.console_log(f'form_filters={form_filters}')
|
|
return render_template('pages/dog/_assessments.html', model = model)
|
|
|
|
@routes_dog_assessment.route(Model_View_Dog_Assessment.HASH_SAVE_DOG_ASSESSMENT_DISTRACTION_AND_RESPONSE, methods=['POST'])
|
|
def save_assessment():
|
|
Helper_App.console_log('save_assessment')
|
|
data = Helper_App.get_request_data(request)
|
|
try:
|
|
token_received = data.get(Model_View_Dog_Assessment.FLAG_CSRF_TOKEN)
|
|
token_expected = session.get(Model_View_Dog_Assessment.FLAG_CSRF_TOKEN) # 'csrf_token'
|
|
if (not token_received) or not hmac.compare_digest(token_received, token_expected):
|
|
Helper_App.console_log(f'token_received: {token_received}\ntoken_expected: {token_expected}')
|
|
Helper_App.console_log(f'session: {session}\nkey: {Model_View_Dog_Assessment.FLAG_CSRF_TOKEN}')
|
|
return jsonify({
|
|
Model_View_Dog_Assessment.FLAG_STATUS: Model_View_Dog_Assessment.FLAG_FAILURE,
|
|
Model_View_Dog_Assessment.FLAG_MESSAGE: f'Invalid token received.'
|
|
})
|
|
form_filters = Filters_Assessment.from_json(data[Model_View_Dog_Assessment.FLAG_FORM_FILTERS])
|
|
"""
|
|
if not form_filters.validate_on_submit():
|
|
return jsonify({
|
|
Model_View_Dog_Assessment.FLAG_STATUS: Model_View_Dog_Assessment.FLAG_FAILURE,
|
|
Model_View_Dog_Assessment.FLAG_MESSAGE: f'Filters form invalid.\n{form_filters.errors}'
|
|
})
|
|
"""
|
|
model_permissions = Model_View_Dog_Assessment(form_filters_old=form_filters)
|
|
Helper_App.console_log('made model')
|
|
if not model_permissions.is_user_logged_in:
|
|
raise Exception('User not logged in')
|
|
|
|
assessments = data[Model_View_Dog_Assessment.FLAG_ASSESSMENT]
|
|
if len(assessments) == 0:
|
|
return jsonify({
|
|
Model_View_Dog_Assessment.FLAG_STATUS: Model_View_Dog_Assessment.FLAG_FAILURE,
|
|
Model_View_Dog_Assessment.FLAG_MESSAGE: f'No assessments.'
|
|
})
|
|
objs_assessment = []
|
|
objs_distraction = []
|
|
objs_assessment_command_modality_link = []
|
|
objs_assessment_responses = []
|
|
for assessment in assessments:
|
|
objs_assessment.append(Assessment.from_json(assessment))
|
|
objs_distraction.extend([Distraction.from_json(link_json) for link_json in assessment.get(Distraction.FLAG_DISTRACTION, [])])
|
|
for link_json in assessment.get(Assessment_Command_Modality_Link.FLAG_ASSESSMENT_COMMAND_MODALITY_LINK, []):
|
|
objs_assessment_command_modality_link.append(Assessment_Command_Modality_Link.from_json(link_json))
|
|
objs_assessment_responses.extend([Assessment_Response.from_json(response_json) for response_json in link_json.get(Assessment_Response.FLAG_ASSESSMENT_RESPONSE, [])])
|
|
"""
|
|
errors = []
|
|
Helper_App.console_log(f'objs_assessment={objs_assessment}')
|
|
if len(objs_assessment) > 0:
|
|
errors.extend(DataStore_Dog.save_assessments(data.get('comment', 'No comment'), objs_assessment))
|
|
Helper_App.console_log(f'objs_distraction={objs_distraction}')
|
|
if len(objs_distraction) > 0:
|
|
errors.extend(DataStore_Dog.save_distractions(data.get('comment', 'No comment'), objs_distraction))
|
|
Helper_App.console_log(f'objs_assessment_command_modality_link={objs_assessment_command_modality_link}')
|
|
if len(objs_assessment_command_modality_link) > 0:
|
|
errors.extend(DataStore_Dog.save_assessment_command_modality_links(data.get('comment', 'No comment'), objs_assessment_command_modality_link))
|
|
Helper_App.console_log(f'objs_assessment_responses={objs_assessment_responses}')
|
|
if len(objs_assessment_responses) > 0:
|
|
errors.extend(DataStore_Dog.save_assessment_responses(data.get('comment', 'No comment'), objs_assessment_responses))
|
|
"""
|
|
errors = DataStore_Dog.save_assessments_distactions_and_responses(
|
|
comment = data.get('comment', 'No comment')
|
|
, assessments = objs_assessment
|
|
, distractions = objs_distraction
|
|
, assessment_command_modality_links = objs_assessment_command_modality_link
|
|
, assessment_responses = objs_assessment_responses
|
|
)
|
|
# model_return = Model_View_Dog_Assessment(form_filters_old=form_filters)
|
|
|
|
if (len(errors) > 0):
|
|
return jsonify({
|
|
Model_View_Dog_Assessment.FLAG_STATUS: Model_View_Dog_Assessment.FLAG_FAILURE,
|
|
Model_View_Dog_Assessment.FLAG_MESSAGE: f'Error saving assessments.\n{model_permissions.convert_list_objects_to_json(errors)}'
|
|
})
|
|
return jsonify({
|
|
Model_View_Dog_Assessment.FLAG_STATUS: Model_View_Dog_Assessment.FLAG_SUCCESS,
|
|
Model_View_Dog_Assessment.FLAG_DATA: None # Model_View_Dog_Assessment.convert_list_objects_to_json(model_permissions.assessments)
|
|
})
|
|
except Exception as e:
|
|
return jsonify({
|
|
Model_View_Dog_Assessment.FLAG_STATUS: Model_View_Dog_Assessment.FLAG_FAILURE,
|
|
Model_View_Dog_Assessment.FLAG_MESSAGE: f'Bad data received by controller.\n{e}'
|
|
})
|
|
|
|
@routes_dog_assessment.route(Model_View_Dog_Assessment.HASH_PAGE_DOG_ASSESSMENT, methods=['GET'])
|
|
def assessment():
|
|
Helper_App.console_log('assessment:')
|
|
Helper_App.console_log(f'request_args: {request.args}')
|
|
try:
|
|
form_filters = Filters_Assessment.from_json(request.args)
|
|
except Exception as e:
|
|
Helper_App.console_log(f'Error: {e}')
|
|
form_filters = Filters_Assessment()
|
|
Helper_App.console_log(f'form_filters={form_filters}')
|
|
temp_id_assessment = request.args.get(Model_View_Dog_Assessment.ATTR_ID_ASSESSMENT, -1)
|
|
id_assessment = None if (temp_id_assessment is None or temp_id_assessment == '') else int(temp_id_assessment)
|
|
model = Model_View_Dog_Assessment(form_filters_old = form_filters, id_assessment = id_assessment, hash_page_current = Model_View_Dog_Assessment.HASH_PAGE_DOG_ASSESSMENT)
|
|
model._title = 'Assessment'
|
|
if model.assessments is None or len(model.assessments) == 0:
|
|
if id_assessment is not None and id_assessment > 0:
|
|
return assessments()
|
|
else:
|
|
model.assessments = [Assessment()]
|
|
if not model.is_user_logged_in:
|
|
return redirect(url_for('routes_core_home.home'))
|
|
session[Model_View_Dog_Assessment.FLAG_CSRF_TOKEN] = model.form_filters.csrf_token.current_token #.hidden_tag()
|
|
Helper_App.console_log(f'form_filters={form_filters}')
|
|
return render_template('pages/dog/_assessment.html', model = model)
|