mirror of
https://github.com/Xevion/go-ha.git
synced 2025-12-06 05:15:15 -06:00
fix bug with newer HA versions by sending int id instead of string add warning to logs when receiving unsuccessful websocket response
53 lines
930 B
Go
53 lines
930 B
Go
package websocket
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"fmt"
|
|
"log"
|
|
|
|
"github.com/gorilla/websocket"
|
|
)
|
|
|
|
type BaseMessage struct {
|
|
Type string `json:"type"`
|
|
Id int64 `json:"id"`
|
|
Success bool `json:"success"`
|
|
}
|
|
|
|
type ChanMsg struct {
|
|
Id int64
|
|
Type string
|
|
Success bool
|
|
Raw []byte
|
|
}
|
|
|
|
func ListenWebsocket(conn *websocket.Conn, ctx context.Context, c chan ChanMsg) {
|
|
for {
|
|
bytes, err := ReadMessage(conn, ctx)
|
|
|
|
if err != nil {
|
|
log.Default().Println("Error reading from websocket:", err)
|
|
close(c)
|
|
break
|
|
}
|
|
|
|
base := BaseMessage{
|
|
// default to true for messages that don't include "success" at all
|
|
Success: true,
|
|
}
|
|
json.Unmarshal(bytes, &base)
|
|
if !base.Success {
|
|
fmt.Println("WARNING: received unsuccessful response:", string(bytes))
|
|
}
|
|
chanMsg := ChanMsg{
|
|
Type: base.Type,
|
|
Id: base.Id,
|
|
Success: base.Success,
|
|
Raw: bytes,
|
|
}
|
|
|
|
c <- chanMsg
|
|
}
|
|
}
|