aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Server.Implementations/Sync/SyncManager.cs
diff options
context:
space:
mode:
author7illusions <z@7illusions.com>2014-08-30 19:06:58 +0200
committer7illusions <z@7illusions.com>2014-08-30 19:06:58 +0200
commit66ad1699e22029b605e17735e8d9450285d8748a (patch)
treeffc92c88d24850b2f82b6b3a8bdd904a2ccc77a5 /MediaBrowser.Server.Implementations/Sync/SyncManager.cs
parent34bc54263e886aae777a3537dc50a6535b51330a (diff)
parent9d36f518182bc075c19d78084870f5115fa62d1e (diff)
Merge pull request #1 from MediaBrowser/master
Update to latest
Diffstat (limited to 'MediaBrowser.Server.Implementations/Sync/SyncManager.cs')
-rw-r--r--MediaBrowser.Server.Implementations/Sync/SyncManager.cs237
1 files changed, 237 insertions, 0 deletions
diff --git a/MediaBrowser.Server.Implementations/Sync/SyncManager.cs b/MediaBrowser.Server.Implementations/Sync/SyncManager.cs
new file mode 100644
index 000000000..b5e13e306
--- /dev/null
+++ b/MediaBrowser.Server.Implementations/Sync/SyncManager.cs
@@ -0,0 +1,237 @@
+using MediaBrowser.Common.Extensions;
+using MediaBrowser.Controller.Drawing;
+using MediaBrowser.Controller.Entities;
+using MediaBrowser.Controller.Entities.Audio;
+using MediaBrowser.Controller.Library;
+using MediaBrowser.Controller.Sync;
+using MediaBrowser.Model.Entities;
+using MediaBrowser.Model.Logging;
+using MediaBrowser.Model.Querying;
+using MediaBrowser.Model.Sync;
+using MoreLinq;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Threading.Tasks;
+
+namespace MediaBrowser.Server.Implementations.Sync
+{
+ public class SyncManager : ISyncManager
+ {
+ private readonly ILibraryManager _libraryManager;
+ private readonly ISyncRepository _repo;
+ private readonly IImageProcessor _imageProcessor;
+ private readonly ILogger _logger;
+
+ private ISyncProvider[] _providers = { };
+
+ public SyncManager(ILibraryManager libraryManager, ISyncRepository repo, IImageProcessor imageProcessor, ILogger logger)
+ {
+ _libraryManager = libraryManager;
+ _repo = repo;
+ _imageProcessor = imageProcessor;
+ _logger = logger;
+ }
+
+ public void AddParts(IEnumerable<ISyncProvider> providers)
+ {
+ _providers = providers.ToArray();
+ }
+
+ public async Task<SyncJobCreationResult> CreateJob(SyncJobRequest request)
+ {
+ var items = GetItemsForSync(request.ItemIds).ToList();
+
+ if (items.Count == 1)
+ {
+ request.Name = GetDefaultName(items[0]);
+ }
+
+ if (string.IsNullOrWhiteSpace(request.Name))
+ {
+ throw new ArgumentException("Please supply a name for the sync job.");
+ }
+
+ var target = GetSyncTargets(request.UserId)
+ .First(i => string.Equals(request.TargetId, i.Id));
+
+ var jobId = Guid.NewGuid().ToString("N");
+
+ var job = new SyncJob
+ {
+ Id = jobId,
+ Name = request.Name,
+ TargetId = target.Id,
+ UserId = request.UserId,
+ UnwatchedOnly = request.UnwatchedOnly,
+ Limit = request.Limit,
+ LimitType = request.LimitType,
+ RequestedItemIds = request.ItemIds,
+ DateCreated = DateTime.UtcNow,
+ DateLastModified = DateTime.UtcNow,
+ ItemCount = 1
+ };
+
+ await _repo.Create(job).ConfigureAwait(false);
+
+ return new SyncJobCreationResult
+ {
+ Job = GetJob(jobId)
+ };
+ }
+
+ public QueryResult<SyncJob> GetJobs(SyncJobQuery query)
+ {
+ var result = _repo.GetJobs(query);
+
+ result.Items.ForEach(FillMetadata);
+
+ return result;
+ }
+
+ private void FillMetadata(SyncJob job)
+ {
+ var item = GetItemsForSync(job.RequestedItemIds)
+ .FirstOrDefault();
+
+ if (item != null)
+ {
+ var hasSeries = item as IHasSeries;
+ if (hasSeries != null)
+ {
+ job.ParentName = hasSeries.SeriesName;
+ }
+
+ var hasAlbumArtist = item as IHasAlbumArtist;
+ if (hasAlbumArtist != null)
+ {
+ job.ParentName = hasAlbumArtist.AlbumArtists.FirstOrDefault();
+ }
+
+ var primaryImage = item.GetImageInfo(ImageType.Primary, 0);
+
+ if (primaryImage != null)
+ {
+ try
+ {
+ job.PrimaryImageTag = _imageProcessor.GetImageCacheTag(item, ImageType.Primary);
+ job.PrimaryImageItemId = item.Id.ToString("N");
+
+ }
+ catch (Exception ex)
+ {
+ _logger.ErrorException("Error getting image info", ex);
+ }
+ }
+ }
+ }
+
+ public Task CancelJob(string id)
+ {
+ throw new NotImplementedException();
+ }
+
+ public SyncJob GetJob(string id)
+ {
+ return _repo.GetJob(id);
+ }
+
+ public IEnumerable<SyncTarget> GetSyncTargets(string userId)
+ {
+ return _providers
+ .SelectMany(i => GetSyncTargets(i, userId))
+ .OrderBy(i => i.Name);
+ }
+
+ private IEnumerable<SyncTarget> GetSyncTargets(ISyncProvider provider, string userId)
+ {
+ var providerId = GetSyncProviderId(provider);
+
+ return provider.GetSyncTargets().Select(i => new SyncTarget
+ {
+ Name = i.Name,
+ Id = providerId + "-" + i.Id
+ });
+ }
+
+ private ISyncProvider GetSyncProvider(SyncTarget target)
+ {
+ var providerId = target.Id.Split(new[] { '-' }, 2).First();
+
+ return _providers.First(i => string.Equals(providerId, GetSyncProviderId(i)));
+ }
+
+ private string GetSyncProviderId(ISyncProvider provider)
+ {
+ return (provider.GetType().Name + provider.Name).GetMD5().ToString("N");
+ }
+
+ public bool SupportsSync(BaseItem item)
+ {
+ if (item.LocationType == LocationType.Virtual)
+ {
+ return false;
+ }
+
+ if (string.Equals(item.MediaType, MediaType.Audio, StringComparison.OrdinalIgnoreCase) ||
+ string.Equals(item.MediaType, MediaType.Video, StringComparison.OrdinalIgnoreCase))
+ {
+ if (item.RunTimeTicks.HasValue)
+ {
+ var video = item as Video;
+
+ if (video != null)
+ {
+ if (video.VideoType != VideoType.VideoFile)
+ {
+ return false;
+ }
+
+ if (video.IsMultiPart)
+ {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ return false;
+ }
+
+ return false;
+ }
+
+ private IEnumerable<BaseItem> GetItemsForSync(IEnumerable<string> itemIds)
+ {
+ return itemIds.SelectMany(GetItemsForSync).DistinctBy(i => i.Id);
+ }
+
+ private IEnumerable<BaseItem> GetItemsForSync(string id)
+ {
+ var item = _libraryManager.GetItemById(id);
+
+ if (item == null)
+ {
+ throw new ArgumentException("Item with Id " + id + " not found.");
+ }
+
+ if (!SupportsSync(item))
+ {
+ throw new ArgumentException("Item with Id " + id + " does not support sync.");
+ }
+
+ return GetItemsForSync(item);
+ }
+
+ private IEnumerable<BaseItem> GetItemsForSync(BaseItem item)
+ {
+ return new[] { item };
+ }
+
+ private string GetDefaultName(BaseItem item)
+ {
+ return item.Name;
+ }
+ }
+}