aboutsummaryrefslogtreecommitdiff
path: root/ui
diff options
context:
space:
mode:
authorPascal Abresch <neplevitan@packageloss.eu>2019-03-19 16:06:40 +0100
committerPascal Abresch <neplevitan@packageloss.eu>2019-03-19 16:06:40 +0100
commitcefa840c28067e33bf67dd65aa267779cdeae34e (patch)
treec3c371a4033a85faaed0524c779aef66f60784bf /ui
parentc5bf3f894c4efad71757f0d64ec128c01cdc5805 (diff)
adds kick, ban, unban and invite command
Diffstat (limited to 'ui')
-rw-r--r--ui/command-processor.go4
-rw-r--r--ui/commands.go58
2 files changed, 62 insertions, 0 deletions
diff --git a/ui/command-processor.go b/ui/command-processor.go
index b18f950..77a7b3d 100644
--- a/ui/command-processor.go
+++ b/ui/command-processor.go
@@ -91,6 +91,9 @@ func NewCommandProcessor(parent *MainView) *CommandProcessor {
"clearcache": cmdClearCache,
"leave": cmdLeave,
"join": cmdJoin,
+ "kick": cmdKick,
+ "ban": cmdBan,
+ "unban": cmdUnban,
"toggle": cmdToggle,
"logout": cmdLogout,
"sendevent": cmdSendEvent,
@@ -98,6 +101,7 @@ func NewCommandProcessor(parent *MainView) *CommandProcessor {
"setstate": cmdSetState,
"msetstate": cmdMSetState,
"rainbow": cmdRainbow,
+ "invite": cmdInvite,
},
}
}
diff --git a/ui/commands.go b/ui/commands.go
index eb2a442..bba1644 100644
--- a/ui/commands.go
+++ b/ui/commands.go
@@ -112,6 +112,64 @@ func cmdLeave(cmd *Command) {
}
}
+func cmdInvite(cmd *Command) {
+ if len(cmd.Args) != 1 {
+ cmd.Reply("Usage: /invite <user id>")
+ return
+ }
+ _, err := cmd.Matrix.Client().InviteUser(cmd.Room.MxRoom().ID, &mautrix.ReqInviteUser{cmd.Args[0]})
+ if err != nil {
+ debug.Print("Error in invite call:", err)
+ cmd.Reply("Failed to invite user:", err)
+ }
+}
+
+func cmdBan(cmd *Command) {
+ if len(cmd.Args) < 1 {
+ cmd.Reply("Usage: /ban <user> <optional:reason>")
+ return
+ }
+ reason := "you are the weakest link, goodbye!"
+ if len(cmd.Args) >= 2 {
+ reason = strings.Join(cmd.Args[1:]," ")
+ }
+ _, err := cmd.Matrix.Client().BanUser(cmd.Room.MxRoom().ID, &mautrix.ReqBanUser{reason,cmd.Args[0]})
+ if err != nil {
+ debug.Print("Error in ban call:", err)
+ cmd.Reply("Failed to ban user:", err)
+ }
+
+}
+
+func cmdUnban(cmd *Command) {
+ if len(cmd.Args) != 1 {
+ cmd.Reply("Usage: /unban <user>")
+ return
+ }
+ _, err := cmd.Matrix.Client().UnbanUser(cmd.Room.MxRoom().ID, &mautrix.ReqUnbanUser{cmd.Args[0]})
+ if err != nil {
+ debug.Print("Error in unban call:", err)
+ cmd.Reply("Failed to unban user:", err)
+ }
+}
+
+func cmdKick(cmd *Command) {
+ if len(cmd.Args) < 1 {
+ cmd.Reply("Usage: /kick <user> <optional:reason>")
+ return
+ }
+ reason := "you are the weakest link, goodbye!"
+ if len(cmd.Args) >= 2 {
+ reason = strings.Join(cmd.Args[1:]," ")
+ }
+ _, err := cmd.Matrix.Client().KickUser(cmd.Room.MxRoom().ID, &mautrix.ReqKickUser{reason,cmd.Args[0]})
+ if err != nil {
+ debug.Print("Error in kick call:", err)
+ debug.Print("Failed to kick user:", err)
+ }
+
+}
+
func cmdJoin(cmd *Command) {
if len(cmd.Args) == 0 {
cmd.Reply("Usage: /join <room>")