fix indexing bug (conflicting uids)
[wolnelektury.git] / src / catalogue / tasks.py
index a2b8be0..30bc55f 100644 (file)
@@ -7,6 +7,8 @@ from traceback import print_exc
 from celery.task import task
 from celery.utils.log import get_task_logger
 from django.conf import settings
+
+from catalogue.utils import gallery_path
 from wolnelektury.utils import localtime_to_utc
 from waiter.models import WaitedFile
 
@@ -46,14 +48,22 @@ def build_custom_pdf(book_id, customizations, file_name, waiter_id=None):
             kwargs = {
                 'cover': True,
             }
-            if 'no-cover' in customizations:
+            if 'nocover' in customizations:
                 kwargs['cover'] = False
-                customizations.remove('no-cover')
-            pdf = Book.objects.get(pk=book_id).wldocument().as_pdf(
-                    customizations=customizations,
-                    morefloats=settings.LIBRARIAN_PDF_MOREFLOATS,
-                    **kwargs)
+                customizations.remove('nocover')
+            wldoc = Book.objects.get(pk=book_id).wldocument()
+            pdf = wldoc.as_pdf(
+                customizations=customizations,
+                morefloats=settings.LIBRARIAN_PDF_MOREFLOATS,
+                ilustr_path=gallery_path(wldoc.book_info.url.slug),
+                **kwargs)
             DefaultStorage().save(file_name, File(open(pdf.get_filename())))
     finally:
         if waiter_id is not None:
             WaitedFile.objects.filter(pk=waiter_id).delete()
+
+
+@task(ignore_result=True)
+def update_counters():
+    from .helpers import update_counters
+    update_counters()