moviewyrm/bookwyrm/models/connector.py

39 lines
1.5 KiB
Python
Raw Normal View History

2021-03-08 16:49:10 +00:00
""" manages interfaces with external sources of book data """
2020-09-17 20:09:11 +00:00
from django.db import models
from bookwyrm.connectors.settings import CONNECTORS
2020-09-17 20:09:11 +00:00
2020-09-21 15:16:34 +00:00
from .base_model import BookWyrmModel
2020-09-17 20:09:11 +00:00
2021-03-08 16:49:10 +00:00
ConnectorFiles = models.TextChoices("ConnectorFiles", CONNECTORS)
2020-09-21 15:16:34 +00:00
class Connector(BookWyrmModel):
2021-04-26 16:15:42 +00:00
"""book data source connectors"""
2021-03-08 16:49:10 +00:00
2020-09-17 20:09:11 +00:00
identifier = models.CharField(max_length=255, unique=True)
priority = models.IntegerField(default=2)
name = models.CharField(max_length=255, null=True, blank=True)
2020-09-17 20:09:11 +00:00
local = models.BooleanField(default=False)
2021-03-08 16:49:10 +00:00
connector_file = models.CharField(max_length=255, choices=ConnectorFiles.choices)
api_key = models.CharField(max_length=255, null=True, blank=True)
2020-09-17 20:09:11 +00:00
base_url = models.CharField(max_length=255)
books_url = models.CharField(max_length=255)
covers_url = models.CharField(max_length=255)
search_url = models.CharField(max_length=255, null=True, blank=True)
2021-03-01 20:09:21 +00:00
isbn_search_url = models.CharField(max_length=255, null=True, blank=True)
2020-09-17 20:09:11 +00:00
2021-03-08 16:49:10 +00:00
politeness_delay = models.IntegerField(null=True, blank=True) # seconds
max_query_count = models.IntegerField(null=True, blank=True)
2020-09-17 20:09:11 +00:00
# how many queries executed in a unit of time, like a day
query_count = models.IntegerField(default=0)
# when to reset the query count back to 0 (ie, after 1 day)
query_count_expiry = models.DateTimeField(auto_now_add=True, blank=True)
2020-09-17 20:09:11 +00:00
def __str__(self):
return "{} ({})".format(
self.identifier,
self.id,
)