|
@ -7,15 +7,13 @@ import ( |
|
|
"hudongzhuanjia/logger" |
|
|
"hudongzhuanjia/logger" |
|
|
"hudongzhuanjia/models" |
|
|
"hudongzhuanjia/models" |
|
|
im_service "hudongzhuanjia/services/im" |
|
|
im_service "hudongzhuanjia/services/im" |
|
|
"hudongzhuanjia/utils/define" |
|
|
|
|
|
"time" |
|
|
"time" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
//处理支付成功之后的回调问题
|
|
|
//处理支付成功之后的回调问题
|
|
|
|
|
|
|
|
|
// 直播红包
|
|
|
// 直播红包
|
|
|
func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
|
|
|
var exist bool |
|
|
|
|
|
|
|
|
func HandleSuccess(param *OrderDelayQueueParam) error { |
|
|
if param.Order.GoodType == 4 { // 直播商品
|
|
|
if param.Order.GoodType == 4 { // 直播商品
|
|
|
customerOrder := new(models.CustomerOrder) |
|
|
customerOrder := new(models.CustomerOrder) |
|
|
_, err := customerOrder.UpdateStatusBy(param.Order.OutTradeNo, 0, 1) |
|
|
_, err := customerOrder.UpdateStatusBy(param.Order.OutTradeNo, 0, 1) |
|
@ -48,7 +46,7 @@ func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
activity := new(models.Activity) |
|
|
activity := new(models.Activity) |
|
|
exist, err = models.Get(activity, param.Order.ActivityId) |
|
|
|
|
|
|
|
|
exist, err := models.Get(activity, param.Order.ActivityId) |
|
|
if err != nil || !exist { |
|
|
if err != nil || !exist { |
|
|
return errors.New("互动信息异常") |
|
|
return errors.New("互动信息异常") |
|
|
} |
|
|
} |
|
@ -56,10 +54,13 @@ func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
gift := new(models.OrderGift) |
|
|
gift := new(models.OrderGift) |
|
|
exist, err = gift.GetByActivityId(param.Order.ActivityId) |
|
|
exist, err = gift.GetByActivityId(param.Order.ActivityId) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
|
|
|
err = fmt.Errorf("获取订单送礼错误: err-> %v, activity_id-> %v", err, activity.Id) |
|
|
|
|
|
logger.Error(err) |
|
|
return err |
|
|
return err |
|
|
} |
|
|
} |
|
|
if !exist || gift.OrderGiftSwitch == define.StatusClose { |
|
|
|
|
|
return |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if !exist { |
|
|
|
|
|
return nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
prize := new(models.UserPrize) |
|
|
prize := new(models.UserPrize) |
|
@ -84,7 +85,7 @@ func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if gift.Num <= int(count) { // 人数足够
|
|
|
if gift.Num <= int(count) { // 人数足够
|
|
|
return |
|
|
|
|
|
|
|
|
return nil |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
_, err = prize.Add() |
|
|
_, err = prize.Add() |
|
@ -103,18 +104,18 @@ func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
} |
|
|
} |
|
|
} else if param.Order.GoodType == 3 { // 直播红包
|
|
|
} else if param.Order.GoodType == 3 { // 直播红包
|
|
|
info := new(models.LiveRedEnvelopeRule) |
|
|
info := new(models.LiveRedEnvelopeRule) |
|
|
_, err = info.UpdateStatusByOutTradeNo(param.Order.OutTradeNo, 1) |
|
|
|
|
|
|
|
|
_, err := info.UpdateStatusByOutTradeNo(param.Order.OutTradeNo, 1) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
err = fmt.Errorf("状态改变出现错误: err->%v, out_trade_no->%v", err, param.Order.OutTradeNo) |
|
|
err = fmt.Errorf("状态改变出现错误: err->%v, out_trade_no->%v", err, param.Order.OutTradeNo) |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
return |
|
|
|
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
exist, err = info.GetByOutTradeNo(param.Order.OutTradeNo) |
|
|
|
|
|
|
|
|
exist, err := info.GetByOutTradeNo(param.Order.OutTradeNo) |
|
|
if err != nil || !exist || info.Status != 1 { |
|
|
if err != nil || !exist || info.Status != 1 { |
|
|
err = fmt.Errorf("直播红包信息异常: err-> %v, exist->%v, status->%v, out_trade_no->%v", |
|
|
err = fmt.Errorf("直播红包信息异常: err-> %v, exist->%v, status->%v, out_trade_no->%v", |
|
|
err, exist, info.Status, param.Order.OutTradeNo) |
|
|
err, exist, info.Status, param.Order.OutTradeNo) |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
return |
|
|
|
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
err = im_service.SendGroupCustomMessage(info.UserId, param.Order.ActivityId, im_service.NoticeLiveRedPackStart, |
|
|
err = im_service.SendGroupCustomMessage(info.UserId, param.Order.ActivityId, im_service.NoticeLiveRedPackStart, |
|
@ -127,27 +128,29 @@ func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
err = fmt.Errorf("发送腾讯im信息出现错误: err->%v, info_id->%v, out_trade_no->%v", |
|
|
err = fmt.Errorf("发送腾讯im信息出现错误: err->%v, info_id->%v, out_trade_no->%v", |
|
|
err, info.Id, param.Order.OutTradeNo) |
|
|
err, info.Id, param.Order.OutTradeNo) |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
} else if param.Order.GoodType == 2 { // 打赏
|
|
|
} else if param.Order.GoodType == 2 { // 打赏
|
|
|
history := new(models.RewardHistory) |
|
|
history := new(models.RewardHistory) |
|
|
exist, err = history.GetByOutTradeNo(param.Order.OutTradeNo) |
|
|
|
|
|
|
|
|
exist, err := history.GetByOutTradeNo(param.Order.OutTradeNo) |
|
|
if err != nil || !exist || history.Status != -1 { |
|
|
if err != nil || !exist || history.Status != -1 { |
|
|
err = fmt.Errorf("打赏历史异常: err->%v, out_trade_no %v", err, param.Order.OutTradeNo) |
|
|
err = fmt.Errorf("打赏历史异常: err->%v, out_trade_no %v", err, param.Order.OutTradeNo) |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
return |
|
|
|
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
_, err = history.UpdateStatus(history.Id, 0) |
|
|
_, err = history.UpdateStatus(history.Id, 0) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
err = fmt.Errorf("打赏状态发送变化: err->%v, out_trade_no %v", err, param.Order.OutTradeNo) |
|
|
err = fmt.Errorf("打赏状态发送变化: err->%v, out_trade_no %v", err, param.Order.OutTradeNo) |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
} else if param.Order.GoodType == 1 { // 霸屏
|
|
|
} else if param.Order.GoodType == 1 { // 霸屏
|
|
|
history := new(models.BullyScreenHistory) |
|
|
history := new(models.BullyScreenHistory) |
|
|
exist, err = history.GetByOutTradeNo(param.Order.OutTradeNo) |
|
|
|
|
|
|
|
|
exist, err := history.GetByOutTradeNo(param.Order.OutTradeNo) |
|
|
if err != nil || !exist || history.Status != -1 { |
|
|
if err != nil || !exist || history.Status != -1 { |
|
|
err = fmt.Errorf("打赏历史异常: err->%v, out_trade_no %v", err, param.Order.OutTradeNo) |
|
|
err = fmt.Errorf("打赏历史异常: err->%v, out_trade_no %v", err, param.Order.OutTradeNo) |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
return |
|
|
|
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
_, err = history.UpdateStatus(history.Id, 0) |
|
|
_, err = history.UpdateStatus(history.Id, 0) |
|
@ -156,7 +159,7 @@ func HandleSuccess(param *OrderDelayQueueParam) (err error) { |
|
|
logger.Error(err.Error()) |
|
|
logger.Error(err.Error()) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
return |
|
|
|
|
|
|
|
|
return nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func HandleFailed(param *OrderDelayQueueParam) (err error) { |
|
|
func HandleFailed(param *OrderDelayQueueParam) (err error) { |
|
|