45 lines
1003 B
Go
45 lines
1003 B
Go
|
package user
|
|||
|
|
|||
|
import (
|
|||
|
"context"
|
|||
|
"errors"
|
|||
|
"tianyuan-api/apps/sentinel/sentinel"
|
|||
|
|
|||
|
"tianyuan-api/apps/gateway/internal/svc"
|
|||
|
"tianyuan-api/apps/gateway/internal/types"
|
|||
|
|
|||
|
"github.com/zeromicro/go-zero/core/logx"
|
|||
|
)
|
|||
|
|
|||
|
type GetSecretInfoLogic struct {
|
|||
|
logx.Logger
|
|||
|
ctx context.Context
|
|||
|
svcCtx *svc.ServiceContext
|
|||
|
}
|
|||
|
|
|||
|
func NewGetSecretInfoLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetSecretInfoLogic {
|
|||
|
return &GetSecretInfoLogic{
|
|||
|
Logger: logx.WithContext(ctx),
|
|||
|
ctx: ctx,
|
|||
|
svcCtx: svcCtx,
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
func (l *GetSecretInfoLogic) GetSecretInfo() (resp *types.SecretInfoResp, err error) {
|
|||
|
// 从上下文中解析 JWT,获取用户ID
|
|||
|
userId, ok := l.ctx.Value("userId").(int64)
|
|||
|
if !ok {
|
|||
|
return nil, errors.New("无法获取 userId")
|
|||
|
}
|
|||
|
secret, err := l.svcCtx.SecretRpc.GetSecretByUserId(l.ctx, &sentinel.GetRecordByIdRequest{
|
|||
|
Id: userId,
|
|||
|
})
|
|||
|
if err != nil {
|
|||
|
return nil, err
|
|||
|
}
|
|||
|
return &types.SecretInfoResp{
|
|||
|
AccessId: secret.SecretId,
|
|||
|
AccessKey: secret.AesKey,
|
|||
|
}, nil
|
|||
|
}
|