sharp-chat/SharpChat.SQLite/SQLiteStorage.cs

67 lines
2.1 KiB
C#
Raw Normal View History

2025-04-28 12:29:11 +00:00
using Microsoft.Extensions.Logging;
2025-04-27 22:31:35 +00:00
using SharpChat.Configuration;
using SharpChat.Messages;
using SharpChat.Storage;
2025-04-27 22:31:35 +00:00
using System.Data.SQLite;
2025-04-28 12:29:11 +00:00
using ZLogger;
2025-04-27 22:31:35 +00:00
using NativeSQLiteConnection = System.Data.SQLite.SQLiteConnection;
namespace SharpChat.SQLite;
public class SQLiteStorage(ILogger logger, string connString) : StorageBackend, IDisposable {
2025-04-27 22:31:35 +00:00
public const string MEMORY = "file::memory:?cache=shared";
public const string DEFAULT = "sharpchat.db";
public SQLiteConnection Connection { get; } = new SQLiteConnection(new NativeSQLiteConnection(connString).OpenAndReturn());
public MessageStorage CreateMessageStorage() {
2025-04-28 12:29:11 +00:00
return new SQLiteMessageStorage(logger, Connection);
2025-04-27 22:31:35 +00:00
}
public async Task UpgradeStorage() {
2025-04-28 12:29:11 +00:00
logger.ZLogInformation($"Upgrading storage...");
await new SQLiteMigrations(logger, Connection).RunMigrations();
2025-04-27 22:31:35 +00:00
}
public static string BuildConnectionString(Config config, bool journalling = true) {
2025-04-27 22:31:35 +00:00
return BuildConnectionString(
config.ReadValue("path", DEFAULT)!,
config.ReadValue("pass"),
config.ReadValue("journal", journalling)
2025-04-27 22:31:35 +00:00
);
}
public static string BuildConnectionString(string path, string? password, bool journalling = true) {
2025-04-27 22:31:35 +00:00
return new SQLiteConnectionStringBuilder {
DataSource = string.IsNullOrWhiteSpace(path) ? MEMORY : path,
DateTimeFormat = SQLiteDateFormats.ISO8601,
DateTimeKind = DateTimeKind.Utc,
FailIfMissing = false,
ForeignKeys = true,
JournalMode = journalling ? SQLiteJournalModeEnum.Wal : SQLiteJournalModeEnum.Off,
2025-04-27 22:31:35 +00:00
LegacyFormat = false,
Password = string.IsNullOrWhiteSpace(password) ? null : password,
ReadOnly = false,
UseUTF16Encoding = false,
}.ToString();
}
private bool disposed = false;
~SQLiteStorage() {
DoDispose();
}
public void Dispose() {
DoDispose();
GC.SuppressFinalize(this);
}
private void DoDispose() {
if(disposed)
return;
disposed = true;
Connection.Dispose();
}
}