first commit
This commit is contained in:
@@ -0,0 +1,45 @@
|
||||
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
|
||||
}
|
||||
Reference in New Issue
Block a user