diff options
author | Tulir Asokan <tulir@maunium.net> | 2018-05-27 15:30:52 +0300 |
---|---|---|
committer | Tulir Asokan <tulir@maunium.net> | 2018-05-27 15:30:52 +0300 |
commit | e6043462118b77b41a89c90e26b9ae5a938ffcbd (patch) | |
tree | b9c52a7542aea7acbd25457c84b534f7406797b5 /ui/commands.go | |
parent | 094a566189a29568a1b7a49510602aecfbcb7bdd (diff) |
Add very basic arbitrary message/state event sending commands
Diffstat (limited to 'ui/commands.go')
-rw-r--r-- | ui/commands.go | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/ui/commands.go b/ui/commands.go index 38694a5..a72f3c7 100644 --- a/ui/commands.go +++ b/ui/commands.go @@ -19,6 +19,7 @@ package ui import ( "maunium.net/go/gomuks/debug" "strings" + "encoding/json" ) func cmdMe(cmd *Command) { @@ -70,6 +71,64 @@ func cmdJoin(cmd *Command) { } } +func cmdSendEvent(cmd *Command) { + debug.Print(cmd.Command, cmd.Args, len(cmd.Args)) + if len(cmd.Args) < 3 { + cmd.Reply("Usage: /send <room id> <event type> <content>") + return + } + roomID := cmd.Args[0] + eventType := cmd.Args[1] + rawContent := strings.Join(cmd.Args[2:], "") + debug.Print(roomID, eventType, rawContent) + + var content interface{} + err := json.Unmarshal([]byte(rawContent), &content) + debug.Print(err) + if err != nil { + cmd.Reply("Failed to parse content: %v", err) + return + } + debug.Print("Sending event to", roomID, eventType, content) + + resp, err := cmd.Matrix.Client().SendMessageEvent(roomID, eventType, content) + debug.Print(resp, err) + if err != nil { + cmd.Reply("Error from server: %v", err) + } else { + cmd.Reply("Event sent, ID: %s", resp.EventID) + } +} + +func cmdSetState(cmd *Command) { + if len(cmd.Args) < 4 { + cmd.Reply("Usage: /setstate <room id> <event type> <state key/`-`> <content>") + return + } + + roomID := cmd.Args[0] + eventType := cmd.Args[1] + stateKey := cmd.Args[2] + if stateKey == "-" { + stateKey = "" + } + rawContent := strings.Join(cmd.Args[3:], "") + + var content interface{} + err := json.Unmarshal([]byte(rawContent), &content) + if err != nil { + cmd.Reply("Failed to parse content: %v", err) + return + } + debug.Print("Sending state event to", roomID, eventType, stateKey, content) + resp, err := cmd.Matrix.Client().SendStateEvent(roomID, eventType, stateKey, content) + if err != nil { + cmd.Reply("Error from server: %v", err) + } else { + cmd.Reply("State event sent, ID: %s", resp.EventID) + } +} + func cmdUIToggle(cmd *Command) { if len(cmd.Args) == 0 { cmd.Reply("Usage: /uitoggle <rooms/users/baremessages>") |