user.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package system
  2. import (
  3. "context"
  4. sysModel "github.com/flipped-aurora/gin-vue-admin/server/model/system"
  5. "github.com/flipped-aurora/gin-vue-admin/server/service/system"
  6. "github.com/flipped-aurora/gin-vue-admin/server/utils"
  7. "github.com/google/uuid"
  8. "github.com/pkg/errors"
  9. "gorm.io/gorm"
  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. ap := ctx.Value("adminPassword")
  40. apStr, ok := ap.(string)
  41. if !ok {
  42. apStr = "123456"
  43. }
  44. password := utils.BcryptHash(apStr)
  45. adminPassword := utils.BcryptHash(apStr)
  46. entities := []sysModel.SysUser{
  47. {
  48. UUID: uuid.New(),
  49. Username: "admin",
  50. Password: adminPassword,
  51. NickName: "Mr.奇淼",
  52. HeaderImg: "https://qmplusimg.henrongyi.top/gva_header.jpg",
  53. AuthorityId: 888,
  54. Phone: "17611111111",
  55. Email: "333333333@qq.com",
  56. },
  57. {
  58. UUID: uuid.New(),
  59. Username: "a303176530",
  60. Password: password,
  61. NickName: "用户1",
  62. HeaderImg: "https:///qmplusimg.henrongyi.top/1572075907logo.png",
  63. AuthorityId: 9528,
  64. Phone: "17611111111",
  65. Email: "333333333@qq.com"},
  66. }
  67. if err = db.Create(&entities).Error; err != nil {
  68. return ctx, errors.Wrap(err, sysModel.SysUser{}.TableName()+"表数据初始化失败!")
  69. }
  70. next = context.WithValue(ctx, i.InitializerName(), entities)
  71. authorityEntities, ok := ctx.Value(new(initAuthority).InitializerName()).([]sysModel.SysAuthority)
  72. if !ok {
  73. return next, errors.Wrap(system.ErrMissingDependentContext, "创建 [用户-权限] 关联失败, 未找到权限表初始化数据")
  74. }
  75. if err = db.Model(&entities[0]).Association("Authorities").Replace(authorityEntities); err != nil {
  76. return next, err
  77. }
  78. if err = db.Model(&entities[1]).Association("Authorities").Replace(authorityEntities[:1]); err != nil {
  79. return next, err
  80. }
  81. return next, err
  82. }
  83. func (i *initUser) DataInserted(ctx context.Context) bool {
  84. db, ok := ctx.Value("db").(*gorm.DB)
  85. if !ok {
  86. return false
  87. }
  88. var record sysModel.SysUser
  89. if errors.Is(db.Where("username = ?", "a303176530").
  90. Preload("Authorities").First(&record).Error, gorm.ErrRecordNotFound) { // 判断是否存在数据
  91. return false
  92. }
  93. return len(record.Authorities) > 0 && record.Authorities[0].AuthorityId == 888
  94. }