|
@@ -10,9 +10,9 @@ using System;
|
|
|
using System.Threading;
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
-namespace MediaBrowser.Server.Implementations.Roku
|
|
|
+namespace MediaBrowser.Server.Implementations.Session
|
|
|
{
|
|
|
- public class RokuSessionController : ISessionController
|
|
|
+ public class HttpSessionController : ISessionController
|
|
|
{
|
|
|
private readonly IHttpClient _httpClient;
|
|
|
private readonly IJsonSerializer _json;
|
|
@@ -20,12 +20,21 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
|
|
|
public SessionInfo Session { get; private set; }
|
|
|
|
|
|
- public RokuSessionController(IHttpClient httpClient, IJsonSerializer json, IServerApplicationHost appHost, SessionInfo session)
|
|
|
+ //var postUrl = string.Format("http://{0}/mediabrowser/message", session.RemoteEndPoint);
|
|
|
+
|
|
|
+ private readonly string _postUrl;
|
|
|
+
|
|
|
+ public HttpSessionController(IHttpClient httpClient,
|
|
|
+ IJsonSerializer json,
|
|
|
+ IServerApplicationHost appHost,
|
|
|
+ SessionInfo session,
|
|
|
+ string postUrl)
|
|
|
{
|
|
|
_httpClient = httpClient;
|
|
|
_json = json;
|
|
|
_appHost = appHost;
|
|
|
Session = session;
|
|
|
+ _postUrl = postUrl;
|
|
|
}
|
|
|
|
|
|
public bool SupportsMediaRemoteControl
|
|
@@ -41,6 +50,19 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ private Task SendMessage(object obj, CancellationToken cancellationToken)
|
|
|
+ {
|
|
|
+ var json = _json.SerializeToString(obj);
|
|
|
+
|
|
|
+ return _httpClient.Post(new HttpRequestOptions
|
|
|
+ {
|
|
|
+ Url = _postUrl,
|
|
|
+ CancellationToken = cancellationToken,
|
|
|
+ RequestContent = json,
|
|
|
+ RequestContentType = "application/json"
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
public Task SendSessionEndedNotification(SessionInfoDto sessionInfo, CancellationToken cancellationToken)
|
|
|
{
|
|
|
return Task.FromResult(true);
|
|
@@ -58,7 +80,7 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
|
|
|
public Task SendPlayCommand(PlayRequest command, CancellationToken cancellationToken)
|
|
|
{
|
|
|
- return SendCommand(new WebSocketMessage<PlayRequest>
|
|
|
+ return SendMessage(new WebSocketMessage<PlayRequest>
|
|
|
{
|
|
|
MessageType = "Play",
|
|
|
Data = command
|
|
@@ -68,7 +90,7 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
|
|
|
public Task SendPlaystateCommand(PlaystateRequest command, CancellationToken cancellationToken)
|
|
|
{
|
|
|
- return SendCommand(new WebSocketMessage<PlaystateRequest>
|
|
|
+ return SendMessage(new WebSocketMessage<PlaystateRequest>
|
|
|
{
|
|
|
MessageType = "Playstate",
|
|
|
Data = command
|
|
@@ -78,13 +100,12 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
|
|
|
public Task SendLibraryUpdateInfo(LibraryUpdateInfo info, CancellationToken cancellationToken)
|
|
|
{
|
|
|
- // Roku probably won't care about this
|
|
|
return Task.FromResult(true);
|
|
|
}
|
|
|
|
|
|
public Task SendRestartRequiredNotification(CancellationToken cancellationToken)
|
|
|
{
|
|
|
- return SendCommand(new WebSocketMessage<SystemInfo>
|
|
|
+ return SendMessage(new WebSocketMessage<SystemInfo>
|
|
|
{
|
|
|
MessageType = "RestartRequired",
|
|
|
Data = _appHost.GetSystemInfo()
|
|
@@ -94,13 +115,12 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
|
|
|
public Task SendUserDataChangeInfo(UserDataChangeInfo info, CancellationToken cancellationToken)
|
|
|
{
|
|
|
- // Roku probably won't care about this
|
|
|
return Task.FromResult(true);
|
|
|
}
|
|
|
|
|
|
public Task SendServerShutdownNotification(CancellationToken cancellationToken)
|
|
|
{
|
|
|
- return SendCommand(new WebSocketMessage<string>
|
|
|
+ return SendMessage(new WebSocketMessage<string>
|
|
|
{
|
|
|
MessageType = "ServerShuttingDown",
|
|
|
Data = string.Empty
|
|
@@ -110,7 +130,7 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
|
|
|
public Task SendServerRestartNotification(CancellationToken cancellationToken)
|
|
|
{
|
|
|
- return SendCommand(new WebSocketMessage<string>
|
|
|
+ return SendMessage(new WebSocketMessage<string>
|
|
|
{
|
|
|
MessageType = "ServerRestarting",
|
|
|
Data = string.Empty
|
|
@@ -118,24 +138,11 @@ namespace MediaBrowser.Server.Implementations.Roku
|
|
|
}, cancellationToken);
|
|
|
}
|
|
|
|
|
|
- private Task SendCommand(object obj, CancellationToken cancellationToken)
|
|
|
- {
|
|
|
- var json = _json.SerializeToString(obj);
|
|
|
-
|
|
|
- return _httpClient.Post(new HttpRequestOptions
|
|
|
- {
|
|
|
- Url = "http://" + Session.RemoteEndPoint + "/mb/remotecontrol",
|
|
|
- CancellationToken = cancellationToken,
|
|
|
- RequestContent = json,
|
|
|
- RequestContentType = "application/json"
|
|
|
- });
|
|
|
- }
|
|
|
-
|
|
|
public Task SendGeneralCommand(GeneralCommand command, CancellationToken cancellationToken)
|
|
|
{
|
|
|
- return SendCommand(new WebSocketMessage<GeneralCommand>
|
|
|
+ return SendMessage(new WebSocketMessage<GeneralCommand>
|
|
|
{
|
|
|
- MessageType = "Command",
|
|
|
+ MessageType = "GeneralCommand",
|
|
|
Data = command
|
|
|
|
|
|
}, cancellationToken);
|