freifunkmanager/websocket/hd_connect.go

54 lines
1.4 KiB
Go
Raw Normal View History

package websocket
import (
log "github.com/sirupsen/logrus"
2018-07-26 14:14:23 +02:00
wsLib "dev.sum7.eu/genofire/golang-lib/websocket"
2018-07-15 21:04:17 +02:00
"github.com/FreifunkBremen/freifunkmanager/runtime"
)
2018-07-15 21:04:17 +02:00
var wifi24Channels []uint32
var wifi5Channels []uint32
func (ws *WebsocketServer) connectHandler(logger *log.Entry, msg *wsLib.Message) error {
2018-07-26 14:14:23 +02:00
//msg.From.Write(&wsLib.Message{Subject: MessageTypeStats, Body: ws.nodes.Statistics})
var nodes []*runtime.Node
var count int
ws.db.Find(&nodes).Count(&count)
ws.nodes.Lock()
i := 0
for _, node := range ws.nodes.List {
2018-07-27 14:09:31 +02:00
n := runtime.NewNode(node, "")
if n == nil {
continue
}
n.Lastseen = node.Lastseen
msg.From.Write(&wsLib.Message{Subject: MessageTypeCurrentNode, Body: n})
2018-07-26 14:14:23 +02:00
i++
}
ws.nodes.Unlock()
for _, node := range nodes {
msg.From.Write(&wsLib.Message{Subject: MessageTypeSystemNode, Body: node})
}
2018-07-15 21:04:17 +02:00
msg.From.Write(&wsLib.Message{Subject: MessageTypeChannelsWifi24, Body: wifi24Channels})
msg.From.Write(&wsLib.Message{Subject: MessageTypeChannelsWifi5, Body: wifi5Channels})
2018-07-26 14:14:23 +02:00
logger.Debugf("done - fetch %d nodes and send %d", count, i)
return nil
}
2018-07-15 21:04:17 +02:00
func init() {
for ch, channel := range runtime.ChannelList {
if runtime.ChannelEU && !channel.AllowedInEU {
continue
}
if channel.Frequenz > runtime.FREQ_THREASHOLD {
wifi5Channels = append(wifi5Channels, ch)
} else {
wifi24Channels = append(wifi24Channels, ch)
}
}
}