aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Api/Playback/MediaInfoService.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MediaBrowser.Api/Playback/MediaInfoService.cs')
-rw-r--r--MediaBrowser.Api/Playback/MediaInfoService.cs58
1 files changed, 23 insertions, 35 deletions
diff --git a/MediaBrowser.Api/Playback/MediaInfoService.cs b/MediaBrowser.Api/Playback/MediaInfoService.cs
index 330a8777c..96958487b 100644
--- a/MediaBrowser.Api/Playback/MediaInfoService.cs
+++ b/MediaBrowser.Api/Playback/MediaInfoService.cs
@@ -1,18 +1,13 @@
-using MediaBrowser.Controller.Channels;
-using MediaBrowser.Controller.Entities;
-using MediaBrowser.Controller.Library;
+using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Net;
-using MediaBrowser.Model.Dto;
using MediaBrowser.Model.MediaInfo;
using ServiceStack;
-using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
namespace MediaBrowser.Api.Playback
{
- [Route("/Items/{Id}/MediaInfo", "GET", Summary = "Gets live playback media info for an item")]
[Route("/Items/{Id}/PlaybackInfo", "GET", Summary = "Gets live playback media info for an item")]
public class GetLiveMediaInfo : IReturn<LiveMediaInfoResult>
{
@@ -23,46 +18,39 @@ namespace MediaBrowser.Api.Playback
public string UserId { get; set; }
}
+ [Route("/Items/{Id}/PlaybackInfo", "GET", Summary = "Gets live playback media info for an item")]
+ public class GetPlaybackInfo : IReturn<LiveMediaInfoResult>
+ {
+ [ApiMember(Name = "Id", Description = "Item Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
+ public string Id { get; set; }
+
+ [ApiMember(Name = "UserId", Description = "User Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "GET")]
+ public string UserId { get; set; }
+ }
+
[Authenticated]
public class MediaInfoService : BaseApiService
{
- private readonly ILibraryManager _libraryManager;
- private readonly IChannelManager _channelManager;
- private readonly IUserManager _userManager;
+ private readonly IMediaSourceManager _mediaSourceManager;
- public MediaInfoService(ILibraryManager libraryManager, IChannelManager channelManager, IUserManager userManager)
+ public MediaInfoService(IMediaSourceManager mediaSourceManager)
{
- _libraryManager = libraryManager;
- _channelManager = channelManager;
- _userManager = userManager;
+ _mediaSourceManager = mediaSourceManager;
}
- public async Task<object> Get(GetLiveMediaInfo request)
+ public async Task<object> Get(GetPlaybackInfo request)
{
- var item = _libraryManager.GetItemById(request.Id);
- IEnumerable<MediaSourceInfo> mediaSources;
-
- var channelItem = item as IChannelMediaItem;
- var user = _userManager.GetUserById(request.UserId);
+ var mediaSources = await _mediaSourceManager.GetPlayackMediaSources(request.Id, request.UserId, CancellationToken.None).ConfigureAwait(false);
- if (channelItem != null)
- {
- mediaSources = await _channelManager.GetChannelItemMediaSources(request.Id, true, CancellationToken.None)
- .ConfigureAwait(false);
- }
- else
+ return ToOptimizedResult(new LiveMediaInfoResult
{
- var hasMediaSources = (IHasMediaSources)item;
+ MediaSources = mediaSources.ToList()
+ });
+ }
- if (user == null)
- {
- mediaSources = hasMediaSources.GetMediaSources(true);
- }
- else
- {
- mediaSources = hasMediaSources.GetMediaSources(true, user);
- }
- }
+ public async Task<object> Get(GetLiveMediaInfo request)
+ {
+ var mediaSources = await _mediaSourceManager.GetPlayackMediaSources(request.Id, request.UserId, CancellationToken.None).ConfigureAwait(false);
return ToOptimizedResult(new LiveMediaInfoResult
{