Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
teknikattan-scoring-system
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
tddd96-grupp1
teknikattan-scoring-system
Commits
bfd7645f
Commit
bfd7645f
authored
3 years ago
by
Victor Löfgren
Browse files
Options
Downloads
Patches
Plain Diff
Add team api
parent
e4c0babf
No related branches found
No related tags found
1 merge request
!161
Resolve "replace-restx-with-smorest"
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
server/app/apis/__init__.py
+12
-5
12 additions, 5 deletions
server/app/apis/__init__.py
server/app/apis/teams.py
+49
-43
49 additions, 43 deletions
server/app/apis/teams.py
with
61 additions
and
48 deletions
server/app/apis/__init__.py
+
12
−
5
View file @
bfd7645f
...
@@ -114,14 +114,19 @@ def protect_route(allowed_roles=None, allowed_views=None):
...
@@ -114,14 +114,19 @@ def protect_route(allowed_roles=None, allowed_views=None):
# from .users import api as user_ns
# from .users import api as user_ns
# flask_api = Api()
# flask_api = Api()
# flask_api.add_namespace(slide_ns, path="/api/competitions/<competition_id>/slides")
# flask_api.add_namespace(slide_ns, path="/api/competitions/<competition_id>/slides")
# flask_api.add_namespace(
# flask_api.add_namespace(
# alternative_ns, path="/api/competitions/<competition_id>/slides/<slide_id>/questions/<question_id>/alternatives"
# alternative_ns, path="/api/competitions/<competition_id>/slides/<slide_id>/questions/<question_id>/alternatives"
# )
# )
# 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(code_ns, path="/api/competitions/<competition_id>/codes")
# flask_api.add_namespace(component_ns, path="/api/competitions/<competition_id>/slides/<slide_id>/components")
# 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(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")
# flask_api.add_namespace(score_ns, path="/api/competitions/<competition_id>/teams/<team_id>/answers/question_scores")
from
flask_smorest
import
Api
from
flask_smorest
import
Api
...
@@ -132,17 +137,19 @@ flask_api = Api()
...
@@ -132,17 +137,19 @@ flask_api = Api()
def
init_api
():
def
init_api
():
from
.auth
import
blp
as
auth_blp
from
.auth
import
blp
as
auth_blp
from
.competitions
import
blp
as
competition
s
_blp
from
.competitions
import
blp
as
competition_blp
from
.media
import
blp
as
media_blp
from
.media
import
blp
as
media_blp
from
.misc
import
blp
as
misc_blp
from
.misc
import
blp
as
misc_blp
from
.questions
import
blp
as
question
s
_blp
from
.questions
import
blp
as
question_blp
from
.slides
import
blp
as
slide_blp
from
.slides
import
blp
as
slide_blp
from
.teams
import
blp
as
team_blp
from
.users
import
blp
as
user_blp
from
.users
import
blp
as
user_blp
flask_api
.
register_blueprint
(
user_blp
)
flask_api
.
register_blueprint
(
user_blp
)
flask_api
.
register_blueprint
(
auth_blp
)
flask_api
.
register_blueprint
(
auth_blp
)
flask_api
.
register_blueprint
(
competition
s
_blp
)
flask_api
.
register_blueprint
(
competition_blp
)
flask_api
.
register_blueprint
(
misc_blp
)
flask_api
.
register_blueprint
(
misc_blp
)
flask_api
.
register_blueprint
(
media_blp
)
flask_api
.
register_blueprint
(
media_blp
)
flask_api
.
register_blueprint
(
slide_blp
)
flask_api
.
register_blueprint
(
slide_blp
)
flask_api
.
register_blueprint
(
questions_blp
)
flask_api
.
register_blueprint
(
question_blp
)
flask_api
.
register_blueprint
(
team_blp
)
This diff is collapsed.
Click to expand it.
server/app/apis/teams.py
+
49
−
43
View file @
bfd7645f
...
@@ -3,70 +3,76 @@ All API calls concerning question alternatives.
...
@@ -3,70 +3,76 @@ All API calls concerning question alternatives.
Default route: /api/competitions/<competition_id>/teams
Default route: /api/competitions/<competition_id>/teams
"""
"""
import
app.core.http_codes
as
codes
import
app.database.controller
as
dbc
import
app.database.controller
as
dbc
from
app.apis
import
item_response
,
list_response
,
protect_route
from
app.apis
import
protect_route
from
app.core.dto
import
TeamDTO
from
app.core
import
ma
from
app.core.parsers
import
sentinel
from
app.core.schemas
import
BaseSchema
,
TeamSchema
from
flask_restx
import
Resource
,
reqparse
from
app.database
import
models
from
flask.views
import
MethodView
from
flask_smorest
import
Blueprint
api
=
TeamDTO
.
api
from
.
import
http_codes
schema
=
TeamDTO
.
schema
list_schema
=
TeamDTO
.
list_schema
team_parser_add
=
reqparse
.
RequestParser
()
blp
=
Blueprint
(
team_parser_add
.
add_argument
(
"
name
"
,
type
=
str
,
required
=
True
,
location
=
"
json
"
)
"
team
"
,
"
team
"
,
url_prefix
=
"
/api/competitions/<competition_id>/teams
"
,
description
=
"
Operations on teams
"
,
)
team_parser_edit
=
reqparse
.
RequestParser
()
team_parser_edit
.
add_argument
(
"
name
"
,
type
=
str
,
default
=
sentinel
,
location
=
"
json
"
)
class
TeamAddArgsSchema
(
BaseSchema
):
class
Meta
(
BaseSchema
.
Meta
):
model
=
models
.
Team
@api.route
(
""
)
name
=
ma
.
auto_field
(
required
=
True
)
@api.param
(
"
competition_id
"
)
class
TeamsList
(
Resource
):
class
TeamEditArgsSchema
(
BaseSchema
):
class
Meta
(
BaseSchema
.
Meta
):
model
=
models
.
Team
name
=
ma
.
auto_field
(
required
=
False
)
@blp.route
(
""
)
class
Teams
(
MethodView
):
@protect_route
(
allowed_roles
=
[
"
*
"
])
@protect_route
(
allowed_roles
=
[
"
*
"
])
@blp.response
(
http_codes
.
OK
,
TeamSchema
(
many
=
True
))
def
get
(
self
,
competition_id
):
def
get
(
self
,
competition_id
):
"""
Gets all teams to the specified competition.
"""
"""
Gets all teams to the specified competition.
"""
return
dbc
.
get
.
team_list
(
competition_id
)
items
=
dbc
.
get
.
team_list
(
competition_id
)
return
list_response
(
list_schema
.
dump
(
items
))
@protect_route
(
allowed_roles
=
[
"
*
"
])
@protect_route
(
allowed_roles
=
[
"
*
"
])
def
post
(
self
,
competition_id
):
@blp.arguments
(
TeamAddArgsSchema
)
@blp.response
(
http_codes
.
OK
,
TeamSchema
)
@blp.alt_response
(
http_codes
.
CONFLICT
,
None
,
description
=
"
Could not add team
"
)
def
post
(
self
,
args
,
competition_id
):
"""
Posts a new team to the specified competition.
"""
"""
Posts a new team to the specified competition.
"""
return
dbc
.
add
.
team
(
args
[
"
name
"
],
competition_id
)
args
=
team_parser_add
.
parse_args
(
strict
=
True
)
item_team
=
dbc
.
add
.
team
(
args
[
"
name
"
],
competition_id
)
return
item_response
(
schema
.
dump
(
item_team
))
@api.route
(
"
/<team_id>
"
)
@blp.route
(
"
/<team_id>
"
)
@api.param
(
"
competition_id,team_id
"
)
class
TeamsById
(
MethodView
):
class
Teams
(
Resource
):
@protect_route
(
allowed_roles
=
[
"
*
"
])
@protect_route
(
allowed_roles
=
[
"
*
"
])
@blp.response
(
http_codes
.
OK
,
TeamSchema
)
@blp.alt_response
(
http_codes
.
NOT_FOUND
,
None
,
description
=
"
Could not find team
"
)
def
get
(
self
,
competition_id
,
team_id
):
def
get
(
self
,
competition_id
,
team_id
):
"""
Gets the specified team.
"""
"""
Gets the specified team.
"""
return
dbc
.
get
.
team
(
competition_id
,
team_id
)
item
=
dbc
.
get
.
team
(
competition_id
,
team_id
)
return
item_response
(
schema
.
dump
(
item
))
@protect_route
(
allowed_roles
=
[
"
*
"
])
@protect_route
(
allowed_roles
=
[
"
*
"
])
def
put
(
self
,
competition_id
,
team_id
):
@blp.arguments
(
TeamEditArgsSchema
)
@blp.response
(
http_codes
.
OK
,
TeamSchema
)
@blp.alt_response
(
http_codes
.
NOT_FOUND
,
None
,
description
=
"
Could not find team
"
)
def
put
(
self
,
args
,
competition_id
,
team_id
):
"""
Edits the specified team using the provided arguments.
"""
"""
Edits the specified team using the provided arguments.
"""
return
dbc
.
edit
.
default
(
dbc
.
get
.
team
(
competition_id
,
team_id
),
**
args
)
args
=
team_parser_edit
.
parse_args
(
strict
=
True
)
name
=
args
.
get
(
"
name
"
)
item_team
=
dbc
.
get
.
team
(
competition_id
,
team_id
)
item_team
=
dbc
.
edit
.
default
(
item_team
,
name
=
name
,
competition_id
=
competition_id
)
return
item_response
(
schema
.
dump
(
item_team
))
@protect_route
(
allowed_roles
=
[
"
*
"
])
@protect_route
(
allowed_roles
=
[
"
*
"
])
@blp.response
(
http_codes
.
NO_CONTENT
,
None
)
@blp.alt_response
(
http_codes
.
NOT_FOUND
,
None
,
description
=
"
Could not find team
"
)
def
delete
(
self
,
competition_id
,
team_id
):
def
delete
(
self
,
competition_id
,
team_id
):
"""
Deletes the specified team.
"""
"""
Deletes the specified team.
"""
dbc
.
delete
.
team
(
dbc
.
get
.
team
(
competition_id
,
team_id
))
item_team
=
dbc
.
get
.
team
(
competition_id
,
team_id
)
return
None
dbc
.
delete
.
team
(
item_team
)
return
{},
codes
.
NO_CONTENT
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment