mirror of
https://gitlab.com/animath/si/plateforme.git
synced 2025-02-23 21:41:19 +00:00
Compare commits
No commits in common. "1df17667539a1dd407d0987abe621b314087fc01" and "a45d57e51a4d7ef3dcb43a14c8c69a18dd63bf03" have entirely different histories.
1df1766753
...
a45d57e51a
@ -1,4 +1,4 @@
|
|||||||
FROM python:3.9-alpine
|
FROM python:3.8-alpine
|
||||||
|
|
||||||
ENV PYTHONUNBUFFERED 1
|
ENV PYTHONUNBUFFERED 1
|
||||||
ENV DJANGO_ALLOW_ASYNC_UNSAFE 1
|
ENV DJANGO_ALLOW_ASYNC_UNSAFE 1
|
||||||
|
@ -16,10 +16,6 @@ if "logs" in settings.INSTALLED_APPS:
|
|||||||
from logs.api.urls import register_logs_urls
|
from logs.api.urls import register_logs_urls
|
||||||
register_logs_urls(router, "logs")
|
register_logs_urls(router, "logs")
|
||||||
|
|
||||||
if "participation" in settings.INSTALLED_APPS:
|
|
||||||
from participation.api.urls import register_participation_urls
|
|
||||||
register_participation_urls(router, "participation")
|
|
||||||
|
|
||||||
app_name = 'api'
|
app_name = 'api'
|
||||||
|
|
||||||
# Wire up our API using automatic URL routing.
|
# Wire up our API using automatic URL routing.
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
# Copyright (C) 2018-2020 by BDE ENS Paris-Saclay
|
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
@ -1,61 +0,0 @@
|
|||||||
# Copyright (C) 2020 by Animath
|
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
||||||
|
|
||||||
from rest_framework import serializers
|
|
||||||
|
|
||||||
from ..models import Note, Participation, Passage, Pool, Solution, Synthesis, Team, Tournament
|
|
||||||
|
|
||||||
|
|
||||||
class NoteSerializer(serializers.ModelSerializer):
|
|
||||||
class Meta:
|
|
||||||
model = Note
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class ParticipationSerializer(serializers.ModelSerializer):
|
|
||||||
class Meta:
|
|
||||||
model = Participation
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class PassageSerializer(serializers.ModelSerializer):
|
|
||||||
class Meta:
|
|
||||||
model = Passage
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class PoolSerializer(serializers.ModelSerializer):
|
|
||||||
passages = serializers.ListSerializer(child=PassageSerializer())
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = Pool
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class SolutionSerializer(serializers.ModelSerializer):
|
|
||||||
class Meta:
|
|
||||||
model = Solution
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class SynthesisSerializer(serializers.ModelSerializer):
|
|
||||||
class Meta:
|
|
||||||
model = Synthesis
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class TeamSerializer(serializers.ModelSerializer):
|
|
||||||
participation = ParticipationSerializer()
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = Team
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class TournamentSerializer(serializers.ModelSerializer):
|
|
||||||
class Meta:
|
|
||||||
model = Tournament
|
|
||||||
fields = ('name', 'date_start', 'date_end', 'place', 'max_teams', 'price', 'remote',
|
|
||||||
'inscription_limit', 'solution_limit', 'solutions_draw', 'syntheses_first_phase_limit',
|
|
||||||
'solutions_available_second_phase', 'syntheses_second_phase_limit',
|
|
||||||
'description', 'organizers', 'final', 'participations',)
|
|
@ -1,19 +0,0 @@
|
|||||||
# Copyright (C) 2020 by Animath
|
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
||||||
|
|
||||||
from .views import NoteViewSet, ParticipationViewSet, PassageViewSet, PoolViewSet, \
|
|
||||||
SolutionViewSet, SynthesisViewSet, TeamViewSet, TournamentViewSet
|
|
||||||
|
|
||||||
|
|
||||||
def register_participation_urls(router, path):
|
|
||||||
"""
|
|
||||||
Configure router for participation REST API.
|
|
||||||
"""
|
|
||||||
router.register(path + "/note", NoteViewSet)
|
|
||||||
router.register(path + "/participation", ParticipationViewSet)
|
|
||||||
router.register(path + "/passage", PassageViewSet)
|
|
||||||
router.register(path + "/pool", PoolViewSet)
|
|
||||||
router.register(path + "/solution", SolutionViewSet)
|
|
||||||
router.register(path + "/synthesis", SynthesisViewSet)
|
|
||||||
router.register(path + "/team", TeamViewSet)
|
|
||||||
router.register(path + "/tournament", TournamentViewSet)
|
|
@ -1,69 +0,0 @@
|
|||||||
# Copyright (C) 2020 by Animath
|
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
||||||
from django_filters.rest_framework import DjangoFilterBackend
|
|
||||||
from rest_framework.viewsets import ModelViewSet
|
|
||||||
|
|
||||||
from .serializers import NoteSerializer, ParticipationSerializer, PassageSerializer, PoolSerializer, \
|
|
||||||
SolutionSerializer, SynthesisSerializer, TeamSerializer, TournamentSerializer
|
|
||||||
from ..models import Note, Participation, Passage, Pool, Solution, Synthesis, Team, Tournament
|
|
||||||
|
|
||||||
|
|
||||||
class NoteViewSet(ModelViewSet):
|
|
||||||
queryset = Note.objects.all()
|
|
||||||
serializer_class = NoteSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['jury', 'passage', 'defender_writing', 'defender_oral', 'opponent_writing',
|
|
||||||
'opponent_oral', 'reporter_writing', 'reporter_oral', ]
|
|
||||||
|
|
||||||
|
|
||||||
class ParticipationViewSet(ModelViewSet):
|
|
||||||
queryset = Participation.objects.all()
|
|
||||||
serializer_class = ParticipationSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['team', 'team__name', 'team__trigram', 'tournament', 'tournament__name', 'valid', 'final', ]
|
|
||||||
|
|
||||||
|
|
||||||
class PassageViewSet(ModelViewSet):
|
|
||||||
queryset = Passage.objects.all()
|
|
||||||
serializer_class = PassageSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['pool', 'place', 'solution_number', 'defender', 'opponent', 'reporter', ]
|
|
||||||
|
|
||||||
|
|
||||||
class PoolViewSet(ModelViewSet):
|
|
||||||
queryset = Pool.objects.all()
|
|
||||||
serializer_class = PoolSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['tournament', 'tournament__name', 'round', 'participations', 'juries', 'bbb_url', ]
|
|
||||||
|
|
||||||
|
|
||||||
class SolutionViewSet(ModelViewSet):
|
|
||||||
queryset = Solution.objects.all()
|
|
||||||
serializer_class = SolutionSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['participation', 'number', 'problem', 'final_solution', ]
|
|
||||||
|
|
||||||
|
|
||||||
class SynthesisViewSet(ModelViewSet):
|
|
||||||
queryset = Synthesis.objects.all()
|
|
||||||
serializer_class = SynthesisSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['participation', 'number', 'passage', 'type', ]
|
|
||||||
|
|
||||||
|
|
||||||
class TeamViewSet(ModelViewSet):
|
|
||||||
queryset = Team.objects.all()
|
|
||||||
serializer_class = TeamSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['name', 'trigram', 'access_code', 'participation__valid', 'participation__tournament',
|
|
||||||
'participation__tournament__name', 'participation__valid', 'participation__final', ]
|
|
||||||
|
|
||||||
|
|
||||||
class TournamentViewSet(ModelViewSet):
|
|
||||||
queryset = Tournament.objects.all()
|
|
||||||
serializer_class = TournamentSerializer
|
|
||||||
filter_backends = [DjangoFilterBackend]
|
|
||||||
filterset_fields = ['name', 'date_start', 'date_end', 'place', 'max_teams', 'price', 'remote',
|
|
||||||
'inscription_limit', 'solution_limit', 'solutions_draw', 'syntheses_first_phase_limit',
|
|
||||||
'solutions_available_second_phase', 'syntheses_second_phase_limit',
|
|
||||||
'description', 'organizers', 'final', ]
|
|
@ -1,5 +1,5 @@
|
|||||||
asgiref~=3.3.1
|
asgiref~=3.3.1
|
||||||
Django~=3.1
|
Django~=3.0
|
||||||
django-address~=0.2
|
django-address~=0.2
|
||||||
django-bootstrap-datepicker-plus~=3.0
|
django-bootstrap-datepicker-plus~=3.0
|
||||||
django-cas-server~=1.2
|
django-cas-server~=1.2
|
||||||
@ -19,7 +19,7 @@ phonenumbers~=8.9.10
|
|||||||
psycopg2-binary~=2.8
|
psycopg2-binary~=2.8
|
||||||
PyPDF3~=1.0.2
|
PyPDF3~=1.0.2
|
||||||
ipython~=7.19.0
|
ipython~=7.19.0
|
||||||
python-magic>=0.4.21
|
python-magic==0.4.18
|
||||||
requests~=2.25.0
|
requests~=2.25.0
|
||||||
sympasoap~=1.0
|
sympasoap~=1.0
|
||||||
whoosh~=2.7
|
whoosh~=2.7
|
2
tox.ini
2
tox.ini
@ -23,7 +23,7 @@ deps =
|
|||||||
django-rest-polymorphic~=0.1
|
django-rest-polymorphic~=0.1
|
||||||
phonenumbers~=8.9.10
|
phonenumbers~=8.9.10
|
||||||
PyPDF3~=1.0.2
|
PyPDF3~=1.0.2
|
||||||
python-magic==0.4.21
|
python-magic==0.4.18
|
||||||
whoosh~=2.7
|
whoosh~=2.7
|
||||||
commands =
|
commands =
|
||||||
coverage run --source=apps,tfjm ./manage.py test apps/ tfjm/
|
coverage run --source=apps,tfjm ./manage.py test apps/ tfjm/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user