X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/3af75386ed5c78b09c4669442a2422a388e949c3..9891ea5fbf1f70686612a66fcb6bdfc04a9a037c:/src/isbn/models.py diff --git a/src/isbn/models.py b/src/isbn/models.py index 746281f74..b5e5de3a2 100644 --- a/src/isbn/models.py +++ b/src/isbn/models.py @@ -1,51 +1,104 @@ -# -*- coding: utf-8 -*- # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # from django.db import models -from jsonfield import JSONField +from django.db.models import F class ISBNPool(models.Model): + PURPOSE_WL = 'WL' + PURPOSE_FNP = 'FNP' + PURPOSE_CHOICES = ( + (PURPOSE_WL, 'Wolne Lektury'), + (PURPOSE_FNP, 'Fundacja Nowoczesna Polska'), + ) + prefix = models.CharField(max_length=10) suffix_from = models.IntegerField() suffix_to = models.IntegerField() ref_from = models.IntegerField() next_suffix = models.IntegerField() + purpose = models.CharField(max_length=4, choices=PURPOSE_CHOICES) + + def __str__(self): + return self.prefix + + @classmethod + def active_pool(cls, purpose): + pools = cls.objects.filter(purpose=purpose) + pools = pools.exclude(next_suffix__gt=F('suffix_to')) + if len(pools) == 1: + return pools.get() + else: + pools.exclude(next_suffix=F('suffix_from')) + return pools.get() @staticmethod def check_digit(prefix12): digits = [int(d) for d in prefix12] return str((-sum(digits[0::2]) + 7 * sum(digits[1::2])) % 10) - def isbn(self, suffix): + def isbn(self, suffix, dashes=False): prefix_length = len(self.prefix) suffix_length = 12 - prefix_length suffix_str = ('%%0%dd' % suffix_length) % suffix prefix12 = self.prefix + suffix_str - return prefix12 + self.check_digit(prefix12) + if dashes: + prefix12_final = '%s-%s-%s-%s-' % (self.prefix[:3], self.prefix[3:5], self.prefix[5:], suffix_str) + else: + prefix12_final = prefix12 + return prefix12_final + self.check_digit(prefix12) class ONIXRecord(models.Model): - isbn_pool = models.ForeignKey(ISBNPool) + isbn_pool = models.ForeignKey(ISBNPool, models.PROTECT) datestamp = models.DateField(auto_now=True) suffix = models.IntegerField() product_form = models.CharField(max_length=4) product_form_detail = models.CharField(max_length=8, blank=True) title = models.CharField(max_length=256) part_number = models.CharField(max_length=64, blank=True) - contributors = JSONField() # roles, names, optional: ISNI, date of birth/death + contributors = models.TextField() # roles, names, optional: ISNI, date of birth/death edition_type = models.CharField(max_length=4) edition_number = models.IntegerField(default=1) language = models.CharField(max_length=4) imprint = models.CharField(max_length=256) publishing_date = models.DateField() + dc_slug = models.CharField(max_length=256, default='', db_index=True) class Meta: ordering = ['isbn_pool__id', 'suffix'] + unique_together = ['isbn_pool', 'suffix'] + + @classmethod + def new_record(cls, purpose, data): + pool = ISBNPool.active_pool(purpose) + fields = { + 'isbn_pool': pool, + 'suffix': pool.next_suffix, + } + fields_to_copy = [ + 'product_form', + 'product_form_detail', + 'title', + 'part_number', + 'contributors', # ??? + 'edition_type', + 'edition_number', + 'language', + 'imprint', + 'publishing_date', + 'dc_slug', + ] + for field in fields_to_copy: + if field in data: + fields[field] = data[field] + cls.objects.create(**fields) + pool.next_suffix += 1 + pool.save() - def isbn(self): - return self.isbn_pool.isbn(self.suffix) + def isbn(self, dashes=False): + return self.isbn_pool.isbn(self.suffix, dashes=dashes) def reference(self): return 'pl-eisbn-%s' % (self.isbn_pool.ref_from + self.suffix)