diff options
author | Alban Gruin | 2017-01-22 18:38:52 +0100 |
---|---|---|
committer | Alban Gruin | 2017-01-22 18:38:52 +0100 |
commit | c0f72b8c7062eceda834beae57efbe95d94eb4f9 (patch) | |
tree | b5cb45720d672619556bcdf1e1a2a19e919eb1cc /views.py | |
parent | 6a9464882f74bc8a85ad86d098f8b4da04c854ca (diff) |
Mécanismes d'abonnement et de désabonnement
Diffstat (limited to 'views.py')
-rw-r--r-- | views.py | 27 |
1 files changed, 24 insertions, 3 deletions
@@ -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") |