moviewyrm/fedireads/models.py

113 lines
3.9 KiB
Python
Raw Normal View History

2020-01-25 06:32:41 +00:00
''' database schema for the whole dang thing '''
from django.db import models
2020-01-25 23:25:19 +00:00
from django.dispatch import receiver
2020-01-25 06:32:41 +00:00
from django.contrib.auth.models import AbstractUser
from django.contrib.postgres.fields import JSONField
2020-01-25 21:46:30 +00:00
from Crypto.PublicKey import RSA
from Crypto import Random
from datetime import datetime
2020-01-25 06:32:41 +00:00
class User(AbstractUser):
''' a user who wants to read books '''
private_key = models.CharField(max_length=255)
public_key = models.CharField(max_length=255)
api_key = models.CharField(max_length=255, blank=True, null=True)
2020-01-25 21:46:30 +00:00
created_date = models.DateTimeField(auto_now_add=True)
updated_date = models.DateTimeField(auto_now=True)
followers = models.ManyToManyField('self', symmetrical=False)
def save(self, *args, **kwargs):
# give a new user keys
if not self.private_key:
random_generator = Random.new().read
key = RSA.generate(1024, random_generator)
self.private_key = key
self.public_key = key.publickey()
if not self.id:
self.created_date = datetime.now()
self.updated_date = datetime.now()
super().save(*args, **kwargs)
2020-01-25 06:32:41 +00:00
2020-01-25 23:25:19 +00:00
@receiver(models.signals.post_save, sender=User)
def execute_after_save(sender, instance, created, *args, **kwargs):
if not created:
return
shelves = [{
'name': 'To Read',
'type': 'to-read',
}, {
'name': 'Currently Reading',
'type': 'reading',
}, {
'name': 'Read',
'type': 'read',
}]
for shelf in shelves:
Shelf(name=shelf['name'], shelf_type=shelf['type'], user=instance, editable=False).save()
2020-01-25 06:32:41 +00:00
class Message(models.Model):
''' any kind of user post, incl. reviews, replies, and status updates '''
author = models.ForeignKey('User', on_delete=models.PROTECT)
name = models.CharField(max_length=255)
content = JSONField(max_length=5000)
2020-01-25 21:46:30 +00:00
created_date = models.DateTimeField(auto_now_add=True)
updated_date = models.DateTimeField(auto_now=True)
2020-01-25 06:32:41 +00:00
class Meta:
abstract = True
class Review(Message):
book = models.ForeignKey('Book', on_delete=models.PROTECT)
star_rating = models.IntegerField(default=0)
class Shelf(models.Model):
name = models.CharField(max_length=100)
user = models.ForeignKey('User', on_delete=models.PROTECT)
editable = models.BooleanField(default=True)
2020-01-25 23:25:19 +00:00
shelf_type = models.CharField(default='custom', max_length=100)
books = models.ManyToManyField(
'Book',
symmetrical=False,
through='ShelfBook',
through_fields=('shelf', 'book')
)
2020-01-25 21:46:30 +00:00
created_date = models.DateTimeField(auto_now_add=True)
updated_date = models.DateTimeField(auto_now=True)
2020-01-25 06:32:41 +00:00
2020-01-25 23:25:19 +00:00
class ShelfBook(models.Model):
# many to many join table for books and shelves
book = models.ForeignKey('Book', on_delete=models.PROTECT)
shelf = models.ForeignKey('Shelf', on_delete=models.PROTECT)
added_by = models.ForeignKey('User', blank=True, null=True, on_delete=models.PROTECT)
added_date = models.DateTimeField(auto_now_add=True)
2020-01-25 06:32:41 +00:00
class Book(models.Model):
''' a non-canonical copy from open library '''
openlibary_key = models.CharField(max_length=255)
data = JSONField()
2020-01-25 21:46:30 +00:00
works = models.ManyToManyField('Work')
2020-01-25 23:25:19 +00:00
authors = models.ManyToManyField('Author')
2020-01-25 21:46:30 +00:00
added_by = models.ForeignKey('User', on_delete=models.PROTECT, blank=True, null=True)
added_date = models.DateTimeField(auto_now_add=True)
updated_date = models.DateTimeField(auto_now=True)
2020-01-25 06:32:41 +00:00
2020-01-25 21:46:30 +00:00
class Work(models.Model):
openlibary_key = models.CharField(max_length=255)
data = JSONField()
added_date = models.DateTimeField(auto_now_add=True)
updated_date = models.DateTimeField(auto_now=True)
2020-01-25 23:25:19 +00:00
class Author(models.Model):
openlibary_key = models.CharField(max_length=255)
data = JSONField()
added_date = models.DateTimeField(auto_now_add=True)
updated_date = models.DateTimeField(auto_now=True)