modify websocketserver to broker with callback functions
This commit is contained in:
@@ -11,13 +11,13 @@ import (
|
||||
|
||||
"github.com/tecamino/tecamino-dbm/args"
|
||||
"github.com/tecamino/tecamino-dbm/models"
|
||||
serverModels "github.com/tecamino/tecamino-dbm/server/models"
|
||||
ws "github.com/tecamino/tecamino-dbm/websocket"
|
||||
"github.com/tecamino/tecamino-logger/logging"
|
||||
)
|
||||
|
||||
type DBMHandler struct {
|
||||
DBM *models.DBM
|
||||
Conns *serverModels.Connections
|
||||
Conns *ws.ClientHandler
|
||||
sync.RWMutex
|
||||
Log *logging.Logger
|
||||
arg *args.Args
|
||||
@@ -43,7 +43,7 @@ func NewDbmHandler(a *args.Args) (*DBMHandler, error) {
|
||||
logger.Info("main", "start dma handler")
|
||||
|
||||
//initialize connection map
|
||||
conns := serverModels.NewConnections()
|
||||
conns := ws.NewConnectionHandler()
|
||||
|
||||
// Initialize dtabase manager handler
|
||||
dmaHandler := DBMHandler{
|
||||
@@ -74,8 +74,8 @@ func NewDbmHandler(a *args.Args) (*DBMHandler, error) {
|
||||
var line int
|
||||
for scanner.Scan() {
|
||||
line++
|
||||
dp := models.Datapoint{}
|
||||
if err = json.Unmarshal(scanner.Bytes(), &dp); err != nil {
|
||||
dp := &models.Datapoint{}
|
||||
if err = json.Unmarshal(scanner.Bytes(), dp); err != nil {
|
||||
dmaHandler.Log.Error("dmbHandler.NewDmbHandler", "error in line "+fmt.Sprint(line)+" "+scanner.Text())
|
||||
dmaHandler.Log.Error("dmbHandler.NewDmbHandler", err.Error())
|
||||
|
||||
|
@@ -51,7 +51,6 @@ func (d *DBMHandler) Json_Data(c *gin.Context) {
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
c.JSON(200, resp)
|
||||
}
|
||||
|
||||
|
@@ -36,7 +36,14 @@ func (d *DBMHandler) Subscribe(req *json_dataModels.Request, id string) {
|
||||
continue
|
||||
}
|
||||
}
|
||||
dp.AddSubscribtion(id, sub)
|
||||
|
||||
client := d.DBM.Conns.GetClient(id)
|
||||
if client == nil {
|
||||
d.Log.Warning("subscribe", "id "+id+" not found")
|
||||
continue
|
||||
}
|
||||
|
||||
dp.AddSubscribtion(client, sub)
|
||||
resp.AddSubscription(json_dataModels.Subscription{
|
||||
Uuid: dp.Uuid,
|
||||
Path: dp.Path,
|
||||
@@ -68,10 +75,17 @@ func (d *DBMHandler) Unsubscribe(req *json_dataModels.Request, id string) {
|
||||
|
||||
for _, sub := range req.Unsubscribe {
|
||||
for _, dp := range d.DBM.QueryDatapoints(sub.Depth, sub.Uuid, sub.Path) {
|
||||
if _, ok := dp.Subscriptions[id]; !ok {
|
||||
|
||||
client := d.DBM.Conns.GetClient(id)
|
||||
if client == nil {
|
||||
d.Log.Warning("subscribe", "id "+id+" not found")
|
||||
continue
|
||||
}
|
||||
dp.RemoveSubscribtion(id)
|
||||
|
||||
if _, ok := dp.Subscriptions[client]; !ok {
|
||||
continue
|
||||
}
|
||||
dp.RemoveSubscribtion(client)
|
||||
resp.AddUnsubscription(json_dataModels.Subscription{
|
||||
Uuid: dp.Uuid,
|
||||
Path: dp.Path,
|
||||
|
@@ -2,11 +2,7 @@ package dbm
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"io"
|
||||
|
||||
"github.com/coder/websocket"
|
||||
"github.com/gin-gonic/gin"
|
||||
"github.com/tecamino/tecamino-dbm/auth"
|
||||
json_dataModels "github.com/tecamino/tecamino-json_data/models"
|
||||
@@ -26,76 +22,33 @@ func (d *DBMHandler) WebSocket(c *gin.Context) {
|
||||
}
|
||||
d.Log.Debug("dbmHandler.webSocket.Websocket", "authorization id token: "+id)
|
||||
|
||||
err = d.Conns.ConnectRecievingWsConnection(id, c)
|
||||
defer d.Conns.RemoveClient(id)
|
||||
client, err := d.Conns.ConnectNewClient(id, c)
|
||||
if err != nil {
|
||||
d.Log.Error("dbmHandler.webSocket.Websocket", "error connecting recieving websocket conection: "+err.Error())
|
||||
d.Log.Error("dbmHandler.webSocket.Websocket", err)
|
||||
return
|
||||
}
|
||||
defer d.Conns.DisconnectWsConnection(id, websocket.StatusInternalError, "Internal error")
|
||||
|
||||
//Read loop
|
||||
for {
|
||||
|
||||
request, err := d.readJsonData(id)
|
||||
client.OnMessage = func(data []byte) {
|
||||
request, err := d.readJsonData(data)
|
||||
if err != nil {
|
||||
d.Log.Error("websocket.WebSocket", err.Error())
|
||||
break
|
||||
d.Log.Error("dbmHandler.webSocket.Websocket", "read json: "+err.Error())
|
||||
}
|
||||
|
||||
// Sets
|
||||
|
||||
d.Get(request, id)
|
||||
// Sets
|
||||
d.Set(request, id)
|
||||
|
||||
// Subscribe
|
||||
d.Subscribe(request, id)
|
||||
|
||||
// Unsubscribe
|
||||
d.Unsubscribe(request, id)
|
||||
}
|
||||
|
||||
request.Get = make([]json_dataModels.Get, 0)
|
||||
request.Set = make([]json_dataModels.Set, 0)
|
||||
request.Subscribe = make([]json_dataModels.Subscription, 0)
|
||||
request.Unsubscribe = make([]json_dataModels.Subscription, 0)
|
||||
request = nil
|
||||
client.OnError = func(err error) {
|
||||
d.Log.Error("dbmHandler.webSocket.Websocket", "error on websocket connection: "+err.Error())
|
||||
}
|
||||
}
|
||||
|
||||
func (d *DBMHandler) readJsonData(id string) (request *json_dataModels.Request, err error) {
|
||||
|
||||
client, ok := d.Conns.Clients[id]
|
||||
if !ok {
|
||||
return request, errors.New("client id not found")
|
||||
}
|
||||
|
||||
_, reader, err := client.Conn.Reader(client.Ctx)
|
||||
if err != nil {
|
||||
d.Log.Info("webSocket.readJsonData", fmt.Sprintf("WebSocket reader: %v\n", err))
|
||||
return request, nil
|
||||
}
|
||||
|
||||
b, err := io.ReadAll(reader)
|
||||
|
||||
if err != nil {
|
||||
code := websocket.CloseStatus(err)
|
||||
|
||||
switch code {
|
||||
case websocket.StatusNormalClosure,
|
||||
websocket.StatusGoingAway,
|
||||
websocket.StatusNoStatusRcvd:
|
||||
d.Log.Info("webSocket.readJsonData", fmt.Sprintf("WebSocket closed: %v (code: %v)\n", err, code))
|
||||
return
|
||||
default:
|
||||
d.Log.Error("webSocket.readJsonData", fmt.Sprintf("WebSocket read error: %v (code: %v)\n", err, code))
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
if err := json.Unmarshal(b, &request); err != nil {
|
||||
return request, err
|
||||
}
|
||||
|
||||
func (d *DBMHandler) readJsonData(data []byte) (request *json_dataModels.Request, err error) {
|
||||
err = json.Unmarshal(data, &request)
|
||||
return
|
||||
}
|
||||
|
Reference in New Issue
Block a user