X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/9d7d8b6bf3dcc7b8322bc4d636d793fe46c106e8..7a3626e47b968d2a56c7992ac6c6d292e91f987a:/src/catalogue/models/book.py diff --git a/src/catalogue/models/book.py b/src/catalogue/models/book.py index 375c79a8e..d0487cd5f 100644 --- a/src/catalogue/models/book.py +++ b/src/catalogue/models/book.py @@ -7,6 +7,7 @@ from datetime import date, timedelta from random import randint import os.path import re +import requests from slugify import slugify from sortify import sortify from urllib.request import urlretrieve @@ -61,6 +62,9 @@ class Book(models.Model): preview_until = models.DateField('prapremiera do', blank=True, null=True) preview_key = models.CharField(max_length=32, blank=True, null=True) findable = models.BooleanField('wyszukiwalna', default=True, db_index=True) + can_sell = models.BooleanField('do sprzedaży', default=True) + can_sell_mp3 = models.BooleanField('do sprzedaży mp3', default=True) + isbn_mp3 = models.CharField('ISBN audiobooka', max_length=32, blank=True) # files generated during publication xml_file = fields.XmlField(storage=bofh_storage, with_etag=False) @@ -683,7 +687,7 @@ class Book(models.Model): @classmethod def from_text_and_meta(cls, raw_file, book_info, overwrite=False, dont_build=None, search_index=True, - remote_gallery_url=None, days=0, findable=True, logo=None, logo_mono=None, logo_alt=None): + remote_gallery_url=None, days=0, findable=True, logo=None, logo_mono=None, logo_alt=None, can_sell=None, isbn_mp3=None): from catalogue import tasks if dont_build is None: @@ -738,6 +742,10 @@ class Book(models.Model): extra['logo_mono'] = logo_mono if logo_alt: extra['logo_alt'] = logo_alt + if can_sell is not None: + book.can_sell = can_sell + if isbn_mp3 is not None: + book.isbn_mp3 = isbn_mp3 book.extra_info = json.dumps(extra) book.load_abstract() book.load_toc() @@ -903,6 +911,18 @@ class Book(models.Model): narrators.append(t) self.narrators.set(narrators) + def update_can_sell_mp3(self): + ret = True + for child in self.get_children(): + child.update_can_sell_mp3() + if not child.can_sell_mp3: + ret = False + if self.has_mp3_file(): + audio_items = requests.get(f'https://audio.wolnelektury.pl/archive/book/{self.slug}.json').json()['items'] + if not all(x['project']['can_sell'] for x in audio_items): + ret = False + self.can_sell_audio = ret + @classmethod @transaction.atomic def repopulate_ancestors(cls):