aboutsummaryrefslogtreecommitdiff
path: root/views.py
diff options
context:
space:
mode:
authorAlban Gruin2017-01-22 18:38:52 +0100
committerAlban Gruin2017-01-22 18:38:52 +0100
commitc0f72b8c7062eceda834beae57efbe95d94eb4f9 (patch)
treeb5cb45720d672619556bcdf1e1a2a19e919eb1cc /views.py
parent6a9464882f74bc8a85ad86d098f8b4da04c854ca (diff)
Mécanismes d'abonnement et de désabonnement
Diffstat (limited to 'views.py')
-rw-r--r--views.py27
1 files changed, 24 insertions, 3 deletions
diff --git a/views.py b/views.py
index a6dfede..729333f 100644
--- a/views.py
+++ b/views.py
@@ -1,8 +1,9 @@
-from django.http import HttpResponse
+from django.http import HttpResponse, Http404
from django.db.models import Count
-from django.shortcuts import get_object_or_404, render, render_to_response
+from django.shortcuts import get_object_or_404, redirect, render, render_to_response
+from django.utils import timezone
-from edt.models import Timetable, LastUpdate, Group, Course
+from edt.models import Timetable, LastUpdate, Group, Subscription, Course
from edt.utils import get_week
import datetime
@@ -40,3 +41,23 @@ def timetable(request, timetable_slug, year, week, group_slug):
grouped_courses[-1].append(course)
return render_to_response("timetable.html", {"timetable": timetable, "group": group, "courses": grouped_courses, "last_update": last_update.date, "week": week})
+
+def confirm_subscription(request, token):
+ subscription = get_object_or_404(Subscription, token=token)
+ if subscription.active:
+ raise Http404()
+
+ subscription.active = True
+ subscription.save()
+
+ year, week, day = timezone.now().isocalendar()
+ if day >= 6:
+ year, week, _ = (timezone.now() + datetime.timedelta(weeks=1)).isocalendar()
+
+ return redirect("timetable", timetable_slug=subscription.group.timetable.slug, year=year, week=week, group_slug=subscription.group.slug)
+
+def cancel_subscription(request, token):
+ subscription = get_object_or_404(Subscription, token=token)
+ subscription.delete()
+
+ return redirect("index")