loginLogic.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package pub
  2. import (
  3. "context"
  4. "time"
  5. "perms-system-server/internal/response"
  6. "perms-system-server/internal/svc"
  7. "perms-system-server/internal/types"
  8. "github.com/zeromicro/go-zero/core/logx"
  9. )
  10. type LoginLogic struct {
  11. logx.Logger
  12. ctx context.Context
  13. svcCtx *svc.ServiceContext
  14. }
  15. func NewLoginLogic(ctx context.Context, svcCtx *svc.ServiceContext) *LoginLogic {
  16. return &LoginLogic{
  17. Logger: logx.WithContext(ctx),
  18. ctx: ctx,
  19. svcCtx: svcCtx,
  20. }
  21. }
  22. func (l *LoginLogic) Login(req *types.LoginReq) (resp *types.LoginResp, err error) {
  23. result, err := ValidateProductLogin(l.ctx, l.svcCtx, req.Username, req.Password, req.ProductCode)
  24. if err != nil {
  25. if le, ok := err.(*LoginError); ok {
  26. switch le.Code {
  27. case 400:
  28. return nil, response.ErrBadRequest(le.Message)
  29. case 401:
  30. return nil, response.ErrUnauthorized(le.Message)
  31. case 403:
  32. return nil, response.ErrForbidden(le.Message)
  33. }
  34. }
  35. return nil, err
  36. }
  37. ud := result.UserDetails
  38. return &types.LoginResp{
  39. AccessToken: result.AccessToken,
  40. RefreshToken: result.RefreshToken,
  41. Expires: time.Now().Unix() + l.svcCtx.Config.Auth.AccessExpire,
  42. UserInfo: types.UserInfo{
  43. UserId: ud.UserId,
  44. Username: ud.Username,
  45. Nickname: ud.Nickname,
  46. Avatar: ud.Avatar,
  47. Email: ud.Email,
  48. Phone: ud.Phone,
  49. IsSuperAdmin: ud.IsSuperAdminRaw,
  50. MustChangePassword: ud.MustChangePwdRaw,
  51. MemberType: ud.MemberType,
  52. Perms: ud.Perms,
  53. },
  54. }, nil
  55. }