|
|
|
package migration
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"gofaster/internal/auth/model"
|
|
|
|
"gofaster/internal/auth/repository"
|
|
|
|
"gofaster/internal/shared/logger"
|
|
|
|
|
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
|
|
|
|
|
|
|
// RunMigrations 运行数据库迁移
|
|
|
|
func RunMigrations(db *gorm.DB) error {
|
|
|
|
log := logger.NewLogger("info", "")
|
|
|
|
defer log.Sync()
|
|
|
|
// 自动迁移用户表
|
|
|
|
if err := db.AutoMigrate(&model.User{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 手动检查并添加可能缺失的字段
|
|
|
|
if err := ensureUserFields(db); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 自动迁移角色表
|
|
|
|
if err := db.AutoMigrate(&model.Role{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 自动迁移用户角色关联表
|
|
|
|
if err := db.AutoMigrate(&model.UserRole{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 自动迁移验证码表
|
|
|
|
if err := db.AutoMigrate(&repository.Captcha{}); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 自动迁移密码策略相关表
|
|
|
|
if err := db.AutoMigrate(
|
|
|
|
&model.PasswordPolicy{},
|
|
|
|
&model.PasswordHistory{},
|
|
|
|
&model.PasswordReset{},
|
|
|
|
); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 自动迁移资源相关表
|
|
|
|
if err := db.AutoMigrate(
|
|
|
|
&model.Resource{},
|
|
|
|
&model.ResourcePermission{},
|
|
|
|
); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 自动迁移权限相关表
|
|
|
|
if err := db.AutoMigrate(
|
|
|
|
&model.Permission{},
|
|
|
|
&model.RolePermission{},
|
|
|
|
); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 为权限表添加code字段
|
|
|
|
if err := AddPermissionCodeField(db); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建路由相关表
|
|
|
|
if err := CreateRouteTables(db, log); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 移除相关表的 delete_at 字段
|
|
|
|
if err := RemoveDeleteAtFields(db, log); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 为 frontend_backend_routes 表添加唯一索引
|
|
|
|
if err := AddUniqueIndexToFrontendBackendRoutes(db, log); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建默认角色
|
|
|
|
if err := createDefaultRoles(db); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建默认管理员用户
|
|
|
|
if err := createDefaultAdmin(db); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建默认密码策略
|
|
|
|
if err := createDefaultPasswordPolicy(db); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建默认权限
|
|
|
|
if err := createDefaultPermissions(db); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ensureUserFields 确保用户表有必要的字段
|
|
|
|
func ensureUserFields(db *gorm.DB) error {
|
|
|
|
// 检查PasswordChangedAt字段是否存在
|
|
|
|
if !db.Migrator().HasColumn(&model.User{}, "password_changed_at") {
|
|
|
|
fmt.Println("添加 password_changed_at 字段到 users 表")
|
|
|
|
if err := db.Exec("ALTER TABLE users ADD COLUMN password_changed_at TIMESTAMP NULL").Error; err != nil {
|
|
|
|
return fmt.Errorf("添加 password_changed_at 字段失败: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 检查ForceChangePassword字段是否存在
|
|
|
|
if !db.Migrator().HasColumn(&model.User{}, "force_change_password") {
|
|
|
|
fmt.Println("添加 force_change_password 字段到 users 表")
|
|
|
|
if err := db.Exec("ALTER TABLE users ADD COLUMN force_change_password BOOLEAN DEFAULT FALSE").Error; err != nil {
|
|
|
|
return fmt.Errorf("添加 force_change_password 字段失败: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Println("用户表字段检查完成")
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// createDefaultRoles 创建默认角色
|
|
|
|
func createDefaultRoles(db *gorm.DB) error {
|
|
|
|
// 检查是否已存在角色
|
|
|
|
var count int64
|
|
|
|
db.Model(&model.Role{}).Count(&count)
|
|
|
|
if count > 0 {
|
|
|
|
return nil // 已存在角色,跳过
|
|
|
|
}
|
|
|
|
|
|
|
|
roles := []model.Role{
|
|
|
|
{
|
|
|
|
Name: "超级管理员",
|
|
|
|
Code: "SUPER_ADMIN",
|
|
|
|
Description: "系统超级管理员,拥有所有权限",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "管理员",
|
|
|
|
Code: "ADMIN",
|
|
|
|
Description: "系统管理员,拥有大部分权限",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "普通用户",
|
|
|
|
Code: "USER",
|
|
|
|
Description: "普通用户,拥有基本权限",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, role := range roles {
|
|
|
|
if err := db.Create(&role).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// createDefaultAdmin 创建默认管理员用户
|
|
|
|
func createDefaultAdmin(db *gorm.DB) error {
|
|
|
|
// 检查是否已存在管理员用户
|
|
|
|
var count int64
|
|
|
|
db.Model(&model.User{}).Where("username = ?", "admin").Count(&count)
|
|
|
|
if count > 0 {
|
|
|
|
return nil // 已存在管理员用户,跳过
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建默认管理员用户
|
|
|
|
adminUser := &model.User{
|
|
|
|
Username: "admin",
|
|
|
|
Password: "$2a$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi", // "password"
|
|
|
|
Email: "admin@gofaster.com",
|
|
|
|
Phone: "13800138000",
|
|
|
|
Status: 1, // 正常状态
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := db.Create(adminUser).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 获取超级管理员角色
|
|
|
|
var superAdminRole model.Role
|
|
|
|
if err := db.Where("code = ?", "SUPER_ADMIN").First(&superAdminRole).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// 关联超级管理员角色
|
|
|
|
if err := db.Model(adminUser).Association("Roles").Append(&superAdminRole); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// createDefaultPasswordPolicy 创建默认密码策略
|
|
|
|
func createDefaultPasswordPolicy(db *gorm.DB) error {
|
|
|
|
// 检查是否已存在默认策略
|
|
|
|
var count int64
|
|
|
|
db.Model(&model.PasswordPolicy{}).Count(&count)
|
|
|
|
if count > 0 {
|
|
|
|
return nil // 已存在默认策略,跳过
|
|
|
|
}
|
|
|
|
|
|
|
|
// 创建默认密码策略(1级)
|
|
|
|
defaultPolicy := &model.PasswordPolicy{
|
|
|
|
Level: 1,
|
|
|
|
MinRequiredLevel: 1, // 新增:要求最低1级强度
|
|
|
|
MinLength: 6,
|
|
|
|
RequireUppercase: false,
|
|
|
|
RequireLowercase: false,
|
|
|
|
RequireNumbers: false,
|
|
|
|
RequireSpecial: false,
|
|
|
|
MinCharTypes: 1,
|
|
|
|
ExpirationDays: 30,
|
|
|
|
PreventReuse: 3,
|
|
|
|
IsActive: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := db.Create(defaultPolicy).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// createDefaultPermissions 创建默认权限
|
|
|
|
func createDefaultPermissions(db *gorm.DB) error {
|
|
|
|
// 检查是否已存在权限
|
|
|
|
var count int64
|
|
|
|
db.Model(&model.Permission{}).Count(&count)
|
|
|
|
if count > 0 {
|
|
|
|
return nil // 已存在权限,跳过
|
|
|
|
}
|
|
|
|
|
|
|
|
permissions := []model.Permission{
|
|
|
|
// 用户管理权限
|
|
|
|
{
|
|
|
|
Name: "查看用户列表",
|
|
|
|
Code: "user:list",
|
|
|
|
Description: "查看系统用户列表",
|
|
|
|
Resource: "user",
|
|
|
|
Action: "list",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "创建用户",
|
|
|
|
Code: "user:create",
|
|
|
|
Description: "创建新用户",
|
|
|
|
Resource: "user",
|
|
|
|
Action: "create",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "编辑用户",
|
|
|
|
Code: "user:update",
|
|
|
|
Description: "编辑用户信息",
|
|
|
|
Resource: "user",
|
|
|
|
Action: "update",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "删除用户",
|
|
|
|
Code: "user:delete",
|
|
|
|
Description: "删除用户",
|
|
|
|
Resource: "user",
|
|
|
|
Action: "delete",
|
|
|
|
},
|
|
|
|
// 角色管理权限
|
|
|
|
{
|
|
|
|
Name: "查看角色列表",
|
|
|
|
Code: "role:list",
|
|
|
|
Description: "查看系统角色列表",
|
|
|
|
Resource: "role",
|
|
|
|
Action: "list",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "创建角色",
|
|
|
|
Code: "role:create",
|
|
|
|
Description: "创建新角色",
|
|
|
|
Resource: "role",
|
|
|
|
Action: "create",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "编辑角色",
|
|
|
|
Code: "role:update",
|
|
|
|
Description: "编辑角色信息",
|
|
|
|
Resource: "role",
|
|
|
|
Action: "update",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "删除角色",
|
|
|
|
Code: "role:delete",
|
|
|
|
Description: "删除角色",
|
|
|
|
Resource: "role",
|
|
|
|
Action: "delete",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "分配角色权限",
|
|
|
|
Code: "role:assign_permissions",
|
|
|
|
Description: "为角色分配权限",
|
|
|
|
Resource: "role",
|
|
|
|
Action: "assign_permissions",
|
|
|
|
},
|
|
|
|
// 权限管理权限
|
|
|
|
{
|
|
|
|
Name: "查看权限列表",
|
|
|
|
Code: "permission:list",
|
|
|
|
Description: "查看系统权限列表",
|
|
|
|
Resource: "permission",
|
|
|
|
Action: "list",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "创建权限",
|
|
|
|
Code: "permission:create",
|
|
|
|
Description: "创建新权限",
|
|
|
|
Resource: "permission",
|
|
|
|
Action: "create",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "编辑权限",
|
|
|
|
Code: "permission:update",
|
|
|
|
Description: "编辑权限信息",
|
|
|
|
Resource: "permission",
|
|
|
|
Action: "update",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "删除权限",
|
|
|
|
Code: "permission:delete",
|
|
|
|
Description: "删除权限",
|
|
|
|
Resource: "permission",
|
|
|
|
Action: "delete",
|
|
|
|
},
|
|
|
|
// 系统管理权限
|
|
|
|
{
|
|
|
|
Name: "系统设置",
|
|
|
|
Code: "system:settings",
|
|
|
|
Description: "管理系统设置",
|
|
|
|
Resource: "system",
|
|
|
|
Action: "settings",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "查看系统日志",
|
|
|
|
Code: "system:logs",
|
|
|
|
Description: "查看系统日志",
|
|
|
|
Resource: "system",
|
|
|
|
Action: "logs",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, permission := range permissions {
|
|
|
|
if err := db.Create(&permission).Error; err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Println("✅ 默认权限创建完成")
|
|
|
|
return nil
|
|
|
|
}
|