forked from mirrors/bookwyrm
Updates models
This commit is contained in:
parent
bae01e1ea5
commit
63075a6fe9
5 changed files with 110 additions and 45 deletions
|
@ -219,7 +219,7 @@ class CoverForm(CustomForm):
|
||||||
class FileLinkForm(CustomForm):
|
class FileLinkForm(CustomForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.FileLink
|
model = models.FileLink
|
||||||
exclude = ["remote_id"]
|
fields = ["url", "filetype", "book"]
|
||||||
|
|
||||||
|
|
||||||
class EditionForm(CustomForm):
|
class EditionForm(CustomForm):
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Generated by Django 3.2.10 on 2022-01-09 21:16
|
# Generated by Django 3.2.10 on 2022-01-09 22:10
|
||||||
|
|
||||||
import bookwyrm.models.activitypub_mixin
|
import bookwyrm.models.activitypub_mixin
|
||||||
import bookwyrm.models.fields
|
import bookwyrm.models.fields
|
||||||
|
@ -13,6 +13,47 @@ class Migration(migrations.Migration):
|
||||||
]
|
]
|
||||||
|
|
||||||
operations = [
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name="LinkDomain",
|
||||||
|
fields=[
|
||||||
|
(
|
||||||
|
"id",
|
||||||
|
models.AutoField(
|
||||||
|
auto_created=True,
|
||||||
|
primary_key=True,
|
||||||
|
serialize=False,
|
||||||
|
verbose_name="ID",
|
||||||
|
),
|
||||||
|
),
|
||||||
|
("created_date", models.DateTimeField(auto_now_add=True)),
|
||||||
|
("updated_date", models.DateTimeField(auto_now=True)),
|
||||||
|
(
|
||||||
|
"remote_id",
|
||||||
|
bookwyrm.models.fields.RemoteIdField(
|
||||||
|
max_length=255,
|
||||||
|
null=True,
|
||||||
|
validators=[bookwyrm.models.fields.validate_remote_id],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
("domain", models.CharField(max_length=255, unique=True)),
|
||||||
|
(
|
||||||
|
"status",
|
||||||
|
models.CharField(
|
||||||
|
choices=[
|
||||||
|
("approved", "Approved"),
|
||||||
|
("blocked", "Blocked"),
|
||||||
|
("pending", "Pending"),
|
||||||
|
],
|
||||||
|
default="pending",
|
||||||
|
max_length=50,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
("name", models.CharField(max_length=100)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
"abstract": False,
|
||||||
|
},
|
||||||
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name="Link",
|
name="Link",
|
||||||
fields=[
|
fields=[
|
||||||
|
@ -36,53 +77,21 @@ class Migration(migrations.Migration):
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
("url", bookwyrm.models.fields.URLField(max_length=255)),
|
("url", bookwyrm.models.fields.URLField(max_length=255)),
|
||||||
|
(
|
||||||
|
"domain",
|
||||||
|
models.ForeignKey(
|
||||||
|
blank=True,
|
||||||
|
null=True,
|
||||||
|
on_delete=django.db.models.deletion.PROTECT,
|
||||||
|
to="bookwyrm.linkdomain",
|
||||||
|
),
|
||||||
|
),
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
"abstract": False,
|
"abstract": False,
|
||||||
},
|
},
|
||||||
bases=(bookwyrm.models.activitypub_mixin.ActivitypubMixin, models.Model),
|
bases=(bookwyrm.models.activitypub_mixin.ActivitypubMixin, models.Model),
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
|
||||||
name="LinkDomain",
|
|
||||||
fields=[
|
|
||||||
(
|
|
||||||
"id",
|
|
||||||
models.AutoField(
|
|
||||||
auto_created=True,
|
|
||||||
primary_key=True,
|
|
||||||
serialize=False,
|
|
||||||
verbose_name="ID",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
("created_date", models.DateTimeField(auto_now_add=True)),
|
|
||||||
("updated_date", models.DateTimeField(auto_now=True)),
|
|
||||||
(
|
|
||||||
"remote_id",
|
|
||||||
bookwyrm.models.fields.RemoteIdField(
|
|
||||||
max_length=255,
|
|
||||||
null=True,
|
|
||||||
validators=[bookwyrm.models.fields.validate_remote_id],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
("domain", models.CharField(max_length=255)),
|
|
||||||
(
|
|
||||||
"status",
|
|
||||||
models.CharField(
|
|
||||||
choices=[
|
|
||||||
("approved", "Approved"),
|
|
||||||
("blocked", "Blocked"),
|
|
||||||
("pending", "Pending"),
|
|
||||||
],
|
|
||||||
default="pending",
|
|
||||||
max_length=50,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
("name", models.CharField(max_length=100)),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
"abstract": False,
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name="FileLink",
|
name="FileLink",
|
||||||
fields=[
|
fields=[
|
||||||
|
|
|
@ -4,7 +4,7 @@ import sys
|
||||||
|
|
||||||
from .book import Book, Work, Edition, BookDataModel
|
from .book import Book, Work, Edition, BookDataModel
|
||||||
from .author import Author
|
from .author import Author
|
||||||
from .link import Link, FileLink
|
from .link import Link, FileLink, LinkDomain
|
||||||
from .connector import Connector
|
from .connector import Connector
|
||||||
|
|
||||||
from .shelf import Shelf, ShelfBook
|
from .shelf import Shelf, ShelfBook
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
""" outlink data """
|
""" outlink data """
|
||||||
|
from urllib.parse import urlparse
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils.translation import gettext_lazy as _
|
from django.utils.translation import gettext_lazy as _
|
||||||
|
|
||||||
|
@ -12,12 +14,25 @@ class Link(ActivitypubMixin, BookWyrmModel):
|
||||||
"""a link to a website"""
|
"""a link to a website"""
|
||||||
|
|
||||||
url = fields.URLField(max_length=255, activitypub_field="href")
|
url = fields.URLField(max_length=255, activitypub_field="href")
|
||||||
|
domain = models.ForeignKey(
|
||||||
|
"LinkDomain", on_delete=models.PROTECT, null=True, blank=True
|
||||||
|
)
|
||||||
|
|
||||||
activity_serializer = activitypub.Link
|
activity_serializer = activitypub.Link
|
||||||
reverse_unfurl = True
|
reverse_unfurl = True
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
"""link name via the assocaited domain"""
|
||||||
|
return self.domain.name
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
"""create a link"""
|
"""create a link"""
|
||||||
|
# get or create the associated domain
|
||||||
|
if not self.domain:
|
||||||
|
domain = urlparse(self.url).netloc
|
||||||
|
self.domain, _ = LinkDomain.objects.get_or_create(domain=domain)
|
||||||
|
|
||||||
# this is never broadcast, the owning model broadcasts an update
|
# this is never broadcast, the owning model broadcasts an update
|
||||||
if "broadcast" in kwargs:
|
if "broadcast" in kwargs:
|
||||||
del kwargs["broadcast"]
|
del kwargs["broadcast"]
|
||||||
|
@ -43,7 +58,7 @@ StatusChoices = [
|
||||||
class LinkDomain(BookWyrmModel):
|
class LinkDomain(BookWyrmModel):
|
||||||
"""List of domains used in links"""
|
"""List of domains used in links"""
|
||||||
|
|
||||||
domain = models.CharField(max_length=255)
|
domain = models.CharField(max_length=255, unique=True)
|
||||||
status = models.CharField(max_length=50, choices=StatusChoices, default="pending")
|
status = models.CharField(max_length=50, choices=StatusChoices, default="pending")
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
|
|
41
bookwyrm/tests/models/test_link.py
Normal file
41
bookwyrm/tests/models/test_link.py
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
""" testing models """
|
||||||
|
from unittest.mock import patch
|
||||||
|
from django.test import TestCase
|
||||||
|
|
||||||
|
from bookwyrm import models
|
||||||
|
|
||||||
|
|
||||||
|
@patch("bookwyrm.models.activitypub_mixin.broadcast_task.apply_async")
|
||||||
|
class Link(TestCase):
|
||||||
|
"""some activitypub oddness ahead"""
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
"""look, a list"""
|
||||||
|
with patch("bookwyrm.suggested_users.rerank_suggestions_task.delay"), patch(
|
||||||
|
"bookwyrm.activitystreams.populate_stream_task.delay"
|
||||||
|
), patch("bookwyrm.lists_stream.populate_lists_task.delay"):
|
||||||
|
self.local_user = models.User.objects.create_user(
|
||||||
|
"mouse", "mouse@mouse.mouse", "mouseword", local=True, localname="mouse"
|
||||||
|
)
|
||||||
|
work = models.Work.objects.create(title="hello")
|
||||||
|
self.book = models.Edition.objects.create(title="hi", parent_work=work)
|
||||||
|
|
||||||
|
def test_create_domain(self, _):
|
||||||
|
"""generated default name"""
|
||||||
|
domain = models.LinkDomain.objects.create(domain="beep.com")
|
||||||
|
self.assertEqual(domain.name, "beep.com")
|
||||||
|
self.assertEqual(domain.status, "pending")
|
||||||
|
|
||||||
|
def test_create_link_new_domain(self, _):
|
||||||
|
"""generates link and sets domain"""
|
||||||
|
link = models.Link.objects.create(url="https://www.hello.com/hi-there")
|
||||||
|
self.assertEqual(link.domain.domain, "www.hello.com")
|
||||||
|
self.assertEqual(link.name, "www.hello.com")
|
||||||
|
|
||||||
|
def test_create_link_existing_domain(self, _):
|
||||||
|
"""generate link with a known domain"""
|
||||||
|
domain = models.LinkDomain.objects.create(domain="www.hello.com", name="Hi")
|
||||||
|
|
||||||
|
link = models.Link.objects.create(url="https://www.hello.com/hi-there")
|
||||||
|
self.assertEqual(link.domain, domain)
|
||||||
|
self.assertEqual(link.name, "Hi")
|
Loading…
Reference in a new issue