loginLogic.go 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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. ud := l.svcCtx.UserDetailsLoader.Load(l.ctx, u.Id, req.ProductCode)
  41. accessToken, err := authHelper.GenerateAccessToken(
  42. l.svcCtx.Config.Auth.AccessSecret,
  43. l.svcCtx.Config.Auth.AccessExpire,
  44. ud.UserId, ud.Username, ud.ProductCode, ud.MemberType, ud.Perms,
  45. )
  46. if err != nil {
  47. return nil, err
  48. }
  49. refreshToken, err := authHelper.GenerateRefreshToken(
  50. l.svcCtx.Config.Auth.RefreshSecret,
  51. l.svcCtx.Config.Auth.RefreshExpire,
  52. ud.UserId, ud.ProductCode,
  53. )
  54. if err != nil {
  55. return nil, err
  56. }
  57. return &types.LoginResp{
  58. AccessToken: accessToken,
  59. RefreshToken: refreshToken,
  60. Expires: time.Now().Unix() + l.svcCtx.Config.Auth.AccessExpire,
  61. UserInfo: types.UserInfo{
  62. UserId: ud.UserId,
  63. Username: ud.Username,
  64. Nickname: ud.Nickname,
  65. Avatar: ud.Avatar,
  66. Email: ud.Email,
  67. Phone: ud.Phone,
  68. IsSuperAdmin: ud.IsSuperAdminRaw,
  69. MustChangePassword: ud.MustChangePwdRaw,
  70. MemberType: ud.MemberType,
  71. Perms: ud.Perms,
  72. },
  73. }, nil
  74. }