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.
128 lines
4.7 KiB
128 lines
4.7 KiB
using System.Globalization; |
|
using ErsatzTV.Application.Libraries; |
|
using ErsatzTV.Core; |
|
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Core.Errors; |
|
using ErsatzTV.Core.Interfaces.Metadata; |
|
using ErsatzTV.Core.Interfaces.Repositories; |
|
using ErsatzTV.FFmpeg.Runtime; |
|
using ErsatzTV.Infrastructure.Data; |
|
using ErsatzTV.Infrastructure.Extensions; |
|
using Microsoft.EntityFrameworkCore; |
|
using Microsoft.Extensions.Logging; |
|
|
|
namespace ErsatzTV.Application.Emby; |
|
|
|
public class CallEmbyLibraryScannerHandler : CallLibraryScannerHandler<ISynchronizeEmbyLibraryById>, |
|
IRequestHandler<ForceSynchronizeEmbyLibraryById, Either<BaseError, string>>, |
|
IRequestHandler<SynchronizeEmbyLibraryByIdIfNeeded, Either<BaseError, string>> |
|
{ |
|
private readonly IScannerProxyService _scannerProxyService; |
|
|
|
public CallEmbyLibraryScannerHandler( |
|
IDbContextFactory<TvContext> dbContextFactory, |
|
IConfigElementRepository configElementRepository, |
|
IScannerProxyService scannerProxyService, |
|
IRuntimeInfo runtimeInfo, |
|
ILogger<CallEmbyLibraryScannerHandler> logger) |
|
: base(dbContextFactory, configElementRepository, runtimeInfo, logger) |
|
{ |
|
_scannerProxyService = scannerProxyService; |
|
} |
|
|
|
Task<Either<BaseError, string>> IRequestHandler<ForceSynchronizeEmbyLibraryById, Either<BaseError, string>>.Handle( |
|
ForceSynchronizeEmbyLibraryById request, |
|
CancellationToken cancellationToken) => Handle(request, cancellationToken); |
|
|
|
Task<Either<BaseError, string>> IRequestHandler<SynchronizeEmbyLibraryByIdIfNeeded, Either<BaseError, string>>. |
|
Handle( |
|
SynchronizeEmbyLibraryByIdIfNeeded request, |
|
CancellationToken cancellationToken) => Handle(request, cancellationToken); |
|
|
|
private async Task<Either<BaseError, string>> Handle( |
|
ISynchronizeEmbyLibraryById request, |
|
CancellationToken cancellationToken) |
|
{ |
|
Validation<BaseError, ScanParameters> validation = await Validate(request, cancellationToken); |
|
return await validation.Match( |
|
parameters => PerformScan(parameters, request, cancellationToken), |
|
error => |
|
{ |
|
foreach (ScanIsNotRequired scanIsNotRequired in error.OfType<ScanIsNotRequired>()) |
|
{ |
|
return Task.FromResult<Either<BaseError, string>>(scanIsNotRequired); |
|
} |
|
|
|
return Task.FromResult<Either<BaseError, string>>(error.Join()); |
|
}); |
|
} |
|
|
|
private async Task<Either<BaseError, string>> PerformScan( |
|
ScanParameters parameters, |
|
ISynchronizeEmbyLibraryById request, |
|
CancellationToken cancellationToken) |
|
{ |
|
Option<Guid> maybeScanId = _scannerProxyService.StartScan(request.EmbyLibraryId); |
|
foreach (var scanId in maybeScanId) |
|
{ |
|
try |
|
{ |
|
var arguments = new List<string> |
|
{ |
|
"scan-emby", |
|
request.EmbyLibraryId.ToString(CultureInfo.InvariantCulture), |
|
GetBaseUrl(scanId) |
|
}; |
|
|
|
if (request.ForceScan) |
|
{ |
|
arguments.Add("--force"); |
|
} |
|
|
|
if (request.DeepScan) |
|
{ |
|
arguments.Add("--deep"); |
|
} |
|
|
|
return await base.PerformScan(parameters, arguments, cancellationToken); |
|
} |
|
finally |
|
{ |
|
_scannerProxyService.EndScan(scanId); |
|
} |
|
} |
|
|
|
return BaseError.New($"Library {request.EmbyLibraryId} is already scanning"); |
|
} |
|
|
|
protected override async Task<Tuple<string, DateTimeOffset>> GetLastScan( |
|
TvContext dbContext, |
|
ISynchronizeEmbyLibraryById request, |
|
CancellationToken cancellationToken) |
|
{ |
|
Option<EmbyLibrary> maybeLibrary = await dbContext.EmbyLibraries |
|
.SelectOneAsync(l => l.Id, l => l.Id == request.EmbyLibraryId, cancellationToken); |
|
|
|
DateTime minDateTime = maybeLibrary.Match( |
|
l => l.LastScan ?? SystemTime.MinValueUtc, |
|
() => SystemTime.MaxValueUtc); |
|
|
|
string libraryName = maybeLibrary.Match(l => l.Name, string.Empty); |
|
|
|
return new Tuple<string, DateTimeOffset>(libraryName, new DateTimeOffset(minDateTime, TimeSpan.Zero)); |
|
} |
|
|
|
protected override bool ScanIsRequired( |
|
DateTimeOffset lastScan, |
|
int libraryRefreshInterval, |
|
ISynchronizeEmbyLibraryById request) |
|
{ |
|
if (lastScan == SystemTime.MaxValueUtc) |
|
{ |
|
return false; |
|
} |
|
|
|
DateTimeOffset nextScan = lastScan + TimeSpan.FromHours(libraryRefreshInterval); |
|
return request.ForceScan || libraryRefreshInterval > 0 && nextScan < DateTimeOffset.Now; |
|
} |
|
}
|
|
|