More automation for YouTube: volume management (WiP).
[audio.git] / src / archive / views.py
index aee88e6..10a998f 100644 (file)
@@ -11,6 +11,7 @@ from django.http import Http404, HttpResponse
 from django.shortcuts import render, redirect, get_object_or_404
 from django.utils.translation import gettext as _
 from django.views.decorators.http import require_POST
+from django.views.generic import ListView
 
 import mutagen
 
@@ -270,15 +271,13 @@ def file_managed(request, id):
         request.user.oauthconnection_set.filter(access=True).exists())
 
     alerts = []
-    series = models.Audiobook.objects.filter(url=audiobook.url)
-    real = series.count()
-    if real != audiobook.parts_count:
-        alerts.append(_('Parts number inconsitent. Declared number: %(declared)d. Real number: %(real)d') % {"declared": audiobook.parts_count, "real": real})
-    if audiobook.parts_count > 1:
+    parts_count = audiobook.parts_count
+    if parts_count > 1:
+        series = models.Audiobook.objects.filter(slug=audiobook.slug)
         if not audiobook.index:
             alerts.append(_('There is more than one part, but index is not set.'))
-        if set(series.values_list('index', flat=True)) != set(range(1, audiobook.parts_count + 1)):
-            alerts.append(_('Part indexes are not 1..%(parts_count)d.') % {"parts_count": audiobook.parts_count})
+        if set(series.values_list('index', flat=True)) != set(range(1, parts_count + 1)):
+            alerts.append(_('Part indexes are not 1..%(parts_count)d.') % {"parts_count": parts_count})
 
     return render(request, "archive/file_managed.html", locals())
 
@@ -299,3 +298,10 @@ def file_unmanaged(request, filename):
     
     err_exists = request.GET.get('exists')
     return render(request, "archive/file_unmanaged.html", locals())
+
+
+class BookView(ListView):
+    template_name = 'archive/book.html'
+
+    def get_queryset(self):
+        return models.Audiobook.objects.filter(slug=self.kwargs['slug'])