<fix>修改回调
This commit is contained in:
parent
2035af1580
commit
921c40606b
|
@ -86,7 +86,7 @@ func closeOrder() {
|
||||||
}
|
}
|
||||||
orderIds = append(orderIds, orderInfo.Id)
|
orderIds = append(orderIds, orderInfo.Id)
|
||||||
// 回调通知下游
|
// 回调通知下游
|
||||||
notifyResult := thirdpay_notify.NewOrderNotifyWithHandle(orderInfo.Id, common.ORDER_STATUS_CLOSE, 0, "长时间未支付关闭订单")
|
notifyResult := thirdpay_notify.NewOrderNotifyWithHandle(orderInfo.Id, response.Code, common.ORDER_STATUS_CLOSE, 0, "长时间未支付关闭订单")
|
||||||
//utils.Log(nil, "主动查询订单支付状态,回调下游", notifyResult)
|
//utils.Log(nil, "主动查询订单支付状态,回调下游", notifyResult)
|
||||||
if notifyResult.ErrCode != errorcode.Success {
|
if notifyResult.ErrCode != errorcode.Success {
|
||||||
utils.Log(nil, "关闭订单,回调下游失败", fmt.Sprintf("%#v", notifyResult))
|
utils.Log(nil, "关闭订单,回调下游失败", fmt.Sprintf("%#v", notifyResult))
|
||||||
|
@ -192,7 +192,7 @@ func queryOrder() {
|
||||||
msg = "订单关闭"
|
msg = "订单关闭"
|
||||||
}
|
}
|
||||||
// 回调通知下游
|
// 回调通知下游
|
||||||
notifyResult := thirdpay_notify.NewOrderNotifyWithHandle(orderInfo.Id, status, int(result.Result.PayerTotal), msg)
|
notifyResult := thirdpay_notify.NewOrderNotifyWithHandle(orderInfo.Id, result.Code, status, int(result.Result.PayerTotal), msg)
|
||||||
//utils.Log(nil, "主动查询订单支付状态,回调下游", notifyResult)
|
//utils.Log(nil, "主动查询订单支付状态,回调下游", notifyResult)
|
||||||
if notifyResult.ErrCode != errorcode.Success {
|
if notifyResult.ErrCode != errorcode.Success {
|
||||||
utils.Log(nil, "主动查询订单支付状态,回调下游失败", fmt.Sprintf("%+v", notifyResult))
|
utils.Log(nil, "主动查询订单支付状态,回调下游失败", fmt.Sprintf("%+v", notifyResult))
|
||||||
|
@ -295,7 +295,7 @@ func queryRefundOrder() {
|
||||||
msg = "退款失败"
|
msg = "退款失败"
|
||||||
}
|
}
|
||||||
// 回调通知下游 todo
|
// 回调通知下游 todo
|
||||||
notifyResult := thirdpay_notify.NewOrderNotifyWithHandle(orderInfo.Id, status, int(result.Result.RefundFee), msg)
|
notifyResult := thirdpay_notify.NewOrderNotifyWithHandle(orderInfo.Id, result.Code, status, int(result.Result.RefundFee), msg)
|
||||||
//utils.Log(nil, "主动查询退款订单状态,回调下游", notifyResult)
|
//utils.Log(nil, "主动查询退款订单状态,回调下游", notifyResult)
|
||||||
if notifyResult.ErrCode != errorcode.Success {
|
if notifyResult.ErrCode != errorcode.Success {
|
||||||
utils.Log(nil, "查询退款订单状态,回调下游失败", notifyResult)
|
utils.Log(nil, "查询退款订单状态,回调下游失败", notifyResult)
|
||||||
|
|
|
@ -51,13 +51,13 @@ type OrderNotifySendContent struct {
|
||||||
PayerTotal int `json:"payer_total"`
|
PayerTotal int `json:"payer_total"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewOrderNotifyWithHandle(orderId int64, Status int, actualAmount int, msg string) *OrderNotifyResp {
|
func NewOrderNotifyWithHandle(orderId int64, code int, Status int, actualAmount int, msg string) *OrderNotifyResp {
|
||||||
orderNotify := &OrderNotify{
|
orderNotify := &OrderNotify{
|
||||||
OrderId: orderId,
|
OrderId: orderId,
|
||||||
Status: Status,
|
Status: Status,
|
||||||
ActualAmount: actualAmount,
|
ActualAmount: actualAmount,
|
||||||
Msg: msg,
|
Msg: msg,
|
||||||
Code: errorcode.Success,
|
Code: code,
|
||||||
}
|
}
|
||||||
return orderNotify.Handle()
|
return orderNotify.Handle()
|
||||||
}
|
}
|
||||||
|
@ -72,6 +72,9 @@ func (o *OrderNotify) NotifyRespFail(errorCode int) *OrderNotifyResp {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (o *OrderNotify) Handle() (res *OrderNotifyResp) {
|
func (o *OrderNotify) Handle() (res *OrderNotifyResp) {
|
||||||
|
if o.Code != errorcode.Success {
|
||||||
|
return o.NotifyRespFail(o.Code)
|
||||||
|
}
|
||||||
o.checkOrder()
|
o.checkOrder()
|
||||||
if o.Code != errorcode.Success {
|
if o.Code != errorcode.Success {
|
||||||
return o.NotifyRespFail(o.Code)
|
return o.NotifyRespFail(o.Code)
|
||||||
|
@ -168,6 +171,7 @@ func (o *OrderNotify) setBody() *OrderNotifySendContent {
|
||||||
|
|
||||||
func (o *OrderNotify) updateOrder() {
|
func (o *OrderNotify) updateOrder() {
|
||||||
if _, ok := common.OrderStatusMap[o.Status]; !ok {
|
if _, ok := common.OrderStatusMap[o.Status]; !ok {
|
||||||
|
|
||||||
o.Code = errorcode.OrderStatusErr
|
o.Code = errorcode.OrderStatusErr
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,6 +81,7 @@ func ALiH5PayInfo(c context.Context, payOrderRequest PayOrderRequest) (string, e
|
||||||
|
|
||||||
// ALiCallBack 支付宝支付回调
|
// ALiCallBack 支付宝支付回调
|
||||||
func ALiCallBack(notifyReq gopay.BodyMap, aliConfig AliPay) error {
|
func ALiCallBack(notifyReq gopay.BodyMap, aliConfig AliPay) error {
|
||||||
|
var orderStatus int
|
||||||
ok, err := alipay.VerifySignWithCert([]byte(aliConfig.AlipayPublicCert), notifyReq)
|
ok, err := alipay.VerifySignWithCert([]byte(aliConfig.AlipayPublicCert), notifyReq)
|
||||||
if !ok || err != nil {
|
if !ok || err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -96,12 +97,15 @@ func ALiCallBack(notifyReq gopay.BodyMap, aliConfig AliPay) error {
|
||||||
switch tradeStatus {
|
switch tradeStatus {
|
||||||
case "TRADE_CLOSED":
|
case "TRADE_CLOSED":
|
||||||
errCode = errorcode.ParamError
|
errCode = errorcode.ParamError
|
||||||
|
orderStatus = common.ORDER_STATUS_CLOSE
|
||||||
msg = "未付款交易超时关闭,或支付完成后全额退款。"
|
msg = "未付款交易超时关闭,或支付完成后全额退款。"
|
||||||
case "TRADE_SUCCESS":
|
case "TRADE_SUCCESS":
|
||||||
errCode = errorcode.Success
|
errCode = errorcode.Success
|
||||||
|
orderStatus = common.ORDER_STATUS_PAYED
|
||||||
msg = "交易支付成功。"
|
msg = "交易支付成功。"
|
||||||
case "TRADE_FINISHED":
|
case "TRADE_FINISHED":
|
||||||
errCode = errorcode.Success
|
errCode = errorcode.Success
|
||||||
|
orderStatus = common.ORDER_STATUS_CLOSE
|
||||||
msg = "交易结束,不可退款。"
|
msg = "交易结束,不可退款。"
|
||||||
}
|
}
|
||||||
if errCode == 0 {
|
if errCode == 0 {
|
||||||
|
@ -109,7 +113,7 @@ func ALiCallBack(notifyReq gopay.BodyMap, aliConfig AliPay) error {
|
||||||
return errors.New("订单状态异常,无法进行后续回调")
|
return errors.New("订单状态异常,无法进行后续回调")
|
||||||
}
|
}
|
||||||
|
|
||||||
res := thirdpay_notify.NewOrderNotifyWithHandle(int64(orderId), errCode, payerTotal, msg)
|
res := thirdpay_notify.NewOrderNotifyWithHandle(int64(orderId), orderStatus, errCode, payerTotal, msg)
|
||||||
merchantCallback, _ := json.Marshal(res)
|
merchantCallback, _ := json.Marshal(res)
|
||||||
// 记录日志
|
// 记录日志
|
||||||
go func() {
|
go func() {
|
||||||
|
|
|
@ -91,6 +91,7 @@ func WxH5PayInfo(c context.Context, payOrderRequest PayOrderRequest) (string, er
|
||||||
// WxPayCallBack 微信支付回调
|
// WxPayCallBack 微信支付回调
|
||||||
func WxPayCallBack(notifyReq *wechat.V3NotifyReq, wxConfig WxPay) error {
|
func WxPayCallBack(notifyReq *wechat.V3NotifyReq, wxConfig WxPay) error {
|
||||||
// 初始化微信客户端
|
// 初始化微信客户端
|
||||||
|
var orderStatus int
|
||||||
wxClient, err := InitClient(wxConfig)
|
wxClient, err := InitClient(wxConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -128,22 +129,26 @@ func WxPayCallBack(notifyReq *wechat.V3NotifyReq, wxConfig WxPay) error {
|
||||||
// 订单状态
|
// 订单状态
|
||||||
switch CallBackInfo.TradeState {
|
switch CallBackInfo.TradeState {
|
||||||
case "SUCCESS":
|
case "SUCCESS":
|
||||||
|
orderStatus = common.ORDER_STATUS_PAYED
|
||||||
errCode = errorcode.Success
|
errCode = errorcode.Success
|
||||||
msg = "支付成功"
|
msg = "支付成功"
|
||||||
case "CLOSED":
|
case "CLOSED":
|
||||||
errCode = errorcode.ParamError
|
errCode = errorcode.ParamError
|
||||||
|
orderStatus = common.ORDER_STATUS_CLOSE
|
||||||
msg = "已关闭"
|
msg = "已关闭"
|
||||||
case "REVOKED":
|
case "REVOKED":
|
||||||
errCode = errorcode.ParamError
|
errCode = errorcode.ParamError
|
||||||
|
orderStatus = common.ORDER_STATUS_FAILED
|
||||||
msg = "已撤销(付款码支付)"
|
msg = "已撤销(付款码支付)"
|
||||||
case "PAYERROR":
|
case "PAYERROR":
|
||||||
errCode = errorcode.ParamError
|
errCode = errorcode.ParamError
|
||||||
msg = "支付失败(其他原因,如银行返回失败)"
|
msg = "支付失败(其他原因,如银行返回失败)"
|
||||||
|
orderStatus = common.ORDER_STATUS_FAILED
|
||||||
}
|
}
|
||||||
|
|
||||||
// 触发下游回调的格式
|
// 触发下游回调的格式
|
||||||
orderId, _ := strconv.Atoi(CallBackInfo.OutTradeNo)
|
orderId, _ := strconv.Atoi(CallBackInfo.OutTradeNo)
|
||||||
res := thirdpay_notify.NewOrderNotifyWithHandle(int64(orderId), errCode, int(CallBackInfo.Amount.PayerTotal), msg)
|
res := thirdpay_notify.NewOrderNotifyWithHandle(int64(orderId), orderStatus, errCode, int(CallBackInfo.Amount.PayerTotal), msg)
|
||||||
merchantCallback, _ := json.Marshal(res)
|
merchantCallback, _ := json.Marshal(res)
|
||||||
// 记录日志
|
// 记录日志
|
||||||
go func() {
|
go func() {
|
||||||
|
@ -224,8 +229,8 @@ func WxOrderRefund(ctx context.Context, orderRefundRequest OrderRefundRequest) (
|
||||||
SetBodyMap("amount", func(bm gopay.BodyMap) {
|
SetBodyMap("amount", func(bm gopay.BodyMap) {
|
||||||
// 退款金额:单位是分
|
// 退款金额:单位是分
|
||||||
bm.Set("refund", orderRefundRequest.RefundAmount). //实际退款金额
|
bm.Set("refund", orderRefundRequest.RefundAmount). //实际退款金额
|
||||||
Set("total", orderRefundRequest.RefundAmount). // 折扣前总金额(不是实际退款数)
|
Set("total", orderRefundRequest.RefundAmount). // 折扣前总金额(不是实际退款数)
|
||||||
Set("currency", "CNY")
|
Set("currency", "CNY")
|
||||||
})
|
})
|
||||||
// body:参数Body
|
// body:参数Body
|
||||||
refund, err := wxClient.V3Refund(ctx, bm)
|
refund, err := wxClient.V3Refund(ctx, bm)
|
||||||
|
|
Loading…
Reference in New Issue