2023-03-21 10:40:23 +00:00
|
|
|
using System.Reactive.Concurrency;
|
2023-03-15 13:38:06 +00:00
|
|
|
using System.Reactive.Linq;
|
|
|
|
using InnovEnergy.App.Backend.DataTypes;
|
2023-03-16 09:34:47 +00:00
|
|
|
using InnovEnergy.App.Backend.DataTypes.Methods;
|
2023-03-15 13:38:06 +00:00
|
|
|
using InnovEnergy.App.Backend.Relations;
|
2023-02-16 12:57:06 +00:00
|
|
|
using InnovEnergy.Lib.Utils;
|
|
|
|
using SQLite;
|
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
|
2023-03-08 12:20:33 +00:00
|
|
|
namespace InnovEnergy.App.Backend.Database;
|
2023-02-16 12:57:06 +00:00
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
|
2023-03-13 10:36:50 +00:00
|
|
|
public static partial class Db
|
2023-02-16 12:57:06 +00:00
|
|
|
{
|
|
|
|
internal const String DbPath = "./db.sqlite";
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
private static SQLiteConnection Connection { get; } = new SQLiteConnection(DbPath);
|
2023-03-13 10:48:04 +00:00
|
|
|
|
2023-04-04 08:39:42 +00:00
|
|
|
public static TableQuery<Session> Sessions => Connection.Table<Session>();
|
|
|
|
public static TableQuery<Folder> Folders => Connection.Table<Folder>();
|
|
|
|
public static TableQuery<Installation> Installations => Connection.Table<Installation>();
|
|
|
|
public static TableQuery<User> Users => Connection.Table<User>();
|
|
|
|
public static TableQuery<FolderAccess> FolderAccess => Connection.Table<FolderAccess>();
|
|
|
|
public static TableQuery<InstallationAccess> InstallationAccess => Connection.Table<InstallationAccess>();
|
|
|
|
public static TableQuery<OrderNumber2Installation> OrderNumber2Installation => Connection.Table<OrderNumber2Installation>();
|
|
|
|
|
|
|
|
public static TableQuery<DeletedInstallation> DeletedInstallations => Connection.Table<DeletedInstallation>();
|
|
|
|
public static TableQuery<DeletedUser> DeletedUsers => Connection.Table<DeletedUser>();
|
|
|
|
public static TableQuery<DeletedFolder> DeletedFolders => Connection.Table<DeletedFolder>();
|
2023-03-23 12:28:55 +00:00
|
|
|
|
|
|
|
public static void Init()
|
|
|
|
{
|
2023-04-04 08:39:42 +00:00
|
|
|
// used to force static constructor
|
2023-03-23 12:28:55 +00:00
|
|
|
}
|
|
|
|
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-02-16 12:57:06 +00:00
|
|
|
static Db()
|
|
|
|
{
|
|
|
|
// on startup create/migrate tables
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
Connection.RunInTransaction(() =>
|
2023-02-16 12:57:06 +00:00
|
|
|
{
|
2023-03-15 13:38:06 +00:00
|
|
|
Connection.CreateTable<User>();
|
2023-03-23 12:28:55 +00:00
|
|
|
Connection.CreateTable<DeletedUser>();
|
2023-03-15 13:38:06 +00:00
|
|
|
Connection.CreateTable<Installation>();
|
2023-03-23 12:28:55 +00:00
|
|
|
Connection.CreateTable<DeletedInstallation>();
|
|
|
|
Connection.CreateTable<DeletedFolder>();
|
2023-03-15 13:38:06 +00:00
|
|
|
Connection.CreateTable<Folder>();
|
2023-03-16 08:25:36 +00:00
|
|
|
Connection.CreateTable<FolderAccess>();
|
|
|
|
Connection.CreateTable<InstallationAccess>();
|
2023-03-15 13:38:06 +00:00
|
|
|
Connection.CreateTable<Session>();
|
2023-03-23 13:23:03 +00:00
|
|
|
Connection.CreateTable<OrderNumber2Installation>();
|
2023-02-16 12:57:06 +00:00
|
|
|
});
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-03-16 09:31:24 +00:00
|
|
|
Observable.Interval(TimeSpan.FromDays(0.5))
|
2023-03-21 10:40:23 +00:00
|
|
|
.StartWith(0) // Do it right away (on startup)
|
|
|
|
.ObserveOn(TaskPoolScheduler.Default)
|
2023-04-04 08:39:42 +00:00
|
|
|
.SubscribeOn(TaskPoolScheduler.Default)
|
2023-03-16 09:31:24 +00:00
|
|
|
.SelectMany(Cleanup)
|
2023-03-21 10:40:23 +00:00
|
|
|
.Subscribe();
|
2023-02-16 12:57:06 +00:00
|
|
|
}
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
private static Boolean RunTransaction(Func<Boolean> func)
|
2023-02-16 12:57:06 +00:00
|
|
|
{
|
2023-03-15 13:38:06 +00:00
|
|
|
var savepoint = Connection.SaveTransactionPoint();
|
|
|
|
var success = false;
|
|
|
|
|
2023-02-16 12:57:06 +00:00
|
|
|
try
|
|
|
|
{
|
2023-03-15 13:38:06 +00:00
|
|
|
success = func();
|
2023-02-16 12:57:06 +00:00
|
|
|
}
|
2023-03-15 13:38:06 +00:00
|
|
|
finally
|
2023-02-16 12:57:06 +00:00
|
|
|
{
|
2023-03-15 13:38:06 +00:00
|
|
|
if (success)
|
|
|
|
Connection.Release(savepoint);
|
|
|
|
else
|
|
|
|
Connection.RollbackTo(savepoint);
|
2023-02-16 12:57:06 +00:00
|
|
|
}
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
return success;
|
2023-02-16 12:57:06 +00:00
|
|
|
}
|
2023-03-09 15:32:11 +00:00
|
|
|
|
2023-02-16 12:57:06 +00:00
|
|
|
|
2023-03-16 09:34:47 +00:00
|
|
|
private static async Task<Boolean> Cleanup(Int64 _)
|
2023-02-21 08:58:21 +00:00
|
|
|
{
|
2023-03-16 09:31:24 +00:00
|
|
|
await UpdateS3Urls();
|
2023-03-15 13:38:06 +00:00
|
|
|
DeleteStaleSessions();
|
2023-03-16 09:31:24 +00:00
|
|
|
return true;
|
2023-02-21 08:58:21 +00:00
|
|
|
}
|
2023-03-09 11:50:21 +00:00
|
|
|
|
2023-03-15 13:38:06 +00:00
|
|
|
private static void DeleteStaleSessions()
|
2023-03-09 11:50:21 +00:00
|
|
|
{
|
2023-03-15 13:38:06 +00:00
|
|
|
var deadline = DateTime.Now - Session.MaxAge;
|
|
|
|
Sessions.Delete(s => s.LastSeen < deadline);
|
2023-03-09 11:50:21 +00:00
|
|
|
}
|
2023-03-09 12:20:37 +00:00
|
|
|
|
2023-03-16 09:31:24 +00:00
|
|
|
private static Task UpdateS3Urls()
|
2023-03-09 12:20:37 +00:00
|
|
|
{
|
2023-03-19 15:09:37 +00:00
|
|
|
return Installations
|
|
|
|
.Select(i => i.RenewS3BucketUrl())
|
|
|
|
.WhenAll();
|
2023-03-09 12:20:37 +00:00
|
|
|
}
|
2023-03-23 13:58:59 +00:00
|
|
|
|
2023-03-09 15:32:11 +00:00
|
|
|
}
|