From 35bbf199f61e97eaee42cfa70a0865eda437904d Mon Sep 17 00:00:00 2001 From: spiral Date: Tue, 9 Nov 2021 01:50:09 -0500 Subject: [PATCH] feat: add config setting to disable sending errors we've disabled/re-enabled these a few times in code now... --- PluralKit.Bot/Bot.cs | 22 +++++++++++++--------- PluralKit.Bot/BotConfig.cs | 2 ++ 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/PluralKit.Bot/Bot.cs b/PluralKit.Bot/Bot.cs index 773fe9f7..c3345eb1 100644 --- a/PluralKit.Bot/Bot.cs +++ b/PluralKit.Bot/Bot.cs @@ -37,6 +37,7 @@ namespace PluralKit.Bot private readonly ILifetimeScope _services; private readonly PeriodicStatCollector _collector; private readonly IMetrics _metrics; + private readonly BotConfig _config; private readonly ErrorMessageService _errorMessageService; private readonly CommandMessageService _commandMessageService; private readonly IDiscordCache _cache; @@ -44,13 +45,14 @@ namespace PluralKit.Bot private bool _hasReceivedReady = false; private Timer _periodicTask; // Never read, just kept here for GC reasons - public Bot(ILifetimeScope services, ILogger logger, PeriodicStatCollector collector, IMetrics metrics, + public Bot(ILifetimeScope services, ILogger logger, PeriodicStatCollector collector, IMetrics metrics, BotConfig config, ErrorMessageService errorMessageService, CommandMessageService commandMessageService, Cluster cluster, DiscordApiClient rest, IDiscordCache cache) { _logger = logger.ForContext(); _services = services; _collector = collector; _metrics = metrics; + _config = config; _errorMessageService = errorMessageService; _commandMessageService = commandMessageService; _cluster = cluster; @@ -252,16 +254,18 @@ namespace PluralKit.Bot SentrySdk.CaptureEvent(sentryEvent, sentryScope); - // most of these errors aren't useful... + // most of these errors aren't useful... + if (_config.DisableErrorReporting) + return; - // // Once we've sent it to Sentry, report it to the user (if we have permission to) - // var reportChannel = handler.ErrorChannelFor(evt); - // if (reportChannel == null) - // return; + // Once we've sent it to Sentry, report it to the user (if we have permission to) + var reportChannel = handler.ErrorChannelFor(evt); + if (reportChannel == null) + return; - // var botPerms = PermissionsIn(reportChannel.Value); - // if (botPerms.HasFlag(PermissionSet.SendMessages | PermissionSet.EmbedLinks)) - // await _errorMessageService.SendErrorMessage(reportChannel.Value, sentryEvent.EventId.ToString()); + var botPerms = PermissionsIn(reportChannel.Value); + if (botPerms.HasFlag(PermissionSet.SendMessages | PermissionSet.EmbedLinks)) + await _errorMessageService.SendErrorMessage(reportChannel.Value, sentryEvent.EventId.ToString()); } } diff --git a/PluralKit.Bot/BotConfig.cs b/PluralKit.Bot/BotConfig.cs index 5f2b4613..dd4a6a0e 100644 --- a/PluralKit.Bot/BotConfig.cs +++ b/PluralKit.Bot/BotConfig.cs @@ -22,6 +22,8 @@ namespace PluralKit.Bot public string? DiscordBaseUrl { get; set; } + public bool DisableErrorReporting { get; set; } = false; + public record ClusterSettings { public string NodeName { get; set; }