fnp
/
wolnelektury.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
procent
[wolnelektury.git]
/
src
/
catalogue
/
tasks.py
diff --git
a/src/catalogue/tasks.py
b/src/catalogue/tasks.py
index
b703e17
..
20690c6
100644
(file)
--- a/
src/catalogue/tasks.py
+++ b/
src/catalogue/tasks.py
@@
-1,5
+1,5
@@
-# This file is part of Wolne
l
ektury, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja
Nowoczesna Polska
. See NOTICE for more information.
+# This file is part of Wolne
L
ektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja
Wolne Lektury
. See NOTICE for more information.
#
from traceback import print_exc
from celery import shared_task
#
from traceback import print_exc
from celery import shared_task
@@
-7,6
+7,7
@@
from celery.utils.log import get_task_logger
from django.conf import settings
from django.utils import timezone
from django.conf import settings
from django.utils import timezone
+from catalogue.models import Book
from catalogue.utils import absolute_url, gallery_url
from waiter.models import WaitedFile
from catalogue.utils import absolute_url, gallery_url
from waiter.models import WaitedFile
@@
-22,11
+23,18
@@
def touch_tag(tag):
type(tag).objects.filter(pk=tag.pk).update(**update_dict)
type(tag).objects.filter(pk=tag.pk).update(**update_dict)
+@shared_task(ignore_result=True)
+def build_field(pk, field_name):
+ book = Book.objects.get(pk=pk)
+ task_logger.info("build %s.%s" % (book.slug, field_name))
+ field_file = getattr(book, field_name)
+ field_file.build()
+
+
@shared_task
@shared_task
-def index_book(book_id, book_info=None, **kwargs):
- from catalogue.models import Book
+def index_book(book_id, **kwargs):
try:
try:
- return Book.objects.get(id=book_id).search_index(
book_info,
**kwargs)
+ return Book.objects.get(id=book_id).search_index(**kwargs)
except Exception as e:
print("Exception during index: %s" % e)
print_exc()
except Exception as e:
print("Exception during index: %s" % e)
print_exc()
@@
-39,7
+47,6
@@
def build_custom_pdf(book_id, customizations, file_name, waiter_id=None):
try:
from django.core.files import File
from django.core.files.storage import DefaultStorage
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):
task_logger.info(DefaultStorage().path(file_name))
if not DefaultStorage().exists(file_name):
@@
-55,7
+62,8
@@
def build_custom_pdf(book_id, customizations, file_name, waiter_id=None):
morefloats=settings.LIBRARIAN_PDF_MOREFLOATS,
base_url=absolute_url(gallery_url(wldoc.book_info.url.slug)),
**kwargs)
morefloats=settings.LIBRARIAN_PDF_MOREFLOATS,
base_url=absolute_url(gallery_url(wldoc.book_info.url.slug)),
**kwargs)
- DefaultStorage().save(file_name, File(open(pdf.get_filename(), 'rb')))
+ with open(pdf.get_filename(), 'rb') as f:
+ DefaultStorage().save(file_name, File(f))
finally:
if waiter_id is not None:
WaitedFile.objects.filter(pk=waiter_id).delete()
finally:
if waiter_id is not None:
WaitedFile.objects.filter(pk=waiter_id).delete()
@@
-69,6
+77,5
@@
def update_counters():
@shared_task(ignore_result=True)
def update_references(book_id):
@shared_task(ignore_result=True)
def update_references(book_id):
- from catalogue.models import Book
Book.objects.get(id=book_id).update_references()
Book.objects.get(id=book_id).update_references()