aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--MediaBrowser.Api/Playback/MediaInfoService.cs35
-rw-r--r--MediaBrowser.Server.Implementations/Session/SessionManager.cs9
-rw-r--r--MediaBrowser.Server.Implementations/Session/SessionWebSocketListener.cs8
3 files changed, 33 insertions, 19 deletions
diff --git a/MediaBrowser.Api/Playback/MediaInfoService.cs b/MediaBrowser.Api/Playback/MediaInfoService.cs
index dfb5086b9..5adb76cc5 100644
--- a/MediaBrowser.Api/Playback/MediaInfoService.cs
+++ b/MediaBrowser.Api/Playback/MediaInfoService.cs
@@ -1,7 +1,10 @@
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Net;
+using MediaBrowser.Model.Dlna;
+using MediaBrowser.Model.Dto;
using MediaBrowser.Model.MediaInfo;
using ServiceStack;
+using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
@@ -38,24 +41,34 @@ namespace MediaBrowser.Api.Playback
_mediaSourceManager = mediaSourceManager;
}
- public async Task<object> Get(GetPlaybackInfo request)
+ public Task<object> Get(GetPlaybackInfo request)
{
- var mediaSources = await _mediaSourceManager.GetPlayackMediaSources(request.Id, request.UserId, true, CancellationToken.None).ConfigureAwait(false);
+ return GetPlaybackInfo(request.Id, request.UserId);
+ }
- return ToOptimizedResult(new LiveMediaInfoResult
- {
- MediaSources = mediaSources.ToList()
- });
+ public Task<object> Get(GetLiveMediaInfo request)
+ {
+ return GetPlaybackInfo(request.Id, request.UserId);
}
- public async Task<object> Get(GetLiveMediaInfo request)
+ private async Task<object> GetPlaybackInfo(string id, string userId)
{
- var mediaSources = await _mediaSourceManager.GetPlayackMediaSources(request.Id, request.UserId, true, CancellationToken.None).ConfigureAwait(false);
+ IEnumerable<MediaSourceInfo> mediaSources;
+ var result = new LiveMediaInfoResult();
- return ToOptimizedResult(new LiveMediaInfoResult
+ try
{
- MediaSources = mediaSources.ToList()
- });
+ mediaSources = await _mediaSourceManager.GetPlayackMediaSources(id, userId, true, CancellationToken.None).ConfigureAwait(false);
+ }
+ catch (PlaybackException ex)
+ {
+ mediaSources = new List<MediaSourceInfo>();
+ result.ErrorCode = ex.ErrorCode;
+ }
+
+ result.MediaSources = mediaSources.ToList();
+
+ return ToOptimizedResult(result);
}
}
}
diff --git a/MediaBrowser.Server.Implementations/Session/SessionManager.cs b/MediaBrowser.Server.Implementations/Session/SessionManager.cs
index 76e97ff48..8a21ed6bd 100644
--- a/MediaBrowser.Server.Implementations/Session/SessionManager.cs
+++ b/MediaBrowser.Server.Implementations/Session/SessionManager.cs
@@ -1687,16 +1687,11 @@ namespace MediaBrowser.Server.Implementations.Session
AccessToken = token
});
- if (result.Items.Length == 0)
- {
- return null;
- }
-
- var info = result.Items[0];
+ var info = result.Items.FirstOrDefault();
if (info == null)
{
- return null;
+ return Task.FromResult<SessionInfo>(null);
}
return GetSessionByAuthenticationToken(info, deviceId, remoteEndpoint, null);
diff --git a/MediaBrowser.Server.Implementations/Session/SessionWebSocketListener.cs b/MediaBrowser.Server.Implementations/Session/SessionWebSocketListener.cs
index dda4c2b90..b8cab0c19 100644
--- a/MediaBrowser.Server.Implementations/Session/SessionWebSocketListener.cs
+++ b/MediaBrowser.Server.Implementations/Session/SessionWebSocketListener.cs
@@ -85,7 +85,8 @@ namespace MediaBrowser.Server.Implementations.Session
async void _httpServer_WebSocketConnecting(object sender, WebSocketConnectingEventArgs e)
{
- if (e.QueryString.AllKeys.Contains("api_key", StringComparer.OrdinalIgnoreCase))
+ var token = e.QueryString["api_key"];
+ if (!string.IsNullOrWhiteSpace(token))
{
var session = await GetSession(e.QueryString, e.Endpoint).ConfigureAwait(false);
@@ -98,6 +99,11 @@ namespace MediaBrowser.Server.Implementations.Session
private Task<SessionInfo> GetSession(NameValueCollection queryString, string remoteEndpoint)
{
+ if (queryString == null)
+ {
+ throw new ArgumentNullException("queryString");
+ }
+
var token = queryString["api_key"];
if (string.IsNullOrWhiteSpace(token))
{