From 3d457d005e052c53a9a5a232b251759f6dab23e1 Mon Sep 17 00:00:00 2001 From: Tulir Asokan Date: Fri, 7 Jan 2022 14:39:00 +0200 Subject: [PATCH] Pass event ID into CommandEvents --- commands.go | 6 ++++-- matrix.go | 2 +- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/commands.go b/commands.go index 141aee3..32caa53 100644 --- a/commands.go +++ b/commands.go @@ -61,6 +61,7 @@ type CommandEvent struct { Portal *Portal Handler *CommandHandler RoomID id.RoomID + EventID id.EventID User *User Command string Args []string @@ -82,7 +83,7 @@ func (ce *CommandEvent) Reply(msg string, args ...interface{}) { } // Handle handles messages to the bridge -func (handler *CommandHandler) Handle(roomID id.RoomID, user *User, message string, replyTo id.EventID) { +func (handler *CommandHandler) Handle(roomID id.RoomID, eventID id.EventID, user *User, message string, replyTo id.EventID) { args := strings.Fields(message) if len(args) == 0 { args = []string{"unknown-command"} @@ -93,6 +94,7 @@ func (handler *CommandHandler) Handle(roomID id.RoomID, user *User, message stri Portal: handler.bridge.GetPortalByMXID(roomID), Handler: handler, RoomID: roomID, + EventID: eventID, User: user, Command: strings.ToLower(args[0]), Args: args[1:], @@ -454,7 +456,7 @@ func (handler *CommandHandler) CommandSetPowerLevel(ce *CommandEvent) { ce.Reply("Only bridge admins can use `set-pl`") return } else if ce.Portal == nil { - ce.Reply("Not a portal room") + ce.Reply("This is not a portal room") return } var level int diff --git a/matrix.go b/matrix.go index 24ee728..b1b5894 100644 --- a/matrix.go +++ b/matrix.go @@ -437,7 +437,7 @@ func (mx *MatrixHandler) HandleMessage(evt *event.Event) { content.Body = strings.TrimLeft(content.Body[len(commandPrefix):], " ") } if hasCommandPrefix || evt.RoomID == user.ManagementRoom { - mx.cmd.Handle(evt.RoomID, user, content.Body, content.GetReplyTo()) + mx.cmd.Handle(evt.RoomID, evt.ID, user, content.Body, content.GetReplyTo()) return } }