From 12afb9f39ef04dcdfe59be3e5b7792b886519835 Mon Sep 17 00:00:00 2001 From: Josue Kouka Date: Mon, 26 Jun 2017 14:51:36 +0200 Subject: [PATCH] api: add agenda detail api (#17188) --- chrono/api/urls.py | 1 + chrono/api/views.py | 57 ++++++++++++++++++++++++++++++++--------------------- tests/test_api.py | 11 +++++++++++ 3 files changed, 46 insertions(+), 23 deletions(-) diff --git a/chrono/api/urls.py b/chrono/api/urls.py index 23c5b04..3a0673f 100644 --- a/chrono/api/urls.py +++ b/chrono/api/urls.py @@ -20,6 +20,7 @@ from . import views urlpatterns = [ url(r'agenda/$', views.agendas), + url(r'agenda/(?P[\w-]+)/$', views.agenda), url(r'agenda/(?P[\w-]+)/datetimes/$', views.datetimes, name='api-agenda-datetimes'), url(r'agenda/(?P[\w-]+)/fillslot/(?P[\w:-]+)/$', diff --git a/chrono/api/views.py b/chrono/api/views.py index 8805397..d133e94 100644 --- a/chrono/api/views.py +++ b/chrono/api/views.py @@ -29,37 +29,48 @@ from rest_framework.views import APIView from ..agendas.models import Agenda, Event, Booking, MeetingType, TimePeriod +def get_agenda_data(request, agenda): + agenda_data = { + 'id': agenda.id, + 'slug': agenda.slug, + 'text': agenda.label, + 'kind': agenda.kind, + } + + if agenda.kind == 'events': + agenda_data['api'] = { + 'datetimes_url': request.build_absolute_uri( + reverse('api-agenda-datetimes', + kwargs={'agenda_identifier': agenda.slug})) + } + elif agenda.kind == 'meetings': + agenda_data['api'] = { + 'meetings_url': request.build_absolute_uri( + reverse('api-agenda-meetings', + kwargs={'agenda_identifier': agenda.slug})) + } + return agenda_data + class Agendas(GenericAPIView): permission_classes = () def get(self, request, format=None): - agendas = [] - for agenda in Agenda.objects.all().order_by('label'): - agenda_data = { - 'id': agenda.id, - 'slug': agenda.slug, - 'text': agenda.label, - 'kind': agenda.kind, - } - - if agenda.kind == 'events': - agenda_data['api'] = { - 'datetimes_url': request.build_absolute_uri( - reverse('api-agenda-datetimes', - kwargs={'agenda_identifier': agenda.slug})) - } - elif agenda.kind == 'meetings': - agenda_data['api'] = { - 'meetings_url': request.build_absolute_uri( - reverse('api-agenda-meetings', - kwargs={'agenda_identifier': agenda.slug})) - } - agendas.append(agenda_data) - + agendas = [get_agenda_data(request, agenda) for agenda in Agenda.objects.all().order_by('label')] return Response({'data': agendas}) agendas = Agendas.as_view() +class AgendaDetail(GenericAPIView): + """View returning detail of a single agenda + """ + permission_classes = () + + def get(self, request, agenda_identifier): + agenda = get_object_or_404(Agenda, slug=agenda_identifier) + return Response({ + 'data': get_agenda_data(request, agenda)}) + +agenda = AgendaDetail.as_view() class Datetimes(GenericAPIView): permission_classes = () diff --git a/tests/test_api.py b/tests/test_api.py index 9900832..5960e40 100644 --- a/tests/test_api.py +++ b/tests/test_api.py @@ -588,3 +588,14 @@ def test_multiple_booking_api(app, some_data, user): resp = app.post(resp3.json['api']['accept_url']) assert event.booked_places == 7 assert event.waiting_list == 0 + +def test_agenda_api(app, some_data): + app.get('/api/agenda/whatever/', status=404) + agenda = Agenda.objects.get(slug='foo-bar') + resp = app.get('/api/agenda/%s/' % agenda.slug) + data = resp.json['data'] + assert data['id'] == 1 + assert data['slug'] == 'foo-bar' + assert data['text'] == 'Foo bar' + assert data['kind'] == 'events' + assert data['api']['datetimes_url'] == 'http://testserver/api/agenda/foo-bar/datetimes/' -- 2.11.0