Files
wechat_ipad_pro/srv/wxrouter/wxreceivehb.go
2026-02-17 13:06:23 +08:00

70 lines
1.9 KiB
Go

package wxrouter
import (
"encoding/json"
"time"
"xiawan/wx/clientsdk"
"xiawan/wx/clientsdk/baseinfo"
"xiawan/wx/clientsdk/baseutils"
"xiawan/wx/protobuf/wechat"
"xiawan/wx/srv/wxcore"
"xiawan/wx/srv/wxface"
)
// WXReceiveHBRouter 接收红包响应处理器
type WXReceiveHBRouter struct {
wxcore.WXBaseRouter
}
// Handle 处理conn业务的方法
func (hbr *WXReceiveHBRouter) Handle(wxResp wxface.IWXResponse) error {
defer wxcore.TryE("WXReceiveHBRouter Handle")
currentWXConn := wxResp.GetWXConncet()
currentWXAccount := currentWXConn.GetWXAccount()
currentUserInfo := currentWXAccount.GetUserInfo()
currentTaskMgr := currentWXConn.GetWXTaskMgr()
currentReqInvoker := currentWXConn.GetWXReqInvoker()
taskMgr, _ := currentTaskMgr.(*wxcore.WXTaskMgr)
currentGrabHBMgr := taskMgr.GetGrabHBTask()
// 心跳包响应
var hongbaoResp wechat.HongBaoRes
err := clientsdk.ParseResponseData(currentUserInfo, wxResp.GetPackHeader(), &hongbaoResp)
if err != nil {
// 请求出问题了,判断是否掉线,并重连
time.Sleep(1 * time.Second)
go currentWXConn.CheckOnLineStatusLogin()
return err
}
// 如果 返回错误码
if hongbaoResp.GetErrorType() != 0 {
baseutils.PrintLog("WXReceiveHBRouter err: " + hongbaoResp.GetErrorMsg())
// 抢下一个红包
currentGrabHBMgr.GrapNext()
return nil
}
// 解析
retHongBaoReceiveResp := &baseinfo.HongBaoReceiverResp{}
err = json.Unmarshal(hongbaoResp.GetRetText().GetBuffer(), retHongBaoReceiveResp)
baseutils.PrintLog("WXReceiveHBRouter retHongBaoReceiveResp: " + retHongBaoReceiveResp.TimingIdentifier)
if err != nil {
// 抢下一个红包
currentGrabHBMgr.GrapNext()
return err
}
// 如果都没问题,就打开红包
currentHBItem := currentGrabHBMgr.GetCurrentHBItem()
err = currentReqInvoker.SendOpenWxHBRequest(currentHBItem, retHongBaoReceiveResp.TimingIdentifier)
if err != nil {
// 抢下一个红包
currentGrabHBMgr.GrapNext()
return err
}
return nil
}