mirror of https://github.com/ErsatzTV/ErsatzTV.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
1.4 KiB
36 lines
1.4 KiB
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Infrastructure.Data; |
|
using ErsatzTV.Infrastructure.Extensions; |
|
using Microsoft.EntityFrameworkCore; |
|
|
|
namespace ErsatzTV.Application.Scheduling; |
|
|
|
public class ErasePlayoutHistoryHandler(IDbContextFactory<TvContext> dbContextFactory) |
|
: IRequestHandler<ErasePlayoutHistory> |
|
{ |
|
public async Task Handle(ErasePlayoutHistory request, CancellationToken cancellationToken) |
|
{ |
|
await using TvContext dbContext = await dbContextFactory.CreateDbContextAsync(cancellationToken); |
|
|
|
Option<Playout> maybePlayout = await dbContext.Playouts |
|
.Filter( |
|
p => p.ProgramSchedulePlayoutType == ProgramSchedulePlayoutType.Block || |
|
p.ProgramSchedulePlayoutType == ProgramSchedulePlayoutType.Yaml) |
|
.SelectOneAsync(p => p.Id, p => p.Id == request.PlayoutId); |
|
|
|
foreach (Playout playout in maybePlayout) |
|
{ |
|
int nextSeed = new Random().Next(); |
|
playout.Seed = nextSeed; |
|
await dbContext.SaveChangesAsync(cancellationToken); |
|
|
|
await dbContext.Database.ExecuteSqlAsync( |
|
$"DELETE FROM PlayoutItem WHERE PlayoutId = {playout.Id}", |
|
cancellationToken); |
|
|
|
await dbContext.Database.ExecuteSqlAsync( |
|
$"DELETE FROM PlayoutHistory WHERE PlayoutId = {playout.Id}", |
|
cancellationToken); |
|
} |
|
} |
|
}
|
|
|