sys_user.go 7.8 KB

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