Simple counter, woot!

This commit is contained in:
Sam Rose 2019-07-13 21:26:08 +01:00
parent 9c8f1ebee7
commit cad454a4bf
3 changed files with 95 additions and 49 deletions

View File

@ -5,6 +5,7 @@ import (
"flag" "flag"
"log" "log"
"os" "os"
"strconv"
"github.com/samwho/streamdeck-livesplit/streamdeck" "github.com/samwho/streamdeck-livesplit/streamdeck"
) )
@ -50,8 +51,11 @@ func run(ctx context.Context, params streamdeck.RegistrationParams) error {
return err return err
} }
client.RegisterHandler(streamdeck.KeyDown, func(ctx context.Context, client *streamdeck.Client, event streamdeck.Event) { counter := 0
return client.Log("key down!") client.RegisterHandler(streamdeck.KeyDown, func(ctx context.Context, client *streamdeck.Client, event streamdeck.Event) error {
counter++
log.Printf("key down! counter: %d\n", counter)
return client.SetTitle(ctx, strconv.Itoa(counter), streamdeck.HardwareAndSoftware)
}) })
log.Println("waiting for connection to close...") log.Println("waiting for connection to close...")

View File

@ -13,7 +13,7 @@ import (
"github.com/gorilla/websocket" "github.com/gorilla/websocket"
) )
type EventHandler func(ctx context.Context, client *Client, event EventReceived) error type EventHandler func(ctx context.Context, client *Client, event Event) error
type Client struct { type Client struct {
c *websocket.Conn c *websocket.Conn
@ -45,24 +45,39 @@ func NewClient(ctx context.Context, params RegistrationParams) (*Client, error)
defer close(done) defer close(done)
log.Println("starting read loop") log.Println("starting read loop")
for { for {
_, message, err := client.c.ReadMessage() messageType, message, err := client.c.ReadMessage()
if err != nil { if err != nil {
log.Println("read: ", err) log.Printf("read error: %v\n", err)
return return
} }
event := EventReceived{} if messageType == websocket.PingMessage {
log.Printf("received ping message\n")
if err := client.c.WriteMessage(websocket.PongMessage, []byte{}); err != nil {
log.Printf("error while ponging: %v\n", err)
}
continue
}
if messageType == websocket.CloseMessage {
// handle close message
panic("websocket close!")
}
event := Event{}
if err := json.Unmarshal(message, &event); err != nil { if err := json.Unmarshal(message, &event); err != nil {
log.Printf("failed to unmarshal received event: %s\n", string(message)) log.Printf("failed to unmarshal received event: %s\n", string(message))
return continue
}
ctx := setContext(ctx, event.Context)
for _, f := range client.handlers[event.Event] {
f(ctx, client, event)
} }
log.Println("recv: ", string(message)) log.Println("recv: ", string(message))
ctx := setContext(ctx, event.Context)
for _, f := range client.handlers[event.Event] {
if err := f(ctx, client, event); err != nil {
log.Printf("error in handler for event %v: %v\n", event.Event, err)
}
}
} }
}() }()
@ -74,23 +89,49 @@ func NewClient(ctx context.Context, params RegistrationParams) (*Client, error)
func (client *Client) register(params RegistrationParams) error { func (client *Client) register(params RegistrationParams) error {
log.Println("sending register event...") log.Println("sending register event...")
if err := client.c.WriteJSON(NewRegisterEvent(params)); err != nil { if err := client.send(Event{UUID: params.PluginUUID, Event: params.RegisterEvent}); err != nil {
client.Close() client.Close()
return err return err
} }
return nil return nil
} }
func (client *Client) send(event Event) error {
j, _ := json.Marshal(event)
log.Printf("sending message: %v\n", string(j))
return client.c.WriteJSON(event)
}
func (client *Client) SetSettings(ctx context.Context, settings interface{}) error { func (client *Client) SetSettings(ctx context.Context, settings interface{}) error {
return client.c.WriteJSON(NewEvent(ctx, SetSettings, settings)) return client.send(NewEvent(ctx, SetSettings, settings))
} }
func (client *Client) GetSettings(ctx context.Context) error { func (client *Client) GetSettings(ctx context.Context) error {
return client.c.WriteJSON(NewEvent(ctx, GetSettings, nil)) return client.send(NewEvent(ctx, GetSettings, nil))
} }
func (client *Client) Log(message string) error { func (client *Client) SetGlobalSettings(ctx context.Context, settings interface{}) error {
return client.c.WriteJSON(NewLogMessage(message)) return client.send(NewEvent(ctx, SetGlobalSettings, settings))
}
func (client *Client) GetGlobalSettings(ctx context.Context) error {
return client.send(NewEvent(ctx, GetGlobalSettings, nil))
}
func (client *Client) OpenURL(ctx context.Context, u url.URL) error {
return client.send(NewEvent(ctx, OpenURL, OpenURLPayload{URL: u.String()}))
}
func (client *Client) LogMessage(message string) error {
return client.send(NewEvent(nil, LogMessage, LogMessagePayload{Message: message}))
}
func (client *Client) SetTitle(ctx context.Context, title string, target Target) error {
return client.send(NewEvent(ctx, SetTitle, SetTitlePayload{Title: title, Target: target}))
}
func (client *Client) SetImage(ctx context.Context, base64image string, target Target) error {
return client.send(NewEvent(ctx, SetImage, SetImagePayload{Base64Image: base64image, Target: target}))
} }
func (client *Client) RegisterHandler(eventName string, handler EventHandler) { func (client *Client) RegisterHandler(eventName string, handler EventHandler) {

View File

@ -2,46 +2,47 @@ package streamdeck
import ( import (
"context" "context"
"encoding/json"
) )
type Event struct {
Action string `json:"action,omitempty"`
Event string `json:"event,omitempty"`
UUID string `json:"uuid,omitempty"`
Context string `json:"context,omitempty"`
Device string `json:"device,omitempty"`
Payload interface{} `json:"payload,omitempty"`
}
func NewEvent(ctx context.Context, name string, payload interface{}) Event {
return Event{
Event: name,
Context: getContext(ctx),
Payload: payload,
}
}
type LogMessagePayload struct { type LogMessagePayload struct {
Message string `json:"message"` Message string `json:"message"`
} }
func NewLogMessage(message string) Event { type OpenURLPayload struct {
return NewEvent(nil, LogMessage, LogMessagePayload{Message: message}) URL string `json:"url"`
} }
type RegisterEvent struct { type Target int
Event string `json:"event"`
UUID string `json:"uuid"` const (
HardwareAndSoftware Target = 0
OnlyHardware Target = 1
OnlySoftware Target = 2
)
type SetTitlePayload struct {
Title string `json:"title"`
Target Target `json:"target"`
} }
func NewRegisterEvent(params RegistrationParams) RegisterEvent { type SetImagePayload struct {
return RegisterEvent{ Base64Image string `json:"image"`
Event: params.RegisterEvent, Target Target `json:"target"`
UUID: params.PluginUUID,
}
}
type Event struct {
Action string `json:"action,omitempty"`
Event string `json:"event,omitempty"`
Context string `json:"context,omitempty"`
Device string `json:"device,omitempty"`
Payload string `json:"payload,omitempty"`
}
func NewEvent(ctx context.Context, name string, payload interface{}) Event {
payloadStr, err := json.Marshal(payload)
if err != nil {
panic(err)
}
return Event{
Event: name,
Context: getContext(ctx),
Payload: string(payloadStr),
}
} }