add queryRecheck
This commit is contained in:
parent
877f1cdaee
commit
768da1fe47
@ -120,6 +120,10 @@ service main {
|
|||||||
@doc "生成分享链接"
|
@doc "生成分享链接"
|
||||||
@handler QueryGenerateShareLink
|
@handler QueryGenerateShareLink
|
||||||
post /query/generate_share_link (QueryGenerateShareLinkReq) returns (QueryGenerateShareLinkResp)
|
post /query/generate_share_link (QueryGenerateShareLinkReq) returns (QueryGenerateShareLinkResp)
|
||||||
|
|
||||||
|
@doc "补查"
|
||||||
|
@handler queryRecheck
|
||||||
|
post /query/recheck/:query_id (QueryRecheckReq) returns (QueryRecheckResp)
|
||||||
}
|
}
|
||||||
|
|
||||||
type (
|
type (
|
||||||
@ -261,3 +265,11 @@ type (
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type (
|
||||||
|
QueryRecheckReq {
|
||||||
|
QueryId int64 `path:"query_id"`
|
||||||
|
}
|
||||||
|
QueryRecheckResp {
|
||||||
|
Success bool `json:"success"`
|
||||||
|
}
|
||||||
|
)
|
@ -0,0 +1,29 @@
|
|||||||
|
package query
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/zeromicro/go-zero/rest/httpx"
|
||||||
|
"qnc-server/app/user/cmd/api/internal/logic/query"
|
||||||
|
"qnc-server/app/user/cmd/api/internal/svc"
|
||||||
|
"qnc-server/app/user/cmd/api/internal/types"
|
||||||
|
"qnc-server/common/result"
|
||||||
|
"qnc-server/pkg/lzkit/validator"
|
||||||
|
)
|
||||||
|
|
||||||
|
func QueryRecheckHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
|
||||||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
var req types.QueryRecheckReq
|
||||||
|
if err := httpx.Parse(r, &req); err != nil {
|
||||||
|
result.ParamErrorResult(r, w, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if err := validator.Validate(req); err != nil {
|
||||||
|
result.ParamValidateErrorResult(r, w, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
l := query.NewQueryRecheckLogic(r.Context(), svcCtx)
|
||||||
|
resp, err := l.QueryRecheck(&req)
|
||||||
|
result.HttpResult(r, w, resp, err)
|
||||||
|
}
|
||||||
|
}
|
@ -345,6 +345,12 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
|
|||||||
Path: "/query/provisional_order/:id",
|
Path: "/query/provisional_order/:id",
|
||||||
Handler: query.QueryProvisionalOrderHandler(serverCtx),
|
Handler: query.QueryProvisionalOrderHandler(serverCtx),
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
// 补查
|
||||||
|
Method: http.MethodPost,
|
||||||
|
Path: "/query/recheck/:query_id",
|
||||||
|
Handler: query.QueryRecheckHandler(serverCtx),
|
||||||
|
},
|
||||||
{
|
{
|
||||||
// 重试查询
|
// 重试查询
|
||||||
Method: http.MethodPost,
|
Method: http.MethodPost,
|
||||||
|
66
app/user/cmd/api/internal/logic/query/queryrechecklogic.go
Normal file
66
app/user/cmd/api/internal/logic/query/queryrechecklogic.go
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
package query
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"database/sql"
|
||||||
|
"encoding/hex"
|
||||||
|
|
||||||
|
"qnc-server/app/user/cmd/api/internal/svc"
|
||||||
|
"qnc-server/app/user/cmd/api/internal/types"
|
||||||
|
"qnc-server/app/user/model"
|
||||||
|
"qnc-server/common/xerr"
|
||||||
|
"qnc-server/pkg/lzkit/crypto"
|
||||||
|
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
"github.com/zeromicro/go-zero/core/logx"
|
||||||
|
)
|
||||||
|
|
||||||
|
type QueryRecheckLogic struct {
|
||||||
|
logx.Logger
|
||||||
|
ctx context.Context
|
||||||
|
svcCtx *svc.ServiceContext
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewQueryRecheckLogic(ctx context.Context, svcCtx *svc.ServiceContext) *QueryRecheckLogic {
|
||||||
|
return &QueryRecheckLogic{
|
||||||
|
Logger: logx.WithContext(ctx),
|
||||||
|
ctx: ctx,
|
||||||
|
svcCtx: svcCtx,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l *QueryRecheckLogic) QueryRecheck(req *types.QueryRecheckReq) (resp *types.QueryRecheckResp, err error) {
|
||||||
|
query, err := l.svcCtx.QueryModel.FindOne(l.ctx, req.QueryId)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "补查, 获取query失败, %v", err)
|
||||||
|
}
|
||||||
|
secretKey := l.svcCtx.Config.Encrypt.SecretKey
|
||||||
|
key, decodeErr := hex.DecodeString(secretKey)
|
||||||
|
if decodeErr != nil {
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "补查, 获取密钥失败, %v", err)
|
||||||
|
}
|
||||||
|
decryptData, aesdecryptErr := crypto.AesDecrypt(query.QueryParams, key)
|
||||||
|
if aesdecryptErr != nil {
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "补查, 解密参数失败: %+v", aesdecryptErr)
|
||||||
|
}
|
||||||
|
combinedResponse, err := l.svcCtx.ApiRequestService.ProcessRequests(decryptData, query.ProductId)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "补查, 处理请求失败: %v", err)
|
||||||
|
}
|
||||||
|
encryptData, aesEncryptErr := crypto.AesEncrypt(combinedResponse, key)
|
||||||
|
if aesEncryptErr != nil {
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "补查, 加密响应信息失败: %v", aesEncryptErr)
|
||||||
|
}
|
||||||
|
query.QueryData = sql.NullString{
|
||||||
|
String: encryptData,
|
||||||
|
Valid: true,
|
||||||
|
}
|
||||||
|
query.QueryState = model.QueryStateSuccess
|
||||||
|
updateErr := l.svcCtx.QueryModel.UpdateWithVersion(l.ctx, nil, query)
|
||||||
|
if updateErr != nil {
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "补查, 保存响应数据失败: %v", updateErr)
|
||||||
|
}
|
||||||
|
return &types.QueryRecheckResp{
|
||||||
|
Success: true,
|
||||||
|
}, nil
|
||||||
|
}
|
@ -471,6 +471,14 @@ type QueryProvisionalOrderResp struct {
|
|||||||
Product Product `json:"product"`
|
Product Product `json:"product"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type QueryRecheckReq struct {
|
||||||
|
QueryId int64 `path:"query_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type QueryRecheckResp struct {
|
||||||
|
Success bool `json:"success"`
|
||||||
|
}
|
||||||
|
|
||||||
type QueryReq struct {
|
type QueryReq struct {
|
||||||
Data string `json:"data" validate:"required"`
|
Data string `json:"data" validate:"required"`
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,7 @@ import (
|
|||||||
|
|
||||||
func TestGenerateAndParseJwtToken(t *testing.T) {
|
func TestGenerateAndParseJwtToken(t *testing.T) {
|
||||||
// 测试参数
|
// 测试参数
|
||||||
userId := int64(2043)
|
userId := int64(39)
|
||||||
secret := "WUvoIwL-FK0qnlxhvxR9tV6SjfOpeJMpKmY2QvT99lA"
|
secret := "WUvoIwL-FK0qnlxhvxR9tV6SjfOpeJMpKmY2QvT99lA"
|
||||||
expireTime := int64(2592000) // 1小时过期
|
expireTime := int64(2592000) // 1小时过期
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user