|
|
|
@ -377,6 +377,9 @@ namespace MediaBrowser.Server.Implementations.Sync
|
|
|
|
|
{
|
|
|
|
|
await EnsureSyncJobItems(null, cancellationToken).ConfigureAwait(false);
|
|
|
|
|
|
|
|
|
|
// Look job items that are supposedly transfering, but need to be requeued because the synced files have been deleted somehow
|
|
|
|
|
await HandleDeletedSyncFiles(cancellationToken).ConfigureAwait(false);
|
|
|
|
|
|
|
|
|
|
// If it already has a converting status then is must have been aborted during conversion
|
|
|
|
|
var result = _syncManager.GetJobItems(new SyncJobItemQuery
|
|
|
|
|
{
|
|
|
|
@ -389,6 +392,28 @@ namespace MediaBrowser.Server.Implementations.Sync
|
|
|
|
|
CleanDeadSyncFiles();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private async Task HandleDeletedSyncFiles(CancellationToken cancellationToken)
|
|
|
|
|
{
|
|
|
|
|
// Look job items that are supposedly transfering, but need to be requeued because the synced files have been deleted somehow
|
|
|
|
|
var result = _syncManager.GetJobItems(new SyncJobItemQuery
|
|
|
|
|
{
|
|
|
|
|
Statuses = new[] { SyncJobItemStatus.ReadyToTransfer, SyncJobItemStatus.Transferring },
|
|
|
|
|
AddMetadata = false
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
foreach (var item in result.Items)
|
|
|
|
|
{
|
|
|
|
|
cancellationToken.ThrowIfCancellationRequested();
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrWhiteSpace(item.OutputPath) || !_fileSystem.FileExists(item.OutputPath))
|
|
|
|
|
{
|
|
|
|
|
item.Status = SyncJobItemStatus.Queued;
|
|
|
|
|
await _syncManager.UpdateSyncJobItemInternal(item).ConfigureAwait(false);
|
|
|
|
|
await UpdateJobStatus(item.JobId).ConfigureAwait(false);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void CleanDeadSyncFiles()
|
|
|
|
|
{
|
|
|
|
|
// TODO
|
|
|
|
|