From 5d8d6d66ac36fe8d4d64fa9bfaab91ffb66512b2 Mon Sep 17 00:00:00 2001 From: robban64 <carl@schonfelder.se> Date: Wed, 19 May 2021 17:59:27 +0200 Subject: [PATCH] fix: question score use first_api instead of first_extended and have it's own file --- server/app/apis/__init__.py | 4 +- server/app/apis/answers.py | 42 -------------------- server/app/apis/scores.py | 56 +++++++++++++++++++++++++++ server/app/database/controller/get.py | 2 +- 4 files changed, 60 insertions(+), 44 deletions(-) create mode 100644 server/app/apis/scores.py diff --git a/server/app/apis/__init__.py b/server/app/apis/__init__.py index 3cb92488..ad71728a 100644 --- a/server/app/apis/__init__.py +++ b/server/app/apis/__init__.py @@ -100,6 +100,7 @@ from .components import api as component_ns from .media import api as media_ns from .misc import api as misc_ns from .questions import api as question_ns +from .scores import api as score_ns from .slides import api as slide_ns from .teams import api as team_ns from .users import api as user_ns @@ -114,8 +115,9 @@ flask_api.add_namespace(slide_ns, path="/api/competitions/<competition_id>/slide flask_api.add_namespace( alternative_ns, path="/api/competitions/<competition_id>/slides/<slide_id>/questions/<question_id>/alternatives" ) -flask_api.add_namespace(answer_ns, path="/api/competitions/<competition_id>/teams/<team_id>/answers") flask_api.add_namespace(team_ns, path="/api/competitions/<competition_id>/teams") flask_api.add_namespace(code_ns, path="/api/competitions/<competition_id>/codes") flask_api.add_namespace(question_ns, path="/api/competitions/<competition_id>") flask_api.add_namespace(component_ns, path="/api/competitions/<competition_id>/slides/<slide_id>/components") +flask_api.add_namespace(answer_ns, path="/api/competitions/<competition_id>/teams/<team_id>/answers") +flask_api.add_namespace(score_ns, path="/api/competitions/<competition_id>/teams/<team_id>/answers/question_scores") diff --git a/server/app/apis/answers.py b/server/app/apis/answers.py index 853b97a0..190f7491 100644 --- a/server/app/apis/answers.py +++ b/server/app/apis/answers.py @@ -23,23 +23,6 @@ answer_parser_add.add_argument("answer", type=str, required=True, location="json answer_parser_edit = reqparse.RequestParser() answer_parser_edit.add_argument("answer", type=str, default=sentinel, location="json") -score_parser_add = reqparse.RequestParser() -score_parser_add.add_argument("score", type=int, required=False, location="json") - -score_parser_edit = reqparse.RequestParser() -score_parser_edit.add_argument("score", type=int, default=sentinel, location="json") - - -@api.route("/question_scores") -@api.param("competition_id, team_id") -class QuestionScoreList(Resource): - @protect_route(allowed_roles=["*"], allowed_views=["*"]) - def get(self, competition_id, team_id): - """ Gets all question answers that the specified team has given. """ - - items = dbc.get.question_score_list(competition_id, team_id) - return list_response(score_list_schema.dump(items)) - @api.route("/question_alternatives") @api.param("competition_id, team_id") @@ -52,31 +35,6 @@ class QuestionAlternativeList(Resource): return list_response(list_schema.dump(items)) -@api.route("/question_scores/<question_id>") -@api.param("competition_id, team_id, question_id") -class QuestionScores(Resource): - @protect_route(allowed_roles=["*"], allowed_views=["*"]) - def get(self, competition_id, team_id, question_id): - """ Gets the specified question answer. """ - - item = dbc.get.question_score(competition_id, team_id, question_id) - return item_response(score_schema.dump(item)) - - @protect_route(allowed_roles=["*"], allowed_views=["*"]) - def put(self, competition_id, team_id, question_id): - """ Add or edit specified quesiton_answer. """ - - item = dbc.get.question_score(competition_id, team_id, question_id, required=False) - if item is None: - args = score_parser_add.parse_args(strict=True) - item = dbc.add.question_score(args.get("score"), question_id, team_id) - else: - args = score_parser_edit.parse_args(strict=True) - item = dbc.edit.default(item, **args) - - return item_response(score_schema.dump(item)) - - @api.route("/question_alternatives/<question_alternative_id>") @api.param("competition_id, team_id, question_alternative_id") class QuestionAlternativeAnswers(Resource): diff --git a/server/app/apis/scores.py b/server/app/apis/scores.py new file mode 100644 index 00000000..2d303e1c --- /dev/null +++ b/server/app/apis/scores.py @@ -0,0 +1,56 @@ +""" +All API calls concerning question score. +Default route: /api/competitions/<competition_id>/teams/<team_id>/answers/quesiton_scores +""" + +import app.database.controller as dbc +from app.apis import item_response, list_response, protect_route +from app.core.dto import QuestionScoreDTO +from app.core.parsers import sentinel +from flask_restx import Resource, reqparse + +api = QuestionScoreDTO.api +schema = QuestionScoreDTO.schema +list_schema = QuestionScoreDTO.list_schema + +score_parser_add = reqparse.RequestParser() +score_parser_add.add_argument("score", type=int, required=False, location="json") + +score_parser_edit = reqparse.RequestParser() +score_parser_edit.add_argument("score", type=int, default=sentinel, location="json") + + +@api.route("/") +@api.param("competition_id, team_id") +class QuestionScoreList(Resource): + @protect_route(allowed_roles=["*"], allowed_views=["*"]) + def get(self, competition_id, team_id): + """ Gets all question answers that the specified team has given. """ + + items = dbc.get.question_score_list(competition_id, team_id) + return list_response(list_schema.dump(items)) + + +@api.route("/<question_id>") +@api.param("competition_id, team_id, question_id") +class QuestionScores(Resource): + @protect_route(allowed_roles=["*"], allowed_views=["*"]) + def get(self, competition_id, team_id, question_id): + """ Gets the specified question answer. """ + + item = dbc.get.question_score(competition_id, team_id, question_id) + return item_response(schema.dump(item)) + + @protect_route(allowed_roles=["*"], allowed_views=["*"]) + def put(self, competition_id, team_id, question_id): + """ Add or edit specified quesiton_answer. """ + + item = dbc.get.question_score(competition_id, team_id, question_id, required=False) + if item is None: + args = score_parser_add.parse_args(strict=True) + item = dbc.add.question_score(args.get("score"), question_id, team_id) + else: + args = score_parser_edit.parse_args(strict=True) + item = dbc.edit.default(item, **args) + + return item_response(schema.dump(item)) diff --git a/server/app/database/controller/get.py b/server/app/database/controller/get.py index b6eb429d..5c075b34 100644 --- a/server/app/database/controller/get.py +++ b/server/app/database/controller/get.py @@ -222,7 +222,7 @@ def question_score(competition_id, team_id, question_id, required=True): QuestionScore.query.join(Team, join_team) .join(Competition, join_competition) .filter(filters) - .first_extended(required) + .first_api(required) ) -- GitLab