代码拉取完成,页面将自动刷新
package message_center
import (
"context"
"sync"
"time"
"gitee.com/prestonTao/keystore"
"gitee.com/prestonTao/libp2parea/config"
"gitee.com/prestonTao/libp2parea/engine"
"gitee.com/prestonTao/libp2parea/nodeStore"
"gitee.com/prestonTao/libp2parea/virtual_node"
"gitee.com/prestonTao/utils"
"gitee.com/prestonTao/utils/utilsleveldb"
)
type MessageCenter struct {
key keystore.KeystoreInterface //
nodeManager *nodeStore.NodeManager //
sessionEngine *engine.Engine //
router *Router //
vm *virtual_node.VnodeManager //
RatchetSession *SessionManager //
securityStore map[string]map[string]*SearchNodeInfo // map[addr]map[machineId]*SearchNodeInfo
securityStoreLock *sync.RWMutex //
contextRoot context.Context //
// msgchannl chan *MsgHolderOne //
msgchannl *utils.ChanDynamic //
msgHolderLock *sync.RWMutex //
msgHolder map[string]*MsgHolder // new(sync.Map)
msgHashTask *utils.Task //
msgHashMap *sync.Map //
levelDB *utilsleveldb.LevelDB //
areaName []byte // 区域名称
}
func NewMessageCenter(nodeManager *nodeStore.NodeManager, sessionEngine *engine.Engine,
vm *virtual_node.VnodeManager, key keystore.KeystoreInterface, c context.Context, areaName []byte) *MessageCenter {
rsm := NewSessionManager()
mc := &MessageCenter{
key: key,
nodeManager: nodeManager,
sessionEngine: sessionEngine,
router: NewRouter(),
vm: vm,
RatchetSession: &rsm,
securityStore: make(map[string]map[string]*SearchNodeInfo),
securityStoreLock: new(sync.RWMutex),
contextRoot: c,
// msgchannl: make(chan *MsgHolderOne, 1000),
msgchannl: utils.NewChanDynamic(10000),
msgHolderLock: new(sync.RWMutex),
msgHolder: make(map[string]*MsgHolder), //
msgHashMap: new(sync.Map),
areaName: areaName,
}
mc.msgHashTask = utils.NewTask(mc.sendhashTaskFun)
mc.Init()
return mc
}
/*
销毁
*/
func (this *MessageCenter) Destroy() {
this.msgHashTask.Destroy()
}
/*
设置数据库
*/
func (this *MessageCenter) SetLevelDB(leveldb *utilsleveldb.LevelDB) {
this.levelDB = leveldb
}
/*
检查节点是否在线
*/
func (this *MessageCenter) CheckOnline() bool {
sessions := this.sessionEngine.GetAllSession(this.areaName)
if len(sessions) > 0 {
// engine.Log.Info("连接数量:%d", len(sessions))
// for _, one := range sessions {
// this.nodeManager.GetNodesClient()
// engine.Log.Info("连接节点地址:%s RemoteHost:%s", nodeStore.AddressNet([]byte(one.GetName())).B58String(), one.GetRemoteHost())
// }
return true
}
return false
}
/*
检查节点是否在线
*/
func (this *MessageCenter) sendhashTaskFun(class string, params []byte) {
this.msgHashMap.Delete(utils.Bytes2string(params))
}
/*
检查重复消息,检查这个消息是否发送过
@return bool 是否重复。true=重复;false=不重复;
*/
func (this *MessageCenter) CheckRepeatHash(sendhash []byte) bool {
_, ok := this.msgHashMap.Load(utils.Bytes2string(sendhash))
if !ok {
this.msgHashMap.Store(utils.Bytes2string(sendhash), nil)
this.msgHashTask.Add(time.Now().Unix()+config.MsgCacheTimeOver, "", sendhash)
}
return ok
}
/*
* 清理加密通道信息
*/
func (this *MessageCenter) CleanHEInfo(id nodeStore.AddressNet, machineId string) {
if this.securityStore != nil {
strKey := utils.Bytes2string(id)
delete(this.securityStore, strKey)
}
this.RatchetSession.RemoveSendPipe(id, machineId)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。