|
@@ -128,7 +128,7 @@ func GetHaverEquallyOrderByUser10MinByActivty(userId, sourceId int) (orderCode s
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-// 处理订单回调
|
|
|
+// 处理支付订单回调
|
|
|
func HandleOrderHandle(itemCallback *WechatPayCallback) {
|
|
|
var err error
|
|
|
defer func() {
|
|
@@ -156,7 +156,6 @@ func HandleOrderHandle(itemCallback *WechatPayCallback) {
|
|
|
if orderDetail.OrderStatus == 2 {
|
|
|
return
|
|
|
}
|
|
|
- go AddCygxOrderPayment(itemCallback) // 记录支付交易信息
|
|
|
|
|
|
itemOrder := new(order.CygxOrder)
|
|
|
itemOrder.OrderCode = itemCallback.OutTradeNo
|
|
@@ -245,3 +244,82 @@ func AddCygxOrderPayment(itemCallback *WechatPayCallback) {
|
|
|
}
|
|
|
return
|
|
|
}
|
|
|
+
|
|
|
+// 处理退款订单回调
|
|
|
+func HandleOrderRefundHandle(itemCallback *WechatPayCallback) {
|
|
|
+ var err error
|
|
|
+ defer func() {
|
|
|
+ if err != nil {
|
|
|
+ fmt.Println(err)
|
|
|
+ go utils.SendAlarmMsg(fmt.Sprint("处理退款订单回调信息失败 HandleOrderRefundHandle, err:", err.Error()), 2)
|
|
|
+ }
|
|
|
+ }()
|
|
|
+ outTradeNo := itemCallback.OutTradeNo
|
|
|
+ orderDetail, e := order.GetCygxOrderDetailByOrderCode(outTradeNo)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetCygxOrderDetailByOrderCode, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ //go AddCygxOrderPayment(itemCallback) // 记录支付交易信息
|
|
|
+
|
|
|
+ //修改过状态的不再二次处理
|
|
|
+ if orderDetail.OrderStatus == 3 {
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ itemOrder := new(order.CygxOrder)
|
|
|
+ itemOrder.OrderCode = itemCallback.OutTradeNo
|
|
|
+ itemOrder.RefundTime = itemCallback.SuccessTime
|
|
|
+ itemOrder.RefundMoney = float64(float64(itemCallback.Amount.PayerTotal) / 100) // 金额分转换处理
|
|
|
+ itemOrder.OrderStatus = 3
|
|
|
+
|
|
|
+ //文章处理逻辑 OrderType int `comment:"订单类型,1:畅读卡订单,2:单场付费订单"`
|
|
|
+ if orderDetail.OrderType == 1 {
|
|
|
+ itemUserCard := new(order.CygxOrderUserCard)
|
|
|
+ itemUserCard.OrderCode = orderDetail.OrderCode
|
|
|
+ itemUserCard.UserId = orderDetail.UserId
|
|
|
+ itemUserCard.Mobile = orderDetail.Mobile
|
|
|
+ itemUserCard.Email = orderDetail.Email
|
|
|
+ itemUserCard.CompanyId = orderDetail.CompanyId
|
|
|
+ itemUserCard.CompanyName = orderDetail.CompanyName
|
|
|
+ itemUserCard.RealName = orderDetail.RealName
|
|
|
+ itemUserCard.SellerName = orderDetail.SellerName
|
|
|
+ itemUserCard.CreateTime = time.Now()
|
|
|
+ itemUserCard.ModifyTime = time.Now()
|
|
|
+ itemUserCard.RegisterPlatform = orderDetail.RegisterPlatform
|
|
|
+
|
|
|
+ if orderDetail.GoodsId == 1 {
|
|
|
+ itemUserCard.CardType = "日卡"
|
|
|
+ } else {
|
|
|
+ itemUserCard.CardType = "月卡"
|
|
|
+ }
|
|
|
+ e = order.RemoveCygxOrderUserCard(itemUserCard, itemOrder) // 移除用户
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("RemoveCygxOrderUserCard, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ } else if orderDetail.OrderType == 2 {
|
|
|
+ //如果是活动,把单场付费信息的活动写入 用户虚拟资产表
|
|
|
+ itemOrderVirtualAsset := new(order.CygxOrderVirtualAsset)
|
|
|
+ itemOrderVirtualAsset.OrderCode = orderDetail.OrderCode
|
|
|
+ itemOrderVirtualAsset.UserId = orderDetail.UserId
|
|
|
+ itemOrderVirtualAsset.Mobile = orderDetail.Mobile
|
|
|
+ itemOrderVirtualAsset.Email = orderDetail.Email
|
|
|
+ itemOrderVirtualAsset.CompanyId = orderDetail.CompanyId
|
|
|
+ itemOrderVirtualAsset.CompanyName = orderDetail.CompanyName
|
|
|
+ itemOrderVirtualAsset.RealName = orderDetail.RealName
|
|
|
+ itemOrderVirtualAsset.SellerName = orderDetail.SellerName
|
|
|
+ itemOrderVirtualAsset.Source = orderDetail.Source
|
|
|
+ itemOrderVirtualAsset.SourceId = orderDetail.SourceId
|
|
|
+ itemOrderVirtualAsset.CreateTime = time.Now()
|
|
|
+ itemOrderVirtualAsset.ModifyTime = time.Now()
|
|
|
+ e = order.RemoveCygxOrderVirtualAsset(itemOrderVirtualAsset, itemOrder)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("AddCygxOrderVirtualAsset, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+ fmt.Println(orderDetail.Source)
|
|
|
+ return
|
|
|
+}
|