sys_user.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. package system
  2. import (
  3. "errors"
  4. "fmt"
  5. "github.com/gofrs/uuid/v5"
  6. "gorm.io/gorm"
  7. "server/global"
  8. "server/model/system"
  9. "server/model/system/request"
  10. "server/utils"
  11. "time"
  12. )
  13. //@author: [piexlmax](https://github.com/piexlmax)
  14. //@function: Register
  15. //@description: 用户注册
  16. //@param: u model.SysUser
  17. //@return: userInter system.SysUser, err error
  18. type UserService struct{}
  19. func (userService *UserService) Register(u system.SysUser) (userInter system.SysUser, err error) {
  20. var user system.SysUser
  21. if !errors.Is(global.GVA_DB.Where("username = ?", u.Username).First(&user).Error, gorm.ErrRecordNotFound) { // 判断用户名是否注册
  22. return userInter, errors.New("用户名已注册")
  23. }
  24. // 否则 附加uuid 密码hash加密 注册
  25. u.Password = utils.BcryptHash(u.Password)
  26. u.UUID = uuid.Must(uuid.NewV4())
  27. err = global.GVA_DB.Create(&u).Error
  28. return u, err
  29. }
  30. //@author: [piexlmax](https://github.com/piexlmax)
  31. //@author: [SliverHorn](https://github.com/SliverHorn)
  32. //@function: Login
  33. //@description: 用户登录
  34. //@param: u *model.SysUser
  35. //@return: err error, userInter *model.SysUser
  36. func (userService *UserService) Login(u *system.SysUser) (userInter *system.SysUser, err error) {
  37. if nil == global.GVA_DB {
  38. return nil, fmt.Errorf("db not init")
  39. }
  40. var user system.SysUser
  41. err = global.GVA_DB.Where("username = ?", u.Username).Preload("Authorities").Preload("Authority").First(&user).Error
  42. if err == nil {
  43. if ok := utils.BcryptCheck(u.Password, user.Password); !ok {
  44. return nil, errors.New("密码错误")
  45. }
  46. MenuServiceApp.UserAuthorityDefaultRouter(&user)
  47. }
  48. return &user, err
  49. }
  50. //@author: [piexlmax](https://github.com/piexlmax)
  51. //@function: ChangePassword
  52. //@description: 修改用户密码
  53. //@param: u *model.SysUser, newPassword string
  54. //@return: userInter *model.SysUser,err error
  55. func (userService *UserService) ChangePassword(u *system.SysUser, newPassword string) (userInter *system.SysUser, err error) {
  56. var user system.SysUser
  57. if err = global.GVA_DB.Where("id = ?", u.ID).First(&user).Error; err != nil {
  58. return nil, err
  59. }
  60. if ok := utils.BcryptCheck(u.Password, user.Password); !ok {
  61. return nil, errors.New("原密码错误")
  62. }
  63. user.Password = utils.BcryptHash(newPassword)
  64. err = global.GVA_DB.Save(&user).Error
  65. return &user, err
  66. }
  67. //@author: [piexlmax](https://github.com/piexlmax)
  68. //@function: GetUserInfoList
  69. //@description: 分页获取数据
  70. //@param: info request.PageInfo
  71. //@return: err error, list interface{}, total int64
  72. func (userService *UserService) GetUserInfoList(info request.SearchAppUserParams) (list interface{}, total int64, err error) {
  73. limit := info.PageInfo.PageSize
  74. offset := info.PageInfo.PageSize * (info.PageInfo.Page - 1)
  75. db := global.GVA_DB.Model(&system.SysUser{})
  76. var userList []system.SysUser
  77. if info.SysUser.Username != "" {
  78. db = db.Where("username like ?", "%"+info.SysUser.Username+"%")
  79. }
  80. if info.SysUser.Phone != "" {
  81. db = db.Where("phone = ?", info.SysUser.Phone)
  82. }
  83. if info.SysUser.DeptId != 0 {
  84. db = db.Where("dept_id = ?", info.SysUser.DeptId)
  85. }
  86. err = db.Count(&total).Error
  87. if err != nil {
  88. return
  89. }
  90. err = db.Limit(limit).Offset(offset).Preload("Authorities").Preload("Authority").Preload("Dept").Find(&userList).Error
  91. return userList, total, err
  92. }
  93. //@author: [piexlmax](https://github.com/piexlmax)
  94. //@function: SetUserAuthority
  95. //@description: 设置一个用户的权限
  96. //@param: uuid uuid.UUID, authorityId string
  97. //@return: err error
  98. func (userService *UserService) SetUserAuthority(id uint, authorityId uint) (err error) {
  99. assignErr := global.GVA_DB.Where("sys_user_id = ? AND sys_authority_authority_id = ?", id, authorityId).First(&system.SysUserAuthority{}).Error
  100. if errors.Is(assignErr, gorm.ErrRecordNotFound) {
  101. return errors.New("该用户无此角色")
  102. }
  103. err = global.GVA_DB.Model(&system.SysUser{}).Where("id = ?", id).Update("authority_id", authorityId).Error
  104. return err
  105. }
  106. //@author: [piexlmax](https://github.com/piexlmax)
  107. //@function: SetUserAuthorities
  108. //@description: 设置一个用户的权限
  109. //@param: id uint, authorityIds []string
  110. //@return: err error
  111. func (userService *UserService) SetUserAuthorities(id uint, authorityIds []uint) (err error) {
  112. return global.GVA_DB.Transaction(func(tx *gorm.DB) error {
  113. var user system.SysUser
  114. TxErr := tx.Where("id = ?", id).First(&user).Error
  115. if TxErr != nil {
  116. global.GVA_LOG.Debug(TxErr.Error())
  117. return errors.New("查询用户数据失败")
  118. }
  119. TxErr = tx.Delete(&[]system.SysUserAuthority{}, "sys_user_id = ?", id).Error
  120. if TxErr != nil {
  121. return TxErr
  122. }
  123. var useAuthority []system.SysUserAuthority
  124. for _, v := range authorityIds {
  125. useAuthority = append(useAuthority, system.SysUserAuthority{
  126. SysUserId: id, SysAuthorityAuthorityId: v,
  127. })
  128. }
  129. TxErr = tx.Create(&useAuthority).Error
  130. if TxErr != nil {
  131. return TxErr
  132. }
  133. TxErr = tx.Model(&user).Update("authority_id", authorityIds[0]).Error
  134. if TxErr != nil {
  135. return TxErr
  136. }
  137. // 返回 nil 提交事务
  138. return nil
  139. })
  140. }
  141. //@author: [piexlmax](https://github.com/piexlmax)
  142. //@function: DeleteUser
  143. //@description: 删除用户
  144. //@param: id float64
  145. //@return: err error
  146. func (userService *UserService) DeleteUser(id int) (err error) {
  147. return global.GVA_DB.Transaction(func(tx *gorm.DB) error {
  148. if err := tx.Where("id = ?", id).Delete(&system.SysUser{}).Error; err != nil {
  149. return err
  150. }
  151. if err := tx.Delete(&[]system.SysUserAuthority{}, "sys_user_id = ?", id).Error; err != nil {
  152. return err
  153. }
  154. return nil
  155. })
  156. }
  157. //@author: [piexlmax](https://github.com/piexlmax)
  158. //@function: SetUserInfo
  159. //@description: 设置用户信息
  160. //@param: reqUser model.SysUser
  161. //@return: err error, user model.SysUser
  162. func (userService *UserService) SetUserInfo(req system.SysUser) error {
  163. return global.GVA_DB.Model(&system.SysUser{}).
  164. Select("updated_at", "nick_name", "header_img", "phone", "email", "sideMode", "enable", "dept_id", "auth_id").
  165. Where("id=?", req.ID).
  166. Updates(map[string]interface{}{
  167. "updated_at": time.Now(),
  168. "nick_name": req.NickName,
  169. "header_img": req.HeaderImg,
  170. "phone": req.Phone,
  171. "email": req.Email,
  172. "side_mode": req.SideMode,
  173. "enable": req.Enable,
  174. "dept_id": req.DeptId,
  175. "auth_id": req.AuthId,
  176. }).Error
  177. }
  178. //@author: [piexlmax](https://github.com/piexlmax)
  179. //@function: SetUserInfo
  180. //@description: 设置用户信息
  181. //@param: reqUser model.SysUser
  182. //@return: err error, user model.SysUser
  183. func (userService *UserService) SetSelfInfo(req system.SysUser) error {
  184. return global.GVA_DB.Model(&system.SysUser{}).
  185. Where("id=?", req.ID).
  186. Updates(req).Error
  187. }
  188. //@author: [piexlmax](https://github.com/piexlmax)
  189. //@author: [SliverHorn](https://github.com/SliverHorn)
  190. //@function: GetUserInfo
  191. //@description: 获取用户信息
  192. //@param: uuid uuid.UUID
  193. //@return: err error, user system.SysUser
  194. func (userService *UserService) GetUserInfo(uuid uuid.UUID) (user system.SysUser, err error) {
  195. var reqUser system.SysUser
  196. err = global.GVA_DB.Preload("Authorities").Preload("Authority").First(&reqUser, "uuid = ?", uuid).Error
  197. if err != nil {
  198. return reqUser, err
  199. }
  200. MenuServiceApp.UserAuthorityDefaultRouter(&reqUser)
  201. return reqUser, err
  202. }
  203. //@author: [SliverHorn](https://github.com/SliverHorn)
  204. //@function: FindUserById
  205. //@description: 通过id获取用户信息
  206. //@param: id int
  207. //@return: err error, user *model.SysUser
  208. func (userService *UserService) FindUserById(id int) (user *system.SysUser, err error) {
  209. var u system.SysUser
  210. err = global.GVA_DB.Where("id = ?", id).First(&u).Error
  211. return &u, err
  212. }
  213. //@author: [SliverHorn](https://github.com/SliverHorn)
  214. //@function: FindUserByUuid
  215. //@description: 通过uuid获取用户信息
  216. //@param: uuid string
  217. //@return: err error, user *model.SysUser
  218. func (userService *UserService) FindUserByUuid(uuid string) (user *system.SysUser, err error) {
  219. var u system.SysUser
  220. if err = global.GVA_DB.Where("uuid = ?", uuid).First(&u).Error; err != nil {
  221. return &u, errors.New("用户不存在")
  222. }
  223. return &u, nil
  224. }
  225. //@author: [piexlmax](https://github.com/piexlmax)
  226. //@function: resetPassword
  227. //@description: 修改用户密码
  228. //@param: ID uint
  229. //@return: err error
  230. func (userService *UserService) ResetPassword(ID uint) (err error) {
  231. err = global.GVA_DB.Model(&system.SysUser{}).Where("id = ?", ID).Update("password", utils.BcryptHash("123456")).Error
  232. return err
  233. }