diff options
Diffstat (limited to 'MediaBrowser.Api/Sync/SyncService.cs')
| -rw-r--r-- | MediaBrowser.Api/Sync/SyncService.cs | 84 |
1 files changed, 80 insertions, 4 deletions
diff --git a/MediaBrowser.Api/Sync/SyncService.cs b/MediaBrowser.Api/Sync/SyncService.cs index a3c2004fc..d4d1106ec 100644 --- a/MediaBrowser.Api/Sync/SyncService.cs +++ b/MediaBrowser.Api/Sync/SyncService.cs @@ -1,9 +1,14 @@ -using MediaBrowser.Controller.Net; +using MediaBrowser.Controller.Dto; +using MediaBrowser.Controller.Library; +using MediaBrowser.Controller.Net; using MediaBrowser.Controller.Sync; +using MediaBrowser.Model.Dto; using MediaBrowser.Model.Querying; using MediaBrowser.Model.Sync; using ServiceStack; +using System; using System.Collections.Generic; +using System.Linq; using System.Threading.Tasks; namespace MediaBrowser.Api.Sync @@ -52,14 +57,42 @@ namespace MediaBrowser.Api.Sync public string UserId { get; set; } } + [Route("/Sync/Options", "GET", Summary = "Gets a list of available sync targets.")] + public class GetSyncDialogOptions : IReturn<SyncDialogOptions> + { + [ApiMember(Name = "UserId", Description = "UserId", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "GET")] + public string UserId { get; set; } + + [ApiMember(Name = "ItemIds", Description = "ItemIds", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "GET")] + public string ItemIds { get; set; } + } + + [Route("/Sync/JobItems/{Id}/Transferred", "POST", Summary = "Reports that a sync job item has successfully been transferred.")] + public class ReportSyncJobItemTransferred : IReturnVoid + { + [ApiMember(Name = "Id", Description = "Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")] + public string Id { get; set; } + } + + [Route("/Sync/JobItems/{Id}/File", "GET", Summary = "Gets a sync job item file")] + public class GetSyncJobItemFile + { + [ApiMember(Name = "Id", Description = "Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] + public string Id { get; set; } + } + [Authenticated] public class SyncService : BaseApiService { private readonly ISyncManager _syncManager; + private readonly IDtoService _dtoService; + private readonly ILibraryManager _libraryManager; - public SyncService(ISyncManager syncManager) + public SyncService(ISyncManager syncManager, IDtoService dtoService, ILibraryManager libraryManager) { _syncManager = syncManager; + _dtoService = dtoService; + _libraryManager = libraryManager; } public object Get(GetSyncTargets request) @@ -73,8 +106,8 @@ namespace MediaBrowser.Api.Sync { var result = _syncManager.GetJobs(new SyncJobQuery { - StartIndex = request.StartIndex, - Limit = request.Limit + StartIndex = request.StartIndex, + Limit = request.Limit }); return ToOptimizedResult(result); @@ -100,5 +133,48 @@ namespace MediaBrowser.Api.Sync return ToOptimizedResult(result); } + + public void Post(ReportSyncJobItemTransferred request) + { + var task = _syncManager.ReportSyncJobItemTransferred(request.Id); + + Task.WaitAll(task); + } + + public object Get(GetSyncJobItemFile request) + { + var jobItem = _syncManager.GetJobItem(request.Id); + + if (jobItem.Status != SyncJobItemStatus.Transferring) + { + throw new ArgumentException("The job item is not yet ready for transfer."); + } + + return ToStaticFileResult(jobItem.OutputPath); + } + + public object Get(GetSyncDialogOptions request) + { + var result = new SyncDialogOptions(); + + result.Targets = _syncManager.GetSyncTargets(request.UserId) + .ToList(); + + var dtos = request.ItemIds.Split(',') + .Select(_libraryManager.GetItemById) + .Where(i => i != null) + .Select(i => _dtoService.GetBaseItemDto(i, new DtoOptions + { + Fields = new List<ItemFields> + { + ItemFields.SyncInfo + } + })) + .ToList(); + + result.Options = SyncHelper.GetSyncOptions(dtos); + + return ToOptimizedResult(result); + } } } |
