From ebd279da45664dcb03feeacae7200bed2aa974ca Mon Sep 17 00:00:00 2001 From: Toastie Date: Thu, 26 Dec 2024 20:24:32 +1300 Subject: [PATCH] Improved error handling in interview database functions --- Database.cs | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/Database.cs b/Database.cs index 1f6a9ed..2a0aaf3 100644 --- a/Database.cs +++ b/Database.cs @@ -772,9 +772,9 @@ public static class Database { Error = delegate (object sender, ErrorEventArgs args) { - Logger.Error("Exception occured when trying to read interview from database:\n" + args.ErrorContext.Error.Message); + Logger.Error("Error occured when trying to read interview templates from database: " + args.ErrorContext.Error.Message); Logger.Debug("Detailed exception:", args.ErrorContext.Error); - args.ErrorContext.Handled = true; + args.ErrorContext.Handled = false; } }); } @@ -823,11 +823,20 @@ public static class Database Dictionary questions = new(); do { - // Channel ID 0 is the interview template - if (results.GetUInt64("channel_id") != 0) + try { - questions.Add(results.GetUInt64("channel_id"), JsonConvert.DeserializeObject(results.GetString("interview"))); + // Channel ID 0 is the interview template, don't read it here. + if (results.GetUInt64("channel_id") != 0) + { + questions.Add(results.GetUInt64("channel_id"), JsonConvert.DeserializeObject(results.GetString("interview"))); + } } + catch (Exception e) + { + Logger.Error("Error occured when trying to read interview from database, it will not be loaded until manually fixed in the database.\nError message: " + e.Message); + Logger.Debug("Detailed exception:", e); + } + } while (results.Read()); results.Close();