about summary refs log tree commit diff
path: root/Utilities/LibMatrix.DevTestBot/Bot/Interfaces
diff options
context:
space:
mode:
authorTheArcaneBrony <myrainbowdash949@gmail.com>2024-01-11 18:40:42 +0000
committerTheArcaneBrony <myrainbowdash949@gmail.com>2024-01-11 18:40:42 +0000
commita481bead16d904da8ad4d6de8d1a8ab006460b31 (patch)
tree247eda7886d12f667ba34060121f262494e51952 /Utilities/LibMatrix.DevTestBot/Bot/Interfaces
parentCleanup, more message formatters, messagebuilder start (diff)
downloadLibMatrix-a481bead16d904da8ad4d6de8d1a8ab006460b31.tar.xz
Dev test bot
Diffstat (limited to 'Utilities/LibMatrix.DevTestBot/Bot/Interfaces')
-rw-r--r--Utilities/LibMatrix.DevTestBot/Bot/Interfaces/CommandContext.cs11
-rw-r--r--Utilities/LibMatrix.DevTestBot/Bot/Interfaces/ICommand.cs12
2 files changed, 23 insertions, 0 deletions
diff --git a/Utilities/LibMatrix.DevTestBot/Bot/Interfaces/CommandContext.cs b/Utilities/LibMatrix.DevTestBot/Bot/Interfaces/CommandContext.cs
new file mode 100644
index 0000000..6dbb7f9
--- /dev/null
+++ b/Utilities/LibMatrix.DevTestBot/Bot/Interfaces/CommandContext.cs
@@ -0,0 +1,11 @@
+using LibMatrix.EventTypes.Spec;
+using LibMatrix.RoomTypes;
+
+namespace LibMatrix.ExampleBot.Bot.Interfaces;
+
+public class CommandContext {
+    public GenericRoom Room { get; set; }
+    public StateEventResponse MessageEvent { get; set; }
+    public string CommandName => (MessageEvent.TypedContent as RoomMessageEventContent).Body.Split(' ')[0][1..];
+    public string[] Args => (MessageEvent.TypedContent as RoomMessageEventContent).Body.Split(' ')[1..];
+}
diff --git a/Utilities/LibMatrix.DevTestBot/Bot/Interfaces/ICommand.cs b/Utilities/LibMatrix.DevTestBot/Bot/Interfaces/ICommand.cs
new file mode 100644
index 0000000..2ba5a27
--- /dev/null
+++ b/Utilities/LibMatrix.DevTestBot/Bot/Interfaces/ICommand.cs
@@ -0,0 +1,12 @@
+namespace LibMatrix.ExampleBot.Bot.Interfaces;
+
+public interface ICommand {
+    public string Name { get; }
+    public string Description { get; }
+
+    public Task<bool> CanInvoke(CommandContext ctx) {
+        return Task.FromResult(true);
+    }
+
+    public Task Invoke(CommandContext ctx);
+}