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-bak-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); +}