From e6030f05ceb7dc0620175352310b88713f961eb8 Mon Sep 17 00:00:00 2001 From: "Robin C. Ladiges" Date: Thu, 25 Apr 2024 02:09:25 +0200 Subject: [PATCH] new setting: Shines/Excluded To exclude specific shines to be synced to other clients. Pre-initialized with shine 496 (Moon Shards in the Sand) that causes people to get stuck in front of the inverted pyramid. This commit fixes issue #31 --- Server/Program.cs | 29 ++++++++++++++++++++++++++--- Server/Settings.cs | 1 + 2 files changed, 27 insertions(+), 3 deletions(-) diff --git a/Server/Program.cs b/Server/Program.cs index c9728d8..1198c12 100644 --- a/Server/Program.cs +++ b/Server/Program.cs @@ -74,7 +74,7 @@ async Task ClientSyncShineBag(Client client) { try { if ((bool?) client.Metadata["speedrun"] ?? false) return; ConcurrentBag clientBag = (ConcurrentBag) (client.Metadata["shineSync"] ??= new ConcurrentBag()); - foreach (int shine in shineBag.Except(clientBag).ToArray()) { + foreach (int shine in shineBag.Except(clientBag).Except(Settings.Instance.Shines.Excluded).ToArray()) { if (!client.Connected) return; await client.Send(new ShinePacket { ShineId = shine @@ -197,6 +197,10 @@ void logError(Task x) { case ShinePacket shinePacket: { if (!Settings.Instance.Shines.Enabled) return false; + if (Settings.Instance.Shines.Excluded.Contains(shinePacket.ShineId)) { + c.Logger.Info($"Got moon {shinePacket.ShineId} (excluded)"); + return false; + } if (c.Metadata["loadedSave"] is false) break; ConcurrentBag playerBag = (ConcurrentBag)c.Metadata["shineSync"]!; shineBag.Add(shinePacket.ShineId); @@ -559,12 +563,16 @@ await server.Broadcast(new TagPacket { }); CommandHandler.RegisterCommand("shine", args => { - const string optionUsage = "Valid options: list, clear, sync, send, set"; + const string optionUsage = "Valid options: list, clear, sync, send, set, include, exclude"; if (args.Length < 1) return optionUsage; switch (args[0]) { case "list" when args.Length == 1: - return $"Shines: {string.Join(", ", shineBag)}"; + return $"Shines: {string.Join(", ", shineBag)}" + ( + Settings.Instance.Shines.Excluded.Count() > 0 + ? "\nExcluded Shines: " + string.Join(", ", Settings.Instance.Shines.Excluded) + : "" + ); case "clear" when args.Length == 1: shineBag.Clear(); Task.Run(async () => { @@ -601,6 +609,21 @@ await c.Send(new ShinePacket { return optionUsage; } + case "exclude" when args.Length == 2: + case "include" when args.Length == 2: { + if (int.TryParse(args[1], out int sid)) { + if (args[0] == "exclude") { + Settings.Instance.Shines.Excluded.Add(sid); + Settings.SaveSettings(); + return $"Exclude shine {sid} from syncing."; + } else { + Settings.Instance.Shines.Excluded.Remove(sid); + Settings.SaveSettings(); + return $"No longer exclude shine {sid} from syncing."; + } + } + return optionUsage; + } default: return optionUsage; } diff --git a/Server/Settings.cs b/Server/Settings.cs index 22a7dc9..f696a7d 100644 --- a/Server/Settings.cs +++ b/Server/Settings.cs @@ -80,6 +80,7 @@ public class DiscordTable { public class ShineTable { public bool Enabled { get; set; } = true; + public ISet Excluded { get; set; } = new SortedSet { 496 }; } public class PersistShinesTable