Large refactor and project restructuring
This commit is contained in:
		| @@ -4,9 +4,9 @@ using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class Autoproxy | ||||
|     { | ||||
|   | ||||
| @@ -3,9 +3,9 @@ using System.Threading.Tasks; | ||||
|  | ||||
| using Discord.WebSocket; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class CommandTree | ||||
|     { | ||||
|   | ||||
| @@ -1,8 +1,6 @@ | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class Fun | ||||
|     { | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class Help | ||||
|     { | ||||
|   | ||||
| @@ -4,13 +4,15 @@ using System.Linq; | ||||
| using System.Net.Http; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
| using Discord.Net; | ||||
|  | ||||
| using Newtonsoft.Json; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class ImportExport | ||||
|     { | ||||
|   | ||||
| @@ -1,10 +1,9 @@ | ||||
| using System.Linq; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class Member | ||||
|     { | ||||
|   | ||||
| @@ -3,9 +3,9 @@ using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class MemberAvatar | ||||
|     { | ||||
| @@ -62,7 +62,7 @@ namespace PluralKit.Bot.Commands | ||||
|             } | ||||
|             else if (ctx.RemainderOrNull() is string url) | ||||
|             { | ||||
|                 await Utils.VerifyAvatarOrThrow(url); | ||||
|                 await AvatarUtils.VerifyAvatarOrThrow(url); | ||||
|                 target.AvatarUrl = url; | ||||
|                 await _data.SaveMember(target); | ||||
|  | ||||
| @@ -71,7 +71,7 @@ namespace PluralKit.Bot.Commands | ||||
|             } | ||||
|             else if (ctx.Message.Attachments.FirstOrDefault() is Attachment attachment) | ||||
|             { | ||||
|                 await Utils.VerifyAvatarOrThrow(attachment.Url); | ||||
|                 await AvatarUtils.VerifyAvatarOrThrow(attachment.Url); | ||||
|                 target.AvatarUrl = attachment.Url; | ||||
|                 await _data.SaveMember(target); | ||||
|  | ||||
|   | ||||
| @@ -3,10 +3,9 @@ using System.Threading.Tasks; | ||||
|  | ||||
| using NodaTime; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class MemberEdit | ||||
|     { | ||||
| @@ -103,7 +102,7 @@ namespace PluralKit.Bot.Commands | ||||
|             var birthday = ctx.RemainderOrNull(); | ||||
|             if (birthday != null) | ||||
|             { | ||||
|                 date = PluralKit.Utils.ParseDate(birthday, true); | ||||
|                 date = DateUtils.ParseDate(birthday, true); | ||||
|                 if (date == null) throw Errors.BirthdayParseError(birthday); | ||||
|             } | ||||
|  | ||||
|   | ||||
| @@ -1,10 +1,9 @@ | ||||
| using System; | ||||
| using System.Linq; | ||||
| using System.Linq; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class MemberProxy | ||||
|     { | ||||
|   | ||||
| @@ -3,6 +3,7 @@ using System.Diagnostics; | ||||
| using System.Linq; | ||||
| using System.Text.RegularExpressions; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using App.Metrics; | ||||
|  | ||||
| using Discord; | ||||
| @@ -11,10 +12,9 @@ using Humanizer; | ||||
|  | ||||
| using NodaTime; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands { | ||||
| namespace PluralKit.Bot { | ||||
|     public class Misc | ||||
|     { | ||||
|         private BotConfig _botConfig; | ||||
| @@ -79,7 +79,7 @@ namespace PluralKit.Bot.Commands { | ||||
|                 .AddField("Messages proxied", $"{messagesProxied.OneMinuteRate * 60:F1}/m ({messagesProxied.FifteenMinuteRate * 60:F1}/m over 15m)", true) | ||||
|                 .AddField("Commands executed", $"{commandsRun.OneMinuteRate * 60:F1}/m ({commandsRun.FifteenMinuteRate * 60:F1}/m over 15m)", true) | ||||
|                 .AddField("Current shard", $"Shard #{shardId} (of {shardTotal} total, {shardUpTotal} are up)", true) | ||||
|                 .AddField("Shard uptime", $"{Formats.DurationFormat.Format(shardUptime)} ({shardInfo.DisconnectionCount} disconnections)", true) | ||||
|                 .AddField("Shard uptime", $"{DateTimeFormats.DurationFormat.Format(shardUptime)} ({shardInfo.DisconnectionCount} disconnections)", true) | ||||
|                 .AddField("CPU usage", $"{_cpu.LastCpuMeasure:P1}", true) | ||||
|                 .AddField("Memory usage", $"{memoryUsage / 1024 / 1024} MiB", true) | ||||
|                 .AddField("Latency", $"API: {(msg.Timestamp - ctx.Message.Timestamp).TotalMilliseconds:F0} ms, shard: {shardInfo.ShardLatency} ms", true) | ||||
|   | ||||
| @@ -1,11 +1,12 @@ | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class ServerConfig | ||||
|     { | ||||
|   | ||||
| @@ -1,14 +1,15 @@ | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
|  | ||||
| using NodaTime; | ||||
| using NodaTime.TimeZones; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class Switch | ||||
|     { | ||||
| @@ -79,7 +80,7 @@ namespace PluralKit.Bot.Commands | ||||
|             var timeToMove = ctx.RemainderOrNull() ?? throw new PKSyntaxError("Must pass a date or time to move the switch to."); | ||||
|             var tz = TzdbDateTimeZoneSource.Default.ForId(ctx.System.UiTz ?? "UTC"); | ||||
|              | ||||
|             var result = PluralKit.Utils.ParseDateTime(timeToMove, true, tz); | ||||
|             var result = DateUtils.ParseDateTime(timeToMove, true, tz); | ||||
|             if (result == null) throw Errors.InvalidDateTime(timeToMove); | ||||
|              | ||||
|             var time = result.Value; | ||||
| @@ -102,10 +103,10 @@ namespace PluralKit.Bot.Commands | ||||
|             // But, we do a prompt to confirm. | ||||
|             var lastSwitchMembers = _data.GetSwitchMembers(lastTwoSwitches[0]); | ||||
|             var lastSwitchMemberStr = string.Join(", ", await lastSwitchMembers.Select(m => m.Name).ToListAsync()); | ||||
|             var lastSwitchTimeStr = Formats.ZonedDateTimeFormat.Format(lastTwoSwitches[0].Timestamp.InZone(ctx.System.Zone)); | ||||
|             var lastSwitchDeltaStr = Formats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - lastTwoSwitches[0].Timestamp); | ||||
|             var newSwitchTimeStr = Formats.ZonedDateTimeFormat.Format(time); | ||||
|             var newSwitchDeltaStr = Formats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - time.ToInstant()); | ||||
|             var lastSwitchTimeStr = DateTimeFormats.ZonedDateTimeFormat.Format(lastTwoSwitches[0].Timestamp.InZone(ctx.System.Zone)); | ||||
|             var lastSwitchDeltaStr = DateTimeFormats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - lastTwoSwitches[0].Timestamp); | ||||
|             var newSwitchTimeStr = DateTimeFormats.ZonedDateTimeFormat.Format(time); | ||||
|             var newSwitchDeltaStr = DateTimeFormats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - time.ToInstant()); | ||||
|              | ||||
|             // yeet | ||||
|             var msg = await ctx.Reply($"{Emojis.Warn} This will move the latest switch ({lastSwitchMemberStr.SanitizeMentions()}) from {lastSwitchTimeStr} ({lastSwitchDeltaStr} ago) to {newSwitchTimeStr} ({newSwitchDeltaStr} ago). Is this OK?"); | ||||
| @@ -137,7 +138,7 @@ namespace PluralKit.Bot.Commands | ||||
|  | ||||
|             var lastSwitchMembers = _data.GetSwitchMembers(lastTwoSwitches[0]); | ||||
|             var lastSwitchMemberStr = string.Join(", ", await lastSwitchMembers.Select(m => m.Name).ToListAsync()); | ||||
|             var lastSwitchDeltaStr = Formats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - lastTwoSwitches[0].Timestamp); | ||||
|             var lastSwitchDeltaStr = DateTimeFormats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - lastTwoSwitches[0].Timestamp); | ||||
|  | ||||
|             IUserMessage msg; | ||||
|             if (lastTwoSwitches.Count == 1) | ||||
| @@ -149,7 +150,7 @@ namespace PluralKit.Bot.Commands | ||||
|             { | ||||
|                 var secondSwitchMembers = _data.GetSwitchMembers(lastTwoSwitches[1]); | ||||
|                 var secondSwitchMemberStr = string.Join(", ", await secondSwitchMembers.Select(m => m.Name).ToListAsync()); | ||||
|                 var secondSwitchDeltaStr = Formats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - lastTwoSwitches[1].Timestamp); | ||||
|                 var secondSwitchDeltaStr = DateTimeFormats.DurationFormat.Format(SystemClock.Instance.GetCurrentInstant() - lastTwoSwitches[1].Timestamp); | ||||
|                 msg = await ctx.Reply( | ||||
|                     $"{Emojis.Warn} This will delete the latest switch ({lastSwitchMemberStr.SanitizeMentions()}, {lastSwitchDeltaStr} ago). The next latest switch is {secondSwitchMemberStr.SanitizeMentions()} ({secondSwitchDeltaStr} ago). Is this okay?"); | ||||
|             } | ||||
|   | ||||
| @@ -1,16 +1,8 @@ | ||||
| using System; | ||||
| using System.Linq; | ||||
| using System.Threading.Tasks; | ||||
| using Discord; | ||||
| using Humanizer; | ||||
| using NodaTime; | ||||
| using NodaTime.Text; | ||||
| using NodaTime.TimeZones; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class System | ||||
|     { | ||||
|   | ||||
| @@ -8,10 +8,9 @@ using NodaTime; | ||||
| using NodaTime.Text; | ||||
| using NodaTime.TimeZones; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class SystemEdit | ||||
|     { | ||||
| @@ -103,7 +102,7 @@ namespace PluralKit.Bot.Commands | ||||
|             { | ||||
|                 // They can't both be null - otherwise we would've hit the conditional at the very top | ||||
|                 string url = ctx.RemainderOrNull() ?? ctx.Message.Attachments.FirstOrDefault()?.ProxyUrl; | ||||
|                 await ctx.BusyIndicator(() => Utils.VerifyAvatarOrThrow(url)); | ||||
|                 await ctx.BusyIndicator(() => AvatarUtils.VerifyAvatarOrThrow(url)); | ||||
|  | ||||
|                 ctx.System.AvatarUrl = url; | ||||
|                 await _data.SaveSystem(ctx.System); | ||||
| @@ -162,7 +161,7 @@ namespace PluralKit.Bot.Commands | ||||
|  | ||||
|             var currentTime = SystemClock.Instance.GetCurrentInstant().InZone(zone); | ||||
|             var msg = await ctx.Reply( | ||||
|                 $"This will change the system time zone to {zone.Id}. The current time is {Formats.ZonedDateTimeFormat.Format(currentTime)}. Is this correct?"); | ||||
|                 $"This will change the system time zone to {zone.Id}. The current time is {DateTimeFormats.ZonedDateTimeFormat.Format(currentTime)}. Is this correct?"); | ||||
|             if (!await ctx.PromptYesNo(msg)) throw Errors.TimezoneChangeCancelled; | ||||
|             ctx.System.UiTz = zone.Id; | ||||
|             await _data.SaveSystem(ctx.System); | ||||
| @@ -246,7 +245,7 @@ namespace PluralKit.Bot.Commands | ||||
|  | ||||
|         public async Task<DateTimeZone> FindTimeZone(Context ctx, string zoneStr) { | ||||
|             // First, if we're given a flag emoji, we extract the flag emoji code from it. | ||||
|             zoneStr = PluralKit.Utils.ExtractCountryFlag(zoneStr) ?? zoneStr; | ||||
|             zoneStr = Core.StringUtils.ExtractCountryFlag(zoneStr) ?? zoneStr; | ||||
|              | ||||
|             // Then, we find all *locations* matching either the given country code or the country name. | ||||
|             var locations = TzdbDateTimeZoneSource.Default.Zone1970Locations; | ||||
|   | ||||
| @@ -5,9 +5,9 @@ using Discord; | ||||
|  | ||||
| using NodaTime; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class SystemFront | ||||
|     { | ||||
| @@ -81,12 +81,12 @@ namespace PluralKit.Bot.Commands | ||||
|                             // Calculate the time between the last switch (that we iterated - ie. the next one on the timeline) and the current one | ||||
|                             var switchDuration = lastSw.Value - sw.Timestamp; | ||||
|                             stringToAdd = | ||||
|                                 $"**{membersStr}** ({Formats.ZonedDateTimeFormat.Format(sw.Timestamp.InZone(system.Zone))}, {Formats.DurationFormat.Format(switchSince)} ago, for {Formats.DurationFormat.Format(switchDuration)})\n"; | ||||
|                                 $"**{membersStr}** ({DateTimeFormats.ZonedDateTimeFormat.Format(sw.Timestamp.InZone(system.Zone))}, {DateTimeFormats.DurationFormat.Format(switchSince)} ago, for {DateTimeFormats.DurationFormat.Format(switchDuration)})\n"; | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             stringToAdd = | ||||
|                                 $"**{membersStr}** ({Formats.ZonedDateTimeFormat.Format(sw.Timestamp.InZone(system.Zone))}, {Formats.DurationFormat.Format(switchSince)} ago)\n"; | ||||
|                                 $"**{membersStr}** ({DateTimeFormats.ZonedDateTimeFormat.Format(sw.Timestamp.InZone(system.Zone))}, {DateTimeFormats.DurationFormat.Format(switchSince)} ago)\n"; | ||||
|                         } | ||||
|  | ||||
|                         if (outputStr.Length + stringToAdd.Length > EmbedBuilder.MaxDescriptionLength) break; | ||||
| @@ -107,7 +107,7 @@ namespace PluralKit.Bot.Commands | ||||
|              | ||||
|             var now = SystemClock.Instance.GetCurrentInstant(); | ||||
|  | ||||
|             var rangeStart = PluralKit.Utils.ParseDateTime(durationStr, true, system.Zone); | ||||
|             var rangeStart = DateUtils.ParseDateTime(durationStr, true, system.Zone); | ||||
|             if (rangeStart == null) throw Errors.InvalidDateTime(durationStr); | ||||
|             if (rangeStart.Value.ToInstant() > now) throw Errors.FrontPercentTimeInFuture; | ||||
|              | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| using System.Linq; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class SystemLink | ||||
|     { | ||||
|   | ||||
| @@ -4,9 +4,9 @@ using System.Threading.Tasks; | ||||
|  | ||||
| using Humanizer; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class SystemList | ||||
|     { | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| using Discord; | ||||
|  | ||||
| using PluralKit.Bot.CommandSystem; | ||||
| using PluralKit.Core; | ||||
|  | ||||
| namespace PluralKit.Bot.Commands | ||||
| namespace PluralKit.Bot | ||||
| { | ||||
|     public class Token | ||||
|     { | ||||
| @@ -33,7 +34,7 @@ namespace PluralKit.Bot.Commands | ||||
|  | ||||
|         private async Task<string> MakeAndSetNewToken(PKSystem system) | ||||
|         { | ||||
|             system.Token = PluralKit.Utils.GenerateToken(); | ||||
|             system.Token = Core.StringUtils.GenerateToken(); | ||||
|             await _data.SaveSystem(system); | ||||
|             return system.Token; | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user