|
|
|
@ -3,6 +3,7 @@ package server
|
|
|
|
|
import (
|
|
|
|
|
"sync"
|
|
|
|
|
_ "fmt"
|
|
|
|
|
"FRMS/internal/pkg/logging"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// package will create and maintain a concurrent system structure
|
|
|
|
@ -23,8 +24,9 @@ func NewStatusMonitor(ch chan *DeviceInfo) *StatusMonitor {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type InfoStream struct {
|
|
|
|
|
// used for reactor and device status streams
|
|
|
|
|
sync.Mutex
|
|
|
|
|
// base stream for any reactor/device
|
|
|
|
|
// NewSender embedds the channel to send updates on
|
|
|
|
|
// NewListener will add the statusmon to the list of devs to echo to
|
|
|
|
|
Stream chan *DeviceInfo
|
|
|
|
|
Layout *syslayout
|
|
|
|
|
}
|
|
|
|
@ -32,7 +34,7 @@ type InfoStream struct {
|
|
|
|
|
type syslayout struct {
|
|
|
|
|
Devs map[uint32]*DeviceInfo
|
|
|
|
|
uint32 //index
|
|
|
|
|
sync.Mutex
|
|
|
|
|
sync.RWMutex
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewInfoStream() *InfoStream {
|
|
|
|
@ -56,32 +58,48 @@ func (s *InfoStream) AddSender() *StatusMonitor {
|
|
|
|
|
func (s *InfoStream) Listener() {
|
|
|
|
|
for {
|
|
|
|
|
deviceInfo := <-s.Stream
|
|
|
|
|
go s.Layout.Update(deviceInfo)
|
|
|
|
|
go s.Update(deviceInfo)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (s *syslayout) Update(d *DeviceInfo) {
|
|
|
|
|
s.Lock()
|
|
|
|
|
defer s.Unlock()
|
|
|
|
|
// set index to be kept for the entire time the dev exists
|
|
|
|
|
if dev, ok := s.Devs[d.Id]; !ok {
|
|
|
|
|
d.Index = s.uint32
|
|
|
|
|
s.uint32 += 1
|
|
|
|
|
func (s *InfoStream) Update(d *DeviceInfo) {
|
|
|
|
|
s.Layout.Lock()
|
|
|
|
|
if dev, ok := s.Layout.Devs[d.Id]; !ok {
|
|
|
|
|
d.Index = s.Layout.uint32
|
|
|
|
|
s.Layout.uint32 += 1
|
|
|
|
|
} else {
|
|
|
|
|
d.Index = dev.Index
|
|
|
|
|
}
|
|
|
|
|
s.Devs[d.Id] = d
|
|
|
|
|
s.Layout.Devs[d.Id] = d
|
|
|
|
|
go s.Echo(d)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (s *InfoStream) Echo(d *DeviceInfo) {
|
|
|
|
|
s.Listeners.RLock()
|
|
|
|
|
defer s.Listeners.RUnlock()
|
|
|
|
|
// read only lock
|
|
|
|
|
for _, lis := range s.Listeners {
|
|
|
|
|
go func(){
|
|
|
|
|
lis <-d
|
|
|
|
|
}()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (s *InfoStream) GetLayout() map[uint32]*DeviceInfo {
|
|
|
|
|
s.Layout.Lock()
|
|
|
|
|
defer s.Layout.Unlock()
|
|
|
|
|
return s.Layout.Devs
|
|
|
|
|
func (s *InfoStream) AddListner(ch chan *DeviceInfo) {
|
|
|
|
|
s.Listeners.Lock()
|
|
|
|
|
defer s.Listeners.Unlock()
|
|
|
|
|
s.Listeners = append(s.Listeners, ch)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//func (s *InfoStream) GetLayout() map[uint32]*DeviceInfo {
|
|
|
|
|
//s.Layout.RLock()
|
|
|
|
|
//defer s.Layout.RUnlock()
|
|
|
|
|
//return s.Layout.Devs
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
// status buffer maintaince
|
|
|
|
|
type StatusMonitor struct {
|
|
|
|
|
// serve as base to embed in managers to send/receive reactor info
|
|
|
|
|
// serve as base to embed in managers to send/receive device info
|
|
|
|
|
TransactionId chan uint32 // monotonically increases to track outdated reqs
|
|
|
|
|
StatusChan chan *DeviceInfo // sending reactor info in same fmt
|
|
|
|
|
}
|
|
|
|
@ -101,6 +119,7 @@ func (s *StatusMonitor) GenerateIds() {
|
|
|
|
|
|
|
|
|
|
func (s *StatusMonitor) Send(d *DeviceInfo) {
|
|
|
|
|
d.TransactionId = <-s.TransactionId
|
|
|
|
|
logging.Debug(logging.DClient,"SYS 01 Updating %s Info (%s, %s)", d.Type, d.Status, d.Data)
|
|
|
|
|
s.StatusChan <-d
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|