loginLogic.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package pub
  2. import (
  3. "context"
  4. "time"
  5. "perms-system-server/internal/consts"
  6. authHelper "perms-system-server/internal/logic/auth"
  7. "perms-system-server/internal/model/user"
  8. "perms-system-server/internal/response"
  9. "perms-system-server/internal/svc"
  10. "perms-system-server/internal/types"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. "golang.org/x/crypto/bcrypt"
  13. )
  14. type LoginLogic struct {
  15. logx.Logger
  16. ctx context.Context
  17. svcCtx *svc.ServiceContext
  18. }
  19. func NewLoginLogic(ctx context.Context, svcCtx *svc.ServiceContext) *LoginLogic {
  20. return &LoginLogic{
  21. Logger: logx.WithContext(ctx),
  22. ctx: ctx,
  23. svcCtx: svcCtx,
  24. }
  25. }
  26. func (l *LoginLogic) Login(req *types.LoginReq) (resp *types.LoginResp, err error) {
  27. u, err := l.svcCtx.SysUserModel.FindOneByUsername(l.ctx, req.Username)
  28. if err != nil {
  29. if err == user.ErrNotFound {
  30. return nil, response.ErrUnauthorized("用户名或密码错误")
  31. }
  32. return nil, err
  33. }
  34. if u.Status != consts.StatusEnabled {
  35. return nil, response.ErrForbidden("账号已被冻结")
  36. }
  37. if err := bcrypt.CompareHashAndPassword([]byte(u.Password), []byte(req.Password)); err != nil {
  38. return nil, response.ErrUnauthorized("用户名或密码错误")
  39. }
  40. if u.IsSuperAdmin == consts.IsSuperAdminYes {
  41. return nil, response.ErrForbidden("超级管理员不允许通过产品端登录,请使用管理后台")
  42. }
  43. product, err := l.svcCtx.SysProductModel.FindOneByCode(l.ctx, req.ProductCode)
  44. if err != nil {
  45. return nil, response.ErrBadRequest("产品不存在")
  46. }
  47. if product.Status != consts.StatusEnabled {
  48. return nil, response.ErrForbidden("该产品已被禁用")
  49. }
  50. if _, memberErr := l.svcCtx.SysProductMemberModel.FindOneByProductCodeUserId(l.ctx, req.ProductCode, u.Id); memberErr != nil {
  51. return nil, response.ErrForbidden("您不是该产品的成员")
  52. }
  53. ud := l.svcCtx.UserDetailsLoader.Load(l.ctx, u.Id, req.ProductCode)
  54. accessToken, err := authHelper.GenerateAccessToken(
  55. l.svcCtx.Config.Auth.AccessSecret,
  56. l.svcCtx.Config.Auth.AccessExpire,
  57. ud.UserId, ud.Username, ud.ProductCode, ud.MemberType, ud.Perms,
  58. )
  59. if err != nil {
  60. return nil, err
  61. }
  62. refreshToken, err := authHelper.GenerateRefreshToken(
  63. l.svcCtx.Config.Auth.RefreshSecret,
  64. l.svcCtx.Config.Auth.RefreshExpire,
  65. ud.UserId, ud.ProductCode,
  66. )
  67. if err != nil {
  68. return nil, err
  69. }
  70. return &types.LoginResp{
  71. AccessToken: accessToken,
  72. RefreshToken: refreshToken,
  73. Expires: time.Now().Unix() + l.svcCtx.Config.Auth.AccessExpire,
  74. UserInfo: types.UserInfo{
  75. UserId: ud.UserId,
  76. Username: ud.Username,
  77. Nickname: ud.Nickname,
  78. Avatar: ud.Avatar,
  79. Email: ud.Email,
  80. Phone: ud.Phone,
  81. IsSuperAdmin: ud.IsSuperAdminRaw,
  82. MustChangePassword: ud.MustChangePwdRaw,
  83. MemberType: ud.MemberType,
  84. Perms: ud.Perms,
  85. },
  86. }, nil
  87. }