Updated SetValueAsKeyValuePairs to SetValueAsJsonObject

This commit is contained in:
barelyprofessional
2024-09-01 20:24:59 +08:00
parent 7509375b43
commit 67cd007252

View File

@@ -1,6 +1,7 @@
using KfChatDotNetBot.Models.DbModels; using KfChatDotNetBot.Models.DbModels;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using System.Runtime.Caching; using System.Runtime.Caching;
using System.Text.Json;
using NLog; using NLog;
namespace KfChatDotNetBot.Settings; namespace KfChatDotNetBot.Settings;
@@ -118,17 +119,13 @@ public static class Helpers
if (cache.Contains(key)) cache.Remove(key); if (cache.Contains(key)) cache.Remove(key);
} }
public static async Task SetValueAsKeyValuePairs<T>(string key, Dictionary<string, T> data, char delimiter = ',', public static async Task SetValueAsJsonObject<T>(string key, T data)
char separator = '=')
{ {
var logger = LogManager.GetCurrentClassLogger(); var logger = LogManager.GetCurrentClassLogger();
await using var db = new ApplicationDbContext(); await using var db = new ApplicationDbContext();
logger.Debug($"Building data for {key}"); logger.Debug($"Building data for {key}");
var value = data.Keys.Aggregate(string.Empty, var value = JsonSerializer.Serialize(data);
(current, dictKey) => current + $"{dictKey}{separator}{data[dictKey]}{delimiter}");
// Remove trailing delimiters that would be leftover as it doesn't account for whether it's the last key
value = value.TrimEnd(delimiter);
logger.Debug($"Setting {key} to {value}"); logger.Debug($"Setting {key} to {value}");
var setting = await db.Settings.FirstOrDefaultAsync(s => s.Key == key); var setting = await db.Settings.FirstOrDefaultAsync(s => s.Key == key);