Kavita/API/Services/HostedServices/ReadingSessionInitializer.cs
Joe Milazzo fc7463a7f4
Polish Pass 3 - Profile Reading Activity (#4333)
Co-authored-by: Amelia <77553571+Fesaa@users.noreply.github.com>
2026-01-09 11:17:32 -08:00

47 lines
1.7 KiB
C#

using System;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using API.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
namespace API.Services.HostedServices;
public class ReadingSessionInitializer : IHostedService
{
private readonly IServiceScopeFactory _serviceScopeFactory;
private readonly ILogger<ReadingSessionInitializer> _logger;
public ReadingSessionInitializer(IServiceScopeFactory serviceScopeFactory,
ILogger<ReadingSessionInitializer> logger)
{
_serviceScopeFactory = serviceScopeFactory;
_logger = logger;
}
public async Task StartAsync(CancellationToken cancellationToken)
{
_logger.LogInformation("Closing any orphaned reading sessions from previous run");
using var scope = _serviceScopeFactory.CreateScope();
var context = scope.ServiceProvider.GetRequiredService<DataContext>();
var closedCount = await context.AppUserReadingSession
.Where(s => s.IsActive)
.ExecuteUpdateAsync(s => s
.SetProperty(x => x.IsActive, false)
.SetProperty(x => x.EndTime, x => x.LastModified)
.SetProperty(x => x.EndTimeUtc, x => x.LastModifiedUtc)
.SetProperty(x => x.LastModified, DateTime.Now)
.SetProperty(x => x.LastModifiedUtc, DateTime.UtcNow),
cancellationToken);
_logger.LogInformation("Closed {Count} orphaned reading sessions", closedCount);
}
public Task StopAsync(CancellationToken cancellationToken) => Task.CompletedTask;
}