package logic import ( "ark-permission/gen_result/pb/permission" "ark-permission/internal/svc" "context" "github.com/zeromicro/go-zero/core/logx" ) type CancelTokenLogic struct { ctx context.Context svcCtx *svc.ServiceContext logx.Logger } func NewCancelTokenLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CancelTokenLogic { return &CancelTokenLogic{ ctx: ctx, svcCtx: svcCtx, Logger: logx.WithContext(ctx), } } type cancelTokenReq struct { Token string `json:"token" validate:"required"` } // CancelToken 取消 Token,也包含他裡面的 One Time Toke func (l *CancelTokenLogic) CancelToken(in *permission.CancelTokenReq) (*permission.OKResp, error) { // // 驗證所需 // if err := l.svcCtx.Validate.ValidateAll(&cancelTokenReq{ // Token: in.GetToken(), // }); err != nil { // return nil, ers.InvalidFormat(err.Error()) // } // claims, err := uc.parseClaims(accessToken) // if err != nil { // return err // } // // token, err := uc.TokenRepository.GetByAccess(ctx, claims.ID()) // if err != nil { // if errors.Is(err, repository.ErrRecordNotFound) { // return usecase.TokenError{Msg: "token not found"} // } // // return usecase.InternalError{Err: fmt.Errorf("tokenRepository.GetByAccess error: %w", err)} // } // // if err := uc.TokenRepository.Delete(ctx, token); err != nil { // if errors.Is(err, repository.ErrRecordNotFound) { // return nil, usecase.TokenError{Msg: "token not found"} // } // // return nil, err // } return &permission.OKResp{}, nil }