607 lines
24 KiB
Python
Executable File
607 lines
24 KiB
Python
Executable File
# Generated by Django 5.0.7 on 2024-09-23 22:59
|
|
|
|
import datetime
|
|
import django.contrib.auth.models
|
|
import django.contrib.auth.validators
|
|
import django.db.models.deletion
|
|
import django.utils.timezone
|
|
from django.conf import settings
|
|
from django.db import migrations, models
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
initial = True
|
|
|
|
dependencies = [
|
|
("auth", "0012_alter_user_first_name_max_length"),
|
|
]
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name="Article",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("chinese_title", models.CharField(max_length=255)),
|
|
("english_title", models.CharField(max_length=255)),
|
|
("chinese_keywords", models.TextField()),
|
|
("english_keywords", models.TextField()),
|
|
("chinese_content", models.TextField()),
|
|
("english_content", models.TextField()),
|
|
("source_url", models.URLField(blank=True, null=True)),
|
|
("published_at", models.DateTimeField(blank=True, null=True)),
|
|
("image_url", models.URLField(blank=True, null=True)),
|
|
(
|
|
"status",
|
|
models.CharField(
|
|
choices=[("published", "已发布"), ("pending", "待审核")],
|
|
default="draft",
|
|
max_length=10,
|
|
),
|
|
),
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
|
],
|
|
options={
|
|
"verbose_name": "Article",
|
|
"verbose_name_plural": "Article",
|
|
"ordering": ["-created_at"],
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name="EmailVerificationCode",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("email", models.EmailField(max_length=254)),
|
|
("code", models.CharField(max_length=6)),
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
|
("is_used", models.BooleanField(default=False)),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="Plan",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("title", models.CharField(max_length=100, unique=True)),
|
|
("description", models.TextField()),
|
|
("price", models.DecimalField(decimal_places=2, max_digits=10)),
|
|
("credits_per_month", models.IntegerField(default=0)),
|
|
("created_at", models.DateTimeField(default=datetime.datetime.now)),
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
|
("is_promotional", models.BooleanField(default=False)),
|
|
("unlimited_exports", models.BooleanField(default=False)),
|
|
("smart_music_sync", models.BooleanField(default=False)),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="SMSVerificationCode",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("phone_number", models.CharField(max_length=15)),
|
|
("code", models.CharField(max_length=6)),
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
|
("is_used", models.BooleanField(default=False)),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="WebsiteInfo",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
(
|
|
"domain_en",
|
|
models.CharField(default=True, max_length=255, verbose_name="域名"),
|
|
),
|
|
(
|
|
"domain_zh",
|
|
models.CharField(default=True, max_length=255, verbose_name="域名"),
|
|
),
|
|
(
|
|
"title_en",
|
|
models.CharField(default=True, max_length=255, verbose_name="英文标题"),
|
|
),
|
|
(
|
|
"title_zh",
|
|
models.CharField(default=True, max_length=255, verbose_name="中文标题"),
|
|
),
|
|
("keywords_en", models.TextField(default=True, verbose_name="英文关键词")),
|
|
("keywords_zh", models.TextField(default=True, verbose_name="中文关键词")),
|
|
("description_en", models.TextField(default=True, verbose_name="英文描述")),
|
|
("description_zh", models.TextField(default=True, verbose_name="中文描述")),
|
|
(
|
|
"created_at",
|
|
models.DateTimeField(auto_now_add=True, verbose_name="创建时间"),
|
|
),
|
|
(
|
|
"updated_at",
|
|
models.DateTimeField(auto_now=True, verbose_name="更新时间"),
|
|
),
|
|
],
|
|
options={
|
|
"verbose_name": "网站信息",
|
|
"verbose_name_plural": "网站信息",
|
|
"db_table": "website_info",
|
|
"ordering": ["-created_at"],
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name="WebsiteAccessLog",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("ip_address", models.GenericIPAddressField(verbose_name="访问IP")),
|
|
(
|
|
"browser_language",
|
|
models.CharField(
|
|
blank=True, max_length=200, null=True, verbose_name="浏览器语言"
|
|
),
|
|
),
|
|
(
|
|
"referrer",
|
|
models.TextField(blank=True, null=True, verbose_name="来源URL"),
|
|
),
|
|
("request_path", models.CharField(max_length=255, verbose_name="请求路径")),
|
|
(
|
|
"request_method",
|
|
models.CharField(max_length=10, verbose_name="请求方法"),
|
|
),
|
|
(
|
|
"user_agent",
|
|
models.TextField(blank=True, null=True, verbose_name="用户代理"),
|
|
),
|
|
(
|
|
"device_type",
|
|
models.CharField(
|
|
blank=True, max_length=50, null=True, verbose_name="设备类型"
|
|
),
|
|
),
|
|
(
|
|
"access_time",
|
|
models.DateTimeField(auto_now_add=True, verbose_name="访问时间"),
|
|
),
|
|
(
|
|
"access_time_bj",
|
|
models.DateTimeField(blank=True, null=True, verbose_name="北京时间"),
|
|
),
|
|
(
|
|
"access_date",
|
|
models.DateField(blank=True, null=True, verbose_name="访问日期"),
|
|
),
|
|
],
|
|
options={
|
|
"verbose_name": "网站访问日志",
|
|
"verbose_name_plural": "网站访问日志",
|
|
"db_table": "website_access_log",
|
|
"unique_together": {("ip_address", "access_date")},
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name="User",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("password", models.CharField(max_length=128, verbose_name="password")),
|
|
(
|
|
"last_login",
|
|
models.DateTimeField(
|
|
blank=True, null=True, verbose_name="last login"
|
|
),
|
|
),
|
|
(
|
|
"is_superuser",
|
|
models.BooleanField(
|
|
default=False,
|
|
help_text="Designates that this user has all permissions without explicitly assigning them.",
|
|
verbose_name="superuser status",
|
|
),
|
|
),
|
|
(
|
|
"username",
|
|
models.CharField(
|
|
error_messages={
|
|
"unique": "A user with that username already exists."
|
|
},
|
|
help_text="Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.",
|
|
max_length=150,
|
|
unique=True,
|
|
validators=[
|
|
django.contrib.auth.validators.UnicodeUsernameValidator()
|
|
],
|
|
verbose_name="username",
|
|
),
|
|
),
|
|
(
|
|
"first_name",
|
|
models.CharField(
|
|
blank=True, max_length=150, verbose_name="first name"
|
|
),
|
|
),
|
|
(
|
|
"last_name",
|
|
models.CharField(
|
|
blank=True, max_length=150, verbose_name="last name"
|
|
),
|
|
),
|
|
(
|
|
"email",
|
|
models.EmailField(
|
|
blank=True, max_length=254, verbose_name="email address"
|
|
),
|
|
),
|
|
(
|
|
"is_staff",
|
|
models.BooleanField(
|
|
default=False,
|
|
help_text="Designates whether the user can log into this admin site.",
|
|
verbose_name="staff status",
|
|
),
|
|
),
|
|
(
|
|
"is_active",
|
|
models.BooleanField(
|
|
default=True,
|
|
help_text="Designates whether this user should be treated as active. Unselect this instead of deleting accounts.",
|
|
verbose_name="active",
|
|
),
|
|
),
|
|
(
|
|
"date_joined",
|
|
models.DateTimeField(
|
|
default=django.utils.timezone.now, verbose_name="date joined"
|
|
),
|
|
),
|
|
(
|
|
"phone",
|
|
models.CharField(blank=True, max_length=20, null=True, unique=True),
|
|
),
|
|
(
|
|
"google_id",
|
|
models.CharField(blank=True, max_length=50, null=True, unique=True),
|
|
),
|
|
("is_member", models.BooleanField(default=False)),
|
|
("points", models.IntegerField(default=0)),
|
|
("referral_code", models.CharField(max_length=50, unique=True)),
|
|
(
|
|
"commission_rate",
|
|
models.DecimalField(decimal_places=2, default=0.0, max_digits=5),
|
|
),
|
|
("created_at", models.DateTimeField(default=datetime.datetime.now)),
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
|
("login_count", models.IntegerField(default=0)),
|
|
("last_login_ip", models.GenericIPAddressField(blank=True, null=True)),
|
|
("membership_start", models.DateTimeField(blank=True, null=True)),
|
|
("membership_end", models.DateTimeField(blank=True, null=True)),
|
|
(
|
|
"openid_used",
|
|
models.CharField(
|
|
blank=True, max_length=150, null=True, unique=True
|
|
),
|
|
),
|
|
("source", models.CharField(default="web", max_length=50)),
|
|
(
|
|
"groups",
|
|
models.ManyToManyField(
|
|
blank=True,
|
|
help_text="The groups this user belongs to. A user will get all permissions granted to each of their groups.",
|
|
related_name="user_set",
|
|
related_query_name="user",
|
|
to="auth.group",
|
|
verbose_name="groups",
|
|
),
|
|
),
|
|
(
|
|
"invited_by",
|
|
models.ForeignKey(
|
|
blank=True,
|
|
null=True,
|
|
on_delete=django.db.models.deletion.SET_NULL,
|
|
related_name="invitees",
|
|
to=settings.AUTH_USER_MODEL,
|
|
),
|
|
),
|
|
(
|
|
"user_permissions",
|
|
models.ManyToManyField(
|
|
blank=True,
|
|
help_text="Specific permissions for this user.",
|
|
related_name="user_set",
|
|
related_query_name="user",
|
|
to="auth.permission",
|
|
verbose_name="user permissions",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"verbose_name": "user",
|
|
"verbose_name_plural": "users",
|
|
"abstract": False,
|
|
},
|
|
managers=[
|
|
("objects", django.contrib.auth.models.UserManager()),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="VideoGeneration",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("video_id", models.CharField(default="", max_length=255)),
|
|
("text", models.TextField(null=True)),
|
|
("voice_name", models.CharField(max_length=50, null=True)),
|
|
(
|
|
"style",
|
|
models.CharField(default="general", max_length=50, null=True),
|
|
),
|
|
("rate", models.IntegerField(default=0, null=True)),
|
|
("media_type", models.CharField(max_length=50, null=True)),
|
|
("ratio", models.CharField(max_length=10)),
|
|
("audio_url", models.URLField(blank=True, null=True)),
|
|
("video_url", models.URLField(blank=True, null=True)),
|
|
(
|
|
"status",
|
|
models.CharField(
|
|
choices=[
|
|
("pending", "Pending"),
|
|
("in_progress", "In Progress"),
|
|
("completed", "Completed"),
|
|
("failed", "Failed"),
|
|
],
|
|
default="pending",
|
|
max_length=20,
|
|
),
|
|
),
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
|
("slug", models.CharField(max_length=50)),
|
|
("pid", models.CharField(default="", max_length=50, null=True)),
|
|
("extension_count", models.IntegerField(default=0)),
|
|
("time_duration", models.IntegerField(default=0)),
|
|
(
|
|
"user",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
to=settings.AUTH_USER_MODEL,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="UserSource",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("source", models.CharField(max_length=50)),
|
|
("created_at", models.DateTimeField(default=datetime.datetime.now)),
|
|
(
|
|
"user",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
to=settings.AUTH_USER_MODEL,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="TransactionHistory",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
(
|
|
"feature",
|
|
models.CharField(
|
|
choices=[
|
|
("text-to-video", "AI文生视频"),
|
|
("img-to-video", "AI图生视频"),
|
|
("create-tiktok-video", "AI长视频生成"),
|
|
("music-to-video", "音乐视频生成"),
|
|
("create-avatar-video", "虚拟形象视频生成"),
|
|
],
|
|
max_length=50,
|
|
verbose_name="功能类型",
|
|
),
|
|
),
|
|
("points_spent", models.IntegerField(verbose_name="消费积分")),
|
|
(
|
|
"char_count",
|
|
models.IntegerField(blank=True, null=True, verbose_name="字符数量"),
|
|
),
|
|
(
|
|
"description",
|
|
models.TextField(blank=True, null=True, verbose_name="操作描述"),
|
|
),
|
|
(
|
|
"transaction_date",
|
|
models.DateTimeField(
|
|
default=datetime.datetime.now, verbose_name="消费时间"
|
|
),
|
|
),
|
|
("previous_points_balance", models.IntegerField(verbose_name="消费前积分")),
|
|
("new_points_balance", models.IntegerField(verbose_name="消费后积分")),
|
|
("success", models.BooleanField(default=True, verbose_name="是否成功")),
|
|
(
|
|
"user",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
related_name="transactions",
|
|
to=settings.AUTH_USER_MODEL,
|
|
verbose_name="用户",
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"verbose_name": "消费明细",
|
|
"verbose_name_plural": "消费明细",
|
|
"db_table": "transaction_history",
|
|
"ordering": ["-transaction_date"],
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name="Referral",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
(
|
|
"commission_amount",
|
|
models.DecimalField(decimal_places=2, max_digits=10),
|
|
),
|
|
("created_at", models.DateTimeField(default=datetime.datetime.now)),
|
|
(
|
|
"referee",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
related_name="referrals_received",
|
|
to=settings.AUTH_USER_MODEL,
|
|
),
|
|
),
|
|
(
|
|
"referrer",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
related_name="referrals_made",
|
|
to=settings.AUTH_USER_MODEL,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name="Order",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.BigAutoField(
|
|
auto_created=True,
|
|
primary_key=True,
|
|
serialize=False,
|
|
verbose_name="ID",
|
|
),
|
|
),
|
|
("order_id", models.CharField(max_length=100, unique=True)),
|
|
("username", models.CharField(max_length=150)),
|
|
(
|
|
"amount",
|
|
models.DecimalField(decimal_places=2, default=0.0, max_digits=10),
|
|
),
|
|
(
|
|
"payment_method",
|
|
models.CharField(
|
|
choices=[("alipay", "Alipay"), ("paypal", "PayPal")],
|
|
max_length=10,
|
|
),
|
|
),
|
|
(
|
|
"status",
|
|
models.CharField(
|
|
choices=[
|
|
("pending", "Pending"),
|
|
("completed", "Completed"),
|
|
("canceled", "Canceled"),
|
|
("failed", "Failed"),
|
|
],
|
|
default="pending",
|
|
max_length=10,
|
|
),
|
|
),
|
|
("created_at", models.DateTimeField(default=datetime.datetime.now)),
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
|
(
|
|
"plan",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE, to="WebAdmin.plan"
|
|
),
|
|
),
|
|
(
|
|
"user",
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
to=settings.AUTH_USER_MODEL,
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
"verbose_name": "Order",
|
|
"verbose_name_plural": "Orders",
|
|
"ordering": ["-created_at"],
|
|
},
|
|
),
|
|
]
|