user.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. package system
  2. import (
  3. "context"
  4. "github.com/gofrs/uuid/v5"
  5. "github.com/pkg/errors"
  6. "gorm.io/gorm"
  7. sysModel "server/model/system"
  8. "server/service/system"
  9. "server/utils"
  10. )
  11. const initOrderUser = initOrderAuthority + 1
  12. type initUser struct{}
  13. // auto run
  14. func init() {
  15. system.RegisterInit(initOrderUser, &initUser{})
  16. }
  17. func (i *initUser) MigrateTable(ctx context.Context) (context.Context, error) {
  18. db, ok := ctx.Value("db").(*gorm.DB)
  19. if !ok {
  20. return ctx, system.ErrMissingDBContext
  21. }
  22. return ctx, db.AutoMigrate(&sysModel.SysUser{})
  23. }
  24. func (i *initUser) TableCreated(ctx context.Context) bool {
  25. db, ok := ctx.Value("db").(*gorm.DB)
  26. if !ok {
  27. return false
  28. }
  29. return db.Migrator().HasTable(&sysModel.SysUser{})
  30. }
  31. func (i initUser) InitializerName() string {
  32. return sysModel.SysUser{}.TableName()
  33. }
  34. func (i *initUser) InitializeData(ctx context.Context) (next context.Context, err error) {
  35. db, ok := ctx.Value("db").(*gorm.DB)
  36. if !ok {
  37. return ctx, system.ErrMissingDBContext
  38. }
  39. password := utils.BcryptHash("6447985")
  40. adminPassword := utils.BcryptHash("123456")
  41. entities := []sysModel.SysUser{
  42. {
  43. UUID: uuid.Must(uuid.NewV4()),
  44. Username: "admin",
  45. Password: adminPassword,
  46. NickName: "Mr.奇淼",
  47. HeaderImg: "https://qmplusimg.henrongyi.top/gva_header.jpg",
  48. AuthorityId: 888,
  49. Phone: "17611111111",
  50. Email: "333333333@qq.com",
  51. },
  52. {
  53. UUID: uuid.Must(uuid.NewV4()),
  54. Username: "a303176530",
  55. Password: password,
  56. NickName: "用户1",
  57. HeaderImg: "https:///qmplusimg.henrongyi.top/1572075907logo.png",
  58. AuthorityId: 9528,
  59. Phone: "17611111111",
  60. Email: "333333333@qq.com"},
  61. }
  62. if err = db.Create(&entities).Error; err != nil {
  63. return ctx, errors.Wrap(err, sysModel.SysUser{}.TableName()+"表数据初始化失败!")
  64. }
  65. next = context.WithValue(ctx, i.InitializerName(), entities)
  66. authorityEntities, ok := ctx.Value(initAuthority{}.InitializerName()).([]sysModel.SysAuthority)
  67. if !ok {
  68. return next, errors.Wrap(system.ErrMissingDependentContext, "创建 [用户-权限] 关联失败, 未找到权限表初始化数据")
  69. }
  70. if err = db.Model(&entities[0]).Association("Authorities").Replace(authorityEntities); err != nil {
  71. return next, err
  72. }
  73. if err = db.Model(&entities[1]).Association("Authorities").Replace(authorityEntities[:1]); err != nil {
  74. return next, err
  75. }
  76. return next, err
  77. }
  78. func (i *initUser) DataInserted(ctx context.Context) bool {
  79. db, ok := ctx.Value("db").(*gorm.DB)
  80. if !ok {
  81. return false
  82. }
  83. var record sysModel.SysUser
  84. if errors.Is(db.Where("username = ?", "a303176530").
  85. Preload("Authorities").First(&record).Error, gorm.ErrRecordNotFound) { // 判断是否存在数据
  86. return false
  87. }
  88. return len(record.Authorities) > 0 && record.Authorities[0].AuthorityId == 888
  89. }