528 lines
20 KiB
Python
528 lines
20 KiB
Python
# Generated by Django 3.2.16 on 2023-01-12 01:32
|
|
|
|
import uuid
|
|
|
|
import django.db.models.deletion
|
|
import simple_history.models
|
|
from django.db import migrations, models
|
|
|
|
import catalog.common.mixins
|
|
import catalog.common.utils
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
initial = True
|
|
|
|
dependencies = []
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name="ExternalResource",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
(
|
|
"id_type",
|
|
models.CharField(
|
|
choices=[
|
|
("wikidata", "维基数据"),
|
|
("isbn10", "ISBN10"),
|
|
("isbn", "ISBN"),
|
|
("asin", "ASIN"),
|
|
("issn", "ISSN"),
|
|
("cubn", "统一书号"),
|
|
("isrc", "ISRC"),
|
|
("gtin", "GTIN UPC EAN码"),
|
|
("feed", "Feed URL"),
|
|
("imdb", "IMDb"),
|
|
("tmdb_tv", "TMDB剧集"),
|
|
("tmdb_tvseason", "TMDB剧集"),
|
|
("tmdb_tvepisode", "TMDB剧集"),
|
|
("tmdb_movie", "TMDB电影"),
|
|
("goodreads", "Goodreads"),
|
|
("goodreads_work", "Goodreads著作"),
|
|
("googlebooks", "谷歌图书"),
|
|
("doubanbook", "豆瓣读书"),
|
|
("doubanbook_work", "豆瓣读书著作"),
|
|
("doubanmovie", "豆瓣电影"),
|
|
("doubanmusic", "豆瓣音乐"),
|
|
("doubangame", "豆瓣游戏"),
|
|
("doubandrama", "豆瓣舞台剧"),
|
|
("bandcamp", "Bandcamp"),
|
|
("spotify_album", "Spotify专辑"),
|
|
("spotify_show", "Spotify播客"),
|
|
("discogs_release", "Discogs Release"),
|
|
("discogs_master", "Discogs Master"),
|
|
("musicbrainz", "MusicBrainz ID"),
|
|
("doubanbook_author", "豆瓣读书作者"),
|
|
("doubanmovie_celebrity", "豆瓣电影影人"),
|
|
("goodreads_author", "Goodreads作者"),
|
|
("spotify_artist", "Spotify艺术家"),
|
|
("tmdb_person", "TMDB影人"),
|
|
("igdb", "IGDB游戏"),
|
|
("steam", "Steam游戏"),
|
|
("bangumi", "Bangumi"),
|
|
("apple_podcast", "苹果播客"),
|
|
],
|
|
max_length=50,
|
|
verbose_name="IdType of the source site",
|
|
),
|
|
),
|
|
(
|
|
"id_value",
|
|
models.CharField(
|
|
max_length=1000, verbose_name="Primary Id on the source site"
|
|
),
|
|
),
|
|
(
|
|
"url",
|
|
models.CharField(
|
|
max_length=1000, unique=True, verbose_name="url to the resource"
|
|
),
|
|
),
|
|
(
|
|
"cover",
|
|
models.ImageField(
|
|
blank=True,
|
|
default="item/default.svg",
|
|
upload_to=catalog.common.utils.resource_cover_path,
|
|
),
|
|
),
|
|
("other_lookup_ids", models.JSONField(default=dict)),
|
|
("metadata", models.JSONField(default=dict)),
|
|
("scraped_time", models.DateTimeField(null=True)),
|
|
("created_time", models.DateTimeField(auto_now_add=True)),
|
|
("edited_time", models.DateTimeField(auto_now=True)),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="HistoricalItem",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigIntegerField(
|
|
auto_created=True, blank=True, db_index=True, verbose_name="ID"
|
|
),
|
|
),
|
|
(
|
|
"uid",
|
|
models.UUIDField(db_index=True, default=uuid.uuid4, editable=False),
|
|
),
|
|
(
|
|
"title",
|
|
models.CharField(default="", max_length=1000, verbose_name="标题"),
|
|
),
|
|
("brief", models.TextField(blank=True, default="", verbose_name="简介")),
|
|
(
|
|
"primary_lookup_id_type",
|
|
models.CharField(max_length=50, null=True, verbose_name="主要标识类型"),
|
|
),
|
|
(
|
|
"primary_lookup_id_value",
|
|
models.CharField(max_length=1000, null=True, verbose_name="主要标识数值"),
|
|
),
|
|
(
|
|
"metadata",
|
|
models.JSONField(
|
|
blank=True, default=dict, null=True, verbose_name="其它信息"
|
|
),
|
|
),
|
|
(
|
|
"cover",
|
|
models.TextField(
|
|
blank=True,
|
|
default="item/default.svg",
|
|
max_length=100,
|
|
verbose_name="封面",
|
|
),
|
|
),
|
|
("created_time", models.DateTimeField(blank=True, editable=False)),
|
|
("edited_time", models.DateTimeField(blank=True, editable=False)),
|
|
("is_deleted", models.BooleanField(db_index=True, default=False)),
|
|
("history_id", models.AutoField(primary_key=True, serialize=False)),
|
|
("history_date", models.DateTimeField(db_index=True)),
|
|
("history_change_reason", models.CharField(max_length=100, null=True)),
|
|
(
|
|
"history_type",
|
|
models.CharField(
|
|
choices=[("+", "Created"), ("~", "Changed"), ("-", "Deleted")],
|
|
max_length=1,
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"verbose_name": "historical item",
|
|
"verbose_name_plural": "historical items",
|
|
"ordering": ("-history_date", "-history_id"),
|
|
"get_latest_by": ("history_date", "history_id"),
|
|
},
|
|
bases=(simple_history.models.HistoricalChanges, models.Model),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Item",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
(
|
|
"uid",
|
|
models.UUIDField(db_index=True, default=uuid.uuid4, editable=False),
|
|
),
|
|
(
|
|
"title",
|
|
models.CharField(default="", max_length=1000, verbose_name="标题"),
|
|
),
|
|
("brief", models.TextField(blank=True, default="", verbose_name="简介")),
|
|
(
|
|
"primary_lookup_id_type",
|
|
models.CharField(max_length=50, null=True, verbose_name="主要标识类型"),
|
|
),
|
|
(
|
|
"primary_lookup_id_value",
|
|
models.CharField(max_length=1000, null=True, verbose_name="主要标识数值"),
|
|
),
|
|
(
|
|
"metadata",
|
|
models.JSONField(
|
|
blank=True, default=dict, null=True, verbose_name="其它信息"
|
|
),
|
|
),
|
|
(
|
|
"cover",
|
|
models.ImageField(
|
|
blank=True,
|
|
default="item/default.svg",
|
|
upload_to=catalog.common.utils.item_cover_path,
|
|
verbose_name="封面",
|
|
),
|
|
),
|
|
("created_time", models.DateTimeField(auto_now_add=True)),
|
|
("edited_time", models.DateTimeField(auto_now=True)),
|
|
("is_deleted", models.BooleanField(db_index=True, default=False)),
|
|
],
|
|
bases=(catalog.common.mixins.SoftDeleteMixin, models.Model),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Album",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Collection",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Edition",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Game",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Movie",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Podcast",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="TVEpisode",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
("episode_number", models.PositiveIntegerField(null=True)),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="TVSeason",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
(
|
|
"season_number",
|
|
models.PositiveIntegerField(null=True, verbose_name="本季序号"),
|
|
),
|
|
(
|
|
"episode_count",
|
|
models.PositiveIntegerField(null=True, verbose_name="本季集数"),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="TVShow",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
(
|
|
"season_count",
|
|
models.IntegerField(blank=True, null=True, verbose_name="总季数"),
|
|
),
|
|
(
|
|
"episode_count",
|
|
models.PositiveIntegerField(
|
|
blank=True, null=True, verbose_name="总集数"
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="Work",
|
|
fields=[
|
|
(
|
|
"item_ptr",
|
|
models.OneToOneField(
|
|
auto_created=True,
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
parent_link=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"abstract": False,
|
|
"base_manager_name": "objects",
|
|
},
|
|
bases=("catalog.item",),
|
|
),
|
|
migrations.CreateModel(
|
|
name="ItemLookupId",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
(
|
|
"id_type",
|
|
models.CharField(
|
|
blank=True,
|
|
choices=[
|
|
("wikidata", "维基数据"),
|
|
("isbn10", "ISBN10"),
|
|
("isbn", "ISBN"),
|
|
("asin", "ASIN"),
|
|
("issn", "ISSN"),
|
|
("cubn", "统一书号"),
|
|
("isrc", "ISRC"),
|
|
("gtin", "GTIN UPC EAN码"),
|
|
("feed", "Feed URL"),
|
|
("imdb", "IMDb"),
|
|
("tmdb_tv", "TMDB剧集"),
|
|
("tmdb_tvseason", "TMDB剧集"),
|
|
("tmdb_tvepisode", "TMDB剧集"),
|
|
("tmdb_movie", "TMDB电影"),
|
|
("goodreads", "Goodreads"),
|
|
("goodreads_work", "Goodreads著作"),
|
|
("googlebooks", "谷歌图书"),
|
|
("doubanbook", "豆瓣读书"),
|
|
("doubanbook_work", "豆瓣读书著作"),
|
|
("doubanmovie", "豆瓣电影"),
|
|
("doubanmusic", "豆瓣音乐"),
|
|
("doubangame", "豆瓣游戏"),
|
|
("doubandrama", "豆瓣舞台剧"),
|
|
("bandcamp", "Bandcamp"),
|
|
("spotify_album", "Spotify专辑"),
|
|
("spotify_show", "Spotify播客"),
|
|
("discogs_release", "Discogs Release"),
|
|
("discogs_master", "Discogs Master"),
|
|
("musicbrainz", "MusicBrainz ID"),
|
|
("doubanbook_author", "豆瓣读书作者"),
|
|
("doubanmovie_celebrity", "豆瓣电影影人"),
|
|
("goodreads_author", "Goodreads作者"),
|
|
("spotify_artist", "Spotify艺术家"),
|
|
("tmdb_person", "TMDB影人"),
|
|
("igdb", "IGDB游戏"),
|
|
("steam", "Steam游戏"),
|
|
("bangumi", "Bangumi"),
|
|
("apple_podcast", "苹果播客"),
|
|
],
|
|
max_length=50,
|
|
verbose_name="源网站",
|
|
),
|
|
),
|
|
(
|
|
"id_value",
|
|
models.CharField(blank=True, max_length=1000, verbose_name="源网站ID"),
|
|
),
|
|
(
|
|
"raw_url",
|
|
models.CharField(
|
|
blank=True, max_length=1000, unique=True, verbose_name="源网站ID"
|
|
),
|
|
),
|
|
(
|
|
"item",
|
|
models.ForeignKey(
|
|
null=True,
|
|
on_delete=django.db.models.deletion.SET_NULL,
|
|
related_name="lookup_ids",
|
|
to="catalog.item",
|
|
),
|
|
),
|
|
],
|
|
),
|
|
]
|