You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
lal/app/demo/dispatch/datamanager/data.go

53 lines
1.4 KiB
Go

// Copyright 2020, Chef. All rights reserved.
// https://github.com/q191201771/lal
//
// Use of this source code is governed by a MIT-style license
// that can be found in the License file.
//
// Author: Chef (191201771@qq.com)
package datamanager
import (
"sync"
"github.com/q191201771/naza/pkg/nazalog"
)
type DataManagerMemory struct {
mutex sync.Mutex
pubStream2ServerID map[string]string
}
func NewDataManagerMemory() *DataManagerMemory {
return &DataManagerMemory{
pubStream2ServerID: make(map[string]string),
}
}
func (d *DataManagerMemory) AddPub(streamName, serverID string) {
d.mutex.Lock()
defer d.mutex.Unlock()
nazalog.Infof("add pub. streamName=%s, serverID=%s", streamName, serverID)
d.pubStream2ServerID[streamName] = serverID
}
func (d *DataManagerMemory) DelPub(streamName, serverID string) {
d.mutex.Lock()
defer d.mutex.Unlock()
// 清除用户推流对应的节点信息
cacheServerID, exist := d.pubStream2ServerID[streamName]
if !exist || serverID != cacheServerID {
nazalog.Errorf("del pub but server id dismatch. streamName=%s, serverID=%s, cache id=%s", streamName, serverID, cacheServerID)
return
}
delete(d.pubStream2ServerID, streamName)
}
func (d *DataManagerMemory) QueryPub(streamName string) (serverID string, exist bool) {
d.mutex.Lock()
defer d.mutex.Unlock()
serverID, exist = d.pubStream2ServerID[streamName]
return
}