2.0
This commit is contained in:
@@ -1,16 +1,225 @@
|
||||
# Generated by Django 5.0.7 on 2024-07-16 15:57
|
||||
# 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
|
||||
from datetime import datetime
|
||||
import django.utils.timezone
|
||||
from django.conf import settings
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
initial = True
|
||||
|
||||
dependencies = []
|
||||
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=[
|
||||
@@ -23,26 +232,84 @@ class Migration(migrations.Migration):
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("username", models.CharField(max_length=150, unique=True)),
|
||||
("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, null=True, unique=True
|
||||
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),
|
||||
),
|
||||
(
|
||||
"password_hash",
|
||||
models.CharField(blank=True, max_length=128, null=True),
|
||||
),
|
||||
(
|
||||
"google_id",
|
||||
models.CharField(blank=True, max_length=50, null=True, unique=True),
|
||||
),
|
||||
("is_active", models.BooleanField(default=True)),
|
||||
("is_member", models.BooleanField(default=False)),
|
||||
("points", models.IntegerField(default=0)),
|
||||
("referral_code", models.CharField(max_length=50, unique=True)),
|
||||
@@ -50,8 +317,30 @@ class Migration(migrations.Migration):
|
||||
"commission_rate",
|
||||
models.DecimalField(decimal_places=2, default=0.0, max_digits=5),
|
||||
),
|
||||
("created_at", models.DateTimeField(default=datetime.now)),
|
||||
("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(
|
||||
@@ -59,13 +348,32 @@ class Migration(migrations.Migration):
|
||||
null=True,
|
||||
on_delete=django.db.models.deletion.SET_NULL,
|
||||
related_name="invitees",
|
||||
to="WebAdmin.user",
|
||||
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="Referral",
|
||||
name="VideoGeneration",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
@@ -76,25 +384,42 @@ class Migration(migrations.Migration):
|
||||
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)),
|
||||
(
|
||||
"commission_amount",
|
||||
models.DecimalField(decimal_places=2, max_digits=10),
|
||||
"style",
|
||||
models.CharField(default="general", max_length=50, null=True),
|
||||
),
|
||||
("created_at", models.DateTimeField(default=datetime.now)),
|
||||
("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)),
|
||||
(
|
||||
"referee",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="referrals_received",
|
||||
to="WebAdmin.user",
|
||||
"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)),
|
||||
(
|
||||
"referrer",
|
||||
"user",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="referrals_made",
|
||||
to="WebAdmin.user",
|
||||
to=settings.AUTH_USER_MODEL,
|
||||
),
|
||||
),
|
||||
],
|
||||
@@ -112,13 +437,170 @@ class Migration(migrations.Migration):
|
||||
),
|
||||
),
|
||||
("source", models.CharField(max_length=50)),
|
||||
("created_at", models.DateTimeField(default=datetime.now)),
|
||||
("created_at", models.DateTimeField(default=datetime.datetime.now)),
|
||||
(
|
||||
"user",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE, to="WebAdmin.user"
|
||||
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"],
|
||||
},
|
||||
),
|
||||
]
|
||||
|
||||
Reference in New Issue
Block a user