PalacePal/Pal.Client/Floors/Tasks/DbTask.cs

47 lines
1.3 KiB
C#
Raw Normal View History

2023-02-24 10:18:03 +00:00
using System;
using System.Threading.Tasks;
2023-02-18 20:12:36 +00:00
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
2023-02-18 20:12:36 +00:00
using Pal.Client.Database;
2023-03-30 20:01:43 +00:00
namespace Pal.Client.Floors.Tasks;
internal abstract class DbTask<T>
where T : DbTask<T>
2023-02-18 20:12:36 +00:00
{
2023-03-30 20:01:43 +00:00
private readonly IServiceScopeFactory _serviceScopeFactory;
2023-02-18 20:12:36 +00:00
2023-03-30 20:01:43 +00:00
protected DbTask(IServiceScopeFactory serviceScopeFactory)
{
_serviceScopeFactory = serviceScopeFactory;
}
2023-02-18 20:12:36 +00:00
2023-03-30 20:01:43 +00:00
public void Start()
{
Task.Run(() =>
2023-02-18 20:12:36 +00:00
{
2023-03-30 20:01:43 +00:00
try
2023-02-18 20:12:36 +00:00
{
2023-03-30 20:01:43 +00:00
using var scope = _serviceScopeFactory.CreateScope();
ILogger<T> logger = scope.ServiceProvider.GetRequiredService<ILogger<T>>();
2023-10-03 20:05:19 +00:00
try
{
using var dbContext = scope.ServiceProvider.GetRequiredService<PalClientContext>();
2023-02-18 20:12:36 +00:00
2023-10-03 20:05:19 +00:00
Run(dbContext, logger);
}
catch (Exception e)
{
logger.LogError(e, "Failed to run DbTask");
}
2023-03-30 20:01:43 +00:00
}
2023-10-03 20:05:19 +00:00
catch (Exception)
2023-03-30 20:01:43 +00:00
{
2023-10-03 20:05:19 +00:00
// nothing we can do here but catch it, if we don't we crash the game
2023-03-30 20:01:43 +00:00
}
});
2023-02-18 20:12:36 +00:00
}
2023-03-30 20:01:43 +00:00
protected abstract void Run(PalClientContext dbContext, ILogger<T> logger);
2023-02-18 20:12:36 +00:00
}