- from django.core.files import File
- from django.core.files.storage import DefaultStorage
- from catalogue.models import Book
-
- print "will gen %s" % DefaultStorage().path(file_name)
- if not DefaultStorage().exists(file_name):
- kwargs = {
- 'cover': True,
- }
- if 'no-cover' 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)
- DefaultStorage().save(file_name, File(open(pdf.get_filename())))
+ try:
+ from django.core.files import File
+ from django.core.files.storage import DefaultStorage
+ from catalogue.models import Book
+
+ task_logger.info(DefaultStorage().path(file_name))
+ if not DefaultStorage().exists(file_name):
+ kwargs = {
+ 'cover': True,
+ }
+ if 'no-cover' 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)
+ DefaultStorage().save(file_name, File(open(pdf.get_filename())))
+ finally:
+ if waiter_id is not None:
+ WaitedFile.objects.filter(pk=waiter_id).delete()