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.
94 lines
3.7 KiB
94 lines
3.7 KiB
using ErsatzTV.Application.Emby; |
|
using ErsatzTV.Application.Jellyfin; |
|
using ErsatzTV.Application.Plex; |
|
using ErsatzTV.Core; |
|
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Core.Interfaces.Locking; |
|
using ErsatzTV.Infrastructure.Data; |
|
using ErsatzTV.Infrastructure.Extensions; |
|
using Microsoft.EntityFrameworkCore; |
|
using Microsoft.Extensions.Logging; |
|
|
|
namespace ErsatzTV.Application.Libraries; |
|
|
|
public class QueueShowScanByLibraryIdHandler( |
|
IDbContextFactory<TvContext> dbContextFactory, |
|
IEntityLocker locker, |
|
IMediator mediator, |
|
ILogger<QueueShowScanByLibraryIdHandler> logger) |
|
: IRequestHandler<QueueShowScanByLibraryId, bool> |
|
{ |
|
public async Task<bool> Handle(QueueShowScanByLibraryId request, CancellationToken cancellationToken) |
|
{ |
|
await using TvContext dbContext = await dbContextFactory.CreateDbContextAsync(cancellationToken); |
|
|
|
Option<Library> maybeLibrary = await dbContext.Libraries |
|
.AsNoTracking() |
|
.SelectOneAsync(l => l.Id, l => l.Id == request.LibraryId); |
|
|
|
foreach (Library library in maybeLibrary) |
|
{ |
|
bool shouldSyncItems = library switch |
|
{ |
|
PlexLibrary plexLibrary => plexLibrary.ShouldSyncItems, |
|
JellyfinLibrary jellyfinLibrary => jellyfinLibrary.ShouldSyncItems, |
|
EmbyLibrary embyLibrary => embyLibrary.ShouldSyncItems, |
|
_ => true |
|
}; |
|
|
|
if (!shouldSyncItems) |
|
{ |
|
logger.LogWarning("Library sync is disabled for library id {Id}", library.Id); |
|
return false; |
|
} |
|
|
|
// Check if library is already being scanned - return false if locked |
|
if (!locker.LockLibrary(library.Id)) |
|
{ |
|
logger.LogWarning("Library {Id} is already being scanned, cannot scan individual show", library.Id); |
|
return false; |
|
} |
|
|
|
logger.LogDebug( |
|
"Queued show scan for library id {Id}, show: {ShowTitle}, deepScan: {DeepScan}", |
|
library.Id, |
|
request.ShowTitle, |
|
request.DeepScan); |
|
|
|
try |
|
{ |
|
switch (library) |
|
{ |
|
case PlexLibrary: |
|
Either<BaseError, string> plexResult = await mediator.Send( |
|
new SynchronizePlexShowById(library.Id, request.ShowId, request.DeepScan), |
|
cancellationToken); |
|
return plexResult.IsRight; |
|
case JellyfinLibrary: |
|
Either<BaseError, string> jellyfinResult = await mediator.Send( |
|
new SynchronizeJellyfinShowById(library.Id, request.ShowId, request.DeepScan), |
|
cancellationToken); |
|
return jellyfinResult.IsRight; |
|
case EmbyLibrary: |
|
Either<BaseError, string> embyResult = await mediator.Send( |
|
new SynchronizeEmbyShowById(library.Id, request.ShowId, request.DeepScan), |
|
cancellationToken); |
|
return embyResult.IsRight; |
|
case LocalLibrary: |
|
logger.LogWarning("Single show scanning is not supported for local libraries"); |
|
return false; |
|
default: |
|
logger.LogWarning("Unknown library type for library {Id}", library.Id); |
|
return false; |
|
} |
|
} |
|
finally |
|
{ |
|
// Always unlock the library when we're done |
|
locker.UnlockLibrary(library.Id); |
|
} |
|
} |
|
|
|
return false; |
|
} |
|
}
|
|
|