logoutLogic.go 990 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. // Code scaffolded by goctl. Safe to edit.
  2. // goctl 1.10.0
  3. package auth
  4. import (
  5. "context"
  6. "perms-system-server/internal/middleware"
  7. "perms-system-server/internal/response"
  8. "perms-system-server/internal/svc"
  9. "github.com/zeromicro/go-zero/core/logx"
  10. )
  11. type LogoutLogic struct {
  12. logx.Logger
  13. ctx context.Context
  14. svcCtx *svc.ServiceContext
  15. }
  16. func NewLogoutLogic(ctx context.Context, svcCtx *svc.ServiceContext) *LogoutLogic {
  17. return &LogoutLogic{
  18. Logger: logx.WithContext(ctx),
  19. ctx: ctx,
  20. svcCtx: svcCtx,
  21. }
  22. }
  23. // Logout 用户注销。递增当前用户的 tokenVersion 使所有已签发的 access/refresh 令牌立即失效,并清除用户缓存。
  24. func (l *LogoutLogic) Logout() error {
  25. userId := middleware.GetUserId(l.ctx)
  26. if userId == 0 {
  27. return response.ErrUnauthorized("未登录")
  28. }
  29. if _, err := l.svcCtx.SysUserModel.IncrementTokenVersion(l.ctx, userId); err != nil {
  30. return err
  31. }
  32. l.svcCtx.UserDetailsLoader.Clean(l.ctx, userId)
  33. return nil
  34. }