about summary refs log tree commit diff
path: root/Utilities/LibMatrix.Utilities.Bot/AppServiceConfiguration.cs
diff options
context:
space:
mode:
authorTheArcaneBrony <myrainbowdash949@gmail.com>2023-09-15 09:50:45 +0200
committerTheArcaneBrony <myrainbowdash949@gmail.com>2023-09-15 09:50:45 +0200
commit6bd02248ccfbcb46960a6f39eaad23888d190eb5 (patch)
tree110578f31b6f9f70a7a1edab32fb3a34d6ad4f1a /Utilities/LibMatrix.Utilities.Bot/AppServiceConfiguration.cs
parentMedia moderator PoC works, abstract command handling to library (diff)
downloadLibMatrix-6bd02248ccfbcb46960a6f39eaad23888d190eb5.tar.xz
Some refactoring
Diffstat (limited to '')
-rw-r--r--Utilities/LibMatrix.Utilities.Bot/AppServiceConfiguration.cs87
1 files changed, 87 insertions, 0 deletions
diff --git a/Utilities/LibMatrix.Utilities.Bot/AppServiceConfiguration.cs b/Utilities/LibMatrix.Utilities.Bot/AppServiceConfiguration.cs
new file mode 100644
index 0000000..4de139e
--- /dev/null
+++ b/Utilities/LibMatrix.Utilities.Bot/AppServiceConfiguration.cs
@@ -0,0 +1,87 @@
+namespace PluralContactBotPoC;
+
+public class AppServiceConfiguration {
+    public string Id { get; set; } = null!;
+    public string? Url { get; set; } = null!;
+    public string SenderLocalpart { get; set; } = null!;
+    public string AppserviceToken { get; set; } = null!;
+    public string HomeserverToken { get; set; } = null!;
+    public List<string>? Protocols { get; set; } = null!;
+    public bool? RateLimited { get; set; } = null!;
+
+    public AppserviceNamespaces Namespaces { get; set; } = null!;
+
+    public class AppserviceNamespaces {
+        public List<AppserviceNamespace>? Users { get; set; } = null;
+        public List<AppserviceNamespace>? Aliases { get; set; } = null;
+        public List<AppserviceNamespace>? Rooms { get; set; } = null;
+
+        public class AppserviceNamespace {
+            public bool Exclusive { get; set; }
+            public string Regex { get; set; } = null!;
+        }
+    }
+
+    /// <summary>
+    /// Please dont look at code, it's horrifying but works
+    /// </summary>
+    /// <returns></returns>
+    public string ToYaml() {
+        var yaml = $"""
+                    id: "{Id ?? throw new NullReferenceException("Id is null")}"
+                    url: {(Url is null ? "null" : $"\"{Url}\"")}
+                    as_token: "{AppserviceToken ?? throw new NullReferenceException("AppserviceToken is null")}"
+                    hs_token: "{HomeserverToken ?? throw new NullReferenceException("HomeserverToken is null")}"
+                    sender_localpart: "{SenderLocalpart ?? throw new NullReferenceException("SenderLocalpart is null")}"
+
+                    """;
+
+        if (Protocols is not null && Protocols.Count > 0)
+            yaml += $"""
+                     protocols:
+                        - "{Protocols[0] ?? throw new NullReferenceException("Protocols[0] is null")}"
+                     """;
+        else
+            yaml += "protocols: []";
+        yaml += "\n";
+        if (RateLimited is not null)
+            yaml += $"rate_limited: {RateLimited!.ToString().ToLower()}\n";
+        else
+            yaml += "rate_limited: false\n";
+
+        yaml += "namespaces: \n";
+
+        if (Namespaces.Users is null || Namespaces.Users.Count == 0)
+            yaml += "  users: []";
+        else
+            Namespaces.Users.ForEach(x =>
+                yaml += $"""
+                             users:
+                                 - exclusive: {x.Exclusive.ToString().ToLower()}
+                                   regex: "{x.Regex ?? throw new NullReferenceException("x.Regex is null")}"
+                         """);
+        yaml += "\n";
+
+        if (Namespaces.Aliases is null || Namespaces.Aliases.Count == 0)
+            yaml += "  aliases: []";
+        else
+            Namespaces.Aliases.ForEach(x =>
+                yaml += $"""
+                             aliases:
+                                 - exclusive: {x.Exclusive.ToString().ToLower()}
+                                   regex: "{x.Regex ?? throw new NullReferenceException("x.Regex is null")}"
+                         """);
+        yaml += "\n";
+        if (Namespaces.Rooms is null || Namespaces.Rooms.Count == 0)
+            yaml += "  rooms: []";
+        else
+            Namespaces.Rooms.ForEach(x =>
+                yaml += $"""
+                             rooms:
+                                 - exclusive: {x.Exclusive.ToString().ToLower()}
+                                   regex: "{x.Regex ?? throw new NullReferenceException("x.Regex is null")}"
+                         """);
+
+        return yaml;
+    }
+}