feat: implement new structure

This commit is contained in:
2025-12-29 09:30:49 +08:00
parent 503b15aab7
commit ad52371028
116 changed files with 17579 additions and 1213 deletions

View File

@@ -8,8 +8,6 @@ import (
"context"
"time"
"quyun/v2/pkg/consts"
"go.ipao.vip/gen"
)
@@ -17,15 +15,15 @@ const TableNameContentAsset = "content_assets"
// ContentAsset mapped from table <content_assets>
type ContentAsset struct {
ID int64 `gorm:"column:id;type:bigint;primaryKey;autoIncrement:true;comment:主键ID自增" json:"id"` // 主键ID自增
TenantID int64 `gorm:"column:tenant_id;type:bigint;not null;comment:租户ID多租户隔离必须与 content_id、asset_id 所属租户一致" json:"tenant_id"` // 租户ID多租户隔离必须与 content_id、asset_id 所属租户一致
UserID int64 `gorm:"column:user_id;type:bigint;not null;comment:用户ID操作人/绑定人;用于审计(通常为租户管理员或作者)" json:"user_id"` // 用户ID操作人/绑定人;用于审计(通常为租户管理员或作者)
ContentID int64 `gorm:"column:content_id;type:bigint;not null;comment:内容ID关联 contents.id用于查询内容下资源列表" json:"content_id"` // 内容ID关联 contents.id用于查询内容下资源列表
AssetID int64 `gorm:"column:asset_id;type:bigint;not null;comment:资源ID关联 media_assets.id用于查询资源归属内容" json:"asset_id"` // 资源ID关联 media_assets.id用于查询资源归属内容
Role consts.ContentAssetRole `gorm:"column:role;type:character varying(32);not null;default:main;comment:资源角色main/cover/previewpreview 必须为独立资源以满足禁下载与防绕过" json:"role"` // 资源角色main/cover/previewpreview 必须为独立资源以满足禁下载与防绕过
Sort int32 `gorm:"column:sort;type:integer;not null;comment:排序:同一 role 下的展示顺序,数值越小越靠前" json:"sort"` // 排序:同一 role 下的展示顺序,数值越小越靠前
CreatedAt time.Time `gorm:"column:created_at;type:timestamp with time zone;not null;default:now();comment:创建时间:默认 now();用于审计" json:"created_at"` // 创建时间:默认 now();用于审计
UpdatedAt time.Time `gorm:"column:updated_at;type:timestamp with time zone;not null;default:now();comment:更新时间:默认 now();更新 sort/role 时写入" json:"updated_at"` // 更新时间:默认 now();更新 sort/role 时写入
ID int64 `gorm:"column:id;type:bigint;primaryKey;autoIncrement:true" json:"id"`
TenantID int64 `gorm:"column:tenant_id;type:bigint;not null" json:"tenant_id"`
UserID int64 `gorm:"column:user_id;type:bigint;not null" json:"user_id"`
ContentID int64 `gorm:"column:content_id;type:bigint;not null" json:"content_id"`
AssetID int64 `gorm:"column:asset_id;type:bigint;not null" json:"asset_id"`
Role string `gorm:"column:role;type:character varying(32);default:main" json:"role"`
Sort int32 `gorm:"column:sort;type:integer" json:"sort"`
CreatedAt time.Time `gorm:"column:created_at;type:timestamp with time zone;default:now()" json:"created_at"`
UpdatedAt time.Time `gorm:"column:updated_at;type:timestamp with time zone;default:now()" json:"updated_at"`
}
// Quick operations without importing query package