46 lines
1.3 KiB
Go
46 lines
1.3 KiB
Go
package wxrouter
|
|
|
|
import (
|
|
"time"
|
|
"xiawan/wx/clientsdk"
|
|
"xiawan/wx/protobuf/wechat"
|
|
"xiawan/wx/srv/wxcore"
|
|
"xiawan/wx/srv/wxface"
|
|
|
|
"github.com/lunny/log"
|
|
)
|
|
|
|
// WXHeartBeatRouter 心跳包响应路由
|
|
type WXHeartBeatRouter struct {
|
|
wxcore.WXBaseRouter
|
|
}
|
|
|
|
// Handle 处理conn业务的方法
|
|
func (hbr *WXHeartBeatRouter) Handle(wxResp wxface.IWXResponse) error {
|
|
defer wxcore.TryE("WXHeartBeatRouter Handle")
|
|
currentWXConn := wxResp.GetWXConncet()
|
|
currentWXAccount := currentWXConn.GetWXAccount()
|
|
currentUserInfo := currentWXAccount.GetUserInfo()
|
|
|
|
// 解析心跳包响应
|
|
var hearBeatResp wechat.HeartBeatResponse
|
|
err := clientsdk.ParseResponseData(currentUserInfo, wxResp.GetPackHeader(), &hearBeatResp)
|
|
if err != nil {
|
|
// 请求出问题了,判断是否掉线,并重连
|
|
time.Sleep(1 * time.Second)
|
|
go currentWXConn.CheckOnLineStatusLogin()
|
|
return err
|
|
}
|
|
if hearBeatResp.GetBaseResponse().GetRet() == 0 {
|
|
log.Printf("[%s],[%s] HeartBeatSuccess \n", currentUserInfo.GetUserName(), currentUserInfo.NickName)
|
|
currentWXConn.StopShortReader()
|
|
// 获取当前时间 秒
|
|
nowTime := time.Now().Unix()
|
|
currentWXConn.SetHeartBeatTime(nowTime)
|
|
}
|
|
//fmt.Println("心跳--->", hearBeatResp.GetBaseResponse().GetRet())
|
|
// 等待 NextTime后再次发送心跳包
|
|
currentWXConn.SendHeartBeatWaitingSeconds(hearBeatResp.GetNextTime())
|
|
return nil
|
|
}
|