aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2016-12-30 16:14:21 -0500
committerLuke Pulverenti <luke.pulverenti@gmail.com>2016-12-30 16:14:21 -0500
commit1dea300f6ba88d2d87110b91f8f15c015412794c (patch)
treebe9993319e041c76436b4b49c8183fec473a2f4a
parentb8f57f586b218558bcb45259d65dfe990e593559 (diff)
handle non-existent user with sync jobs
-rw-r--r--Emby.Server.Implementations/Sync/SyncJobProcessor.cs20
-rw-r--r--Emby.Server.Implementations/Sync/SyncManager.cs2
2 files changed, 12 insertions, 10 deletions
diff --git a/Emby.Server.Implementations/Sync/SyncJobProcessor.cs b/Emby.Server.Implementations/Sync/SyncJobProcessor.cs
index b1adc64df..17cdef5fc 100644
--- a/Emby.Server.Implementations/Sync/SyncJobProcessor.cs
+++ b/Emby.Server.Implementations/Sync/SyncJobProcessor.cs
@@ -59,15 +59,8 @@ namespace Emby.Server.Implementations.Sync
_mediaSourceManager = mediaSourceManager;
}
- public async Task EnsureJobItems(SyncJob job)
+ public async Task EnsureJobItems(SyncJob job, User user)
{
- var user = _userManager.GetUserById(job.UserId);
-
- if (user == null)
- {
- throw new InvalidOperationException("Cannot proceed with sync because user no longer exists.");
- }
-
var items = (await GetItemsForSync(job.Category, job.ParentId, job.RequestedItemIds, user, job.UnwatchedOnly).ConfigureAwait(false))
.ToList();
@@ -385,7 +378,16 @@ namespace Emby.Server.Implementations.Sync
if (job.SyncNewContent)
{
- await EnsureJobItems(job).ConfigureAwait(false);
+ var user = _userManager.GetUserById(job.UserId);
+
+ if (user == null)
+ {
+ await _syncManager.CancelJob(job.Id).ConfigureAwait(false);
+ }
+ else
+ {
+ await EnsureJobItems(job, user).ConfigureAwait(false);
+ }
}
}
}
diff --git a/Emby.Server.Implementations/Sync/SyncManager.cs b/Emby.Server.Implementations/Sync/SyncManager.cs
index 310b35afe..2687eaefc 100644
--- a/Emby.Server.Implementations/Sync/SyncManager.cs
+++ b/Emby.Server.Implementations/Sync/SyncManager.cs
@@ -181,7 +181,7 @@ namespace Emby.Server.Implementations.Sync
await _repo.Create(job).ConfigureAwait(false);
- await processor.EnsureJobItems(job).ConfigureAwait(false);
+ await processor.EnsureJobItems(job, user).ConfigureAwait(false);
// If it already has a converting status then is must have been aborted during conversion
var jobItemsResult = GetJobItems(new SyncJobItemQuery