| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 | 
							- using MediaBrowser.Common.Net;
 
- using MediaBrowser.Controller.Dto;
 
- using MediaBrowser.Controller.Session;
 
- using MediaBrowser.Model.Logging;
 
- using MediaBrowser.Model.Net;
 
- using System;
 
- using System.Linq;
 
- using System.Threading.Tasks;
 
- namespace MediaBrowser.Server.Implementations.Session
 
- {
 
-     /// <summary>
 
-     /// Class SessionWebSocketListener
 
-     /// </summary>
 
-     public class SessionWebSocketListener : IWebSocketListener
 
-     {
 
-         /// <summary>
 
-         /// The _true task result
 
-         /// </summary>
 
-         private readonly Task _trueTaskResult = Task.FromResult(true);
 
-         /// <summary>
 
-         /// The _session manager
 
-         /// </summary>
 
-         private readonly ISessionManager _sessionManager;
 
-         /// <summary>
 
-         /// The _logger
 
-         /// </summary>
 
-         private readonly ILogger _logger;
 
-         /// <summary>
 
-         /// The _dto service
 
-         /// </summary>
 
-         private readonly IDtoService _dtoService;
 
-         /// <summary>
 
-         /// Initializes a new instance of the <see cref="SessionWebSocketListener" /> class.
 
-         /// </summary>
 
-         /// <param name="sessionManager">The session manager.</param>
 
-         /// <param name="logManager">The log manager.</param>
 
-         /// <param name="dtoService">The dto service.</param>
 
-         public SessionWebSocketListener(ISessionManager sessionManager, ILogManager logManager, IDtoService dtoService)
 
-         {
 
-             _sessionManager = sessionManager;
 
-             _logger = logManager.GetLogger(GetType().Name);
 
-             _dtoService = dtoService;
 
-         }
 
-         /// <summary>
 
-         /// Processes the message.
 
-         /// </summary>
 
-         /// <param name="message">The message.</param>
 
-         /// <returns>Task.</returns>
 
-         public Task ProcessMessage(WebSocketMessageInfo message)
 
-         {
 
-             if (string.Equals(message.MessageType, "Identity", StringComparison.OrdinalIgnoreCase))
 
-             {
 
-                 _logger.Debug("Received Identity message");
 
-                 var vals = message.Data.Split('|');
 
-                 var client = vals[0];
 
-                 var deviceId = vals[1];
 
-                 var version = vals[2];
 
-                 var session = _sessionManager.Sessions
 
-                     .FirstOrDefault(i => string.Equals(i.DeviceId, deviceId) &&
 
-                         string.Equals(i.Client, client) &&
 
-                         string.Equals(i.ApplicationVersion, version));
 
-                 if (session != null)
 
-                 {
 
-                     var sockets = session.WebSockets.Where(i => i.State == WebSocketState.Open).ToList();
 
-                     sockets.Add(message.Connection);
 
-                     session.WebSockets = sockets;
 
-                 }
 
-                 else
 
-                 {
 
-                     _logger.Warn("Unable to determine session based on identity message: {0}", message.Data);
 
-                 }
 
-             }
 
-             else if (string.Equals(message.MessageType, "Context", StringComparison.OrdinalIgnoreCase))
 
-             {
 
-                 var session = _sessionManager.Sessions.FirstOrDefault(i => i.WebSockets.Contains(message.Connection));
 
-                 if (session != null)
 
-                 {
 
-                     var vals = message.Data.Split('|');
 
-                     session.NowViewingItemType = vals[0];
 
-                     session.NowViewingItemId = vals[1];
 
-                     session.NowViewingItemName = vals[2];
 
-                     session.NowViewingContext = vals.Length > 3 ? vals[3] : null;
 
-                 }
 
-                 else
 
-                 {
 
-                     _logger.Warn("Unable to determine session based on context message: {0}", message.Data);
 
-                 }
 
-             }
 
-             else if (string.Equals(message.MessageType, "PlaybackStart", StringComparison.OrdinalIgnoreCase))
 
-             {
 
-                 ReportPlaybackStart(message);
 
-             }
 
-             else if (string.Equals(message.MessageType, "PlaybackProgress", StringComparison.OrdinalIgnoreCase))
 
-             {
 
-                 var session = _sessionManager.Sessions.FirstOrDefault(i => i.WebSockets.Contains(message.Connection));
 
-                 if (session != null && session.User != null)
 
-                 {
 
-                     var vals = message.Data.Split('|');
 
-                     var item = _dtoService.GetItemByDtoId(vals[0]);
 
-                     long? positionTicks = null;
 
-                     if (vals.Length > 1)
 
-                     {
 
-                         long pos;
 
-                         if (long.TryParse(vals[1], out pos))
 
-                         {
 
-                             positionTicks = pos;
 
-                         }
 
-                     }
 
-                     var isPaused = vals.Length > 2 && string.Equals(vals[2], "true", StringComparison.OrdinalIgnoreCase);
 
-                     var isMuted = vals.Length > 3 && string.Equals(vals[3], "true", StringComparison.OrdinalIgnoreCase);
 
-                     _sessionManager.OnPlaybackProgress(item, positionTicks, isPaused, isMuted, session.Id);
 
-                 }
 
-             }
 
-             else if (string.Equals(message.MessageType, "PlaybackStopped", StringComparison.OrdinalIgnoreCase))
 
-             {
 
-                 _logger.Debug("Received PlaybackStopped message");
 
-                 
 
-                 var session = _sessionManager.Sessions.FirstOrDefault(i => i.WebSockets.Contains(message.Connection));
 
-                 if (session != null && session.User != null)
 
-                 {
 
-                     var vals = message.Data.Split('|');
 
-                     var item = _dtoService.GetItemByDtoId(vals[0]);
 
-                     long? positionTicks = null;
 
-                     if (vals.Length > 1)
 
-                     {
 
-                         long pos;
 
-                         if (long.TryParse(vals[1], out pos))
 
-                         {
 
-                             positionTicks = pos;
 
-                         }
 
-                     }
 
-                     _sessionManager.OnPlaybackStopped(item, positionTicks, session.Id);
 
-                 }
 
-             }
 
-             return _trueTaskResult;
 
-         }
 
-         /// <summary>
 
-         /// Reports the playback start.
 
-         /// </summary>
 
-         /// <param name="message">The message.</param>
 
-         private void ReportPlaybackStart(WebSocketMessageInfo message)
 
-         {
 
-             _logger.Debug("Received PlaybackStart message");
 
-             
 
-             var session = _sessionManager.Sessions
 
-                 .FirstOrDefault(i => i.WebSockets.Contains(message.Connection));
 
-             if (session != null && session.User != null)
 
-             {
 
-                 var vals = message.Data.Split('|');
 
-                 var item = _dtoService.GetItemByDtoId(vals[0]);
 
-                 var queueableMediaTypes = string.Empty;
 
-                 var canSeek = true;
 
-                 if (vals.Length > 1)
 
-                 {
 
-                     canSeek = string.Equals(vals[1], "true", StringComparison.OrdinalIgnoreCase);
 
-                 }
 
-                 if (vals.Length > 2)
 
-                 {
 
-                     queueableMediaTypes = vals[2];
 
-                 }
 
-   
 
-                 var info = new PlaybackInfo
 
-                 {
 
-                     CanSeek = canSeek,
 
-                     Item = item,
 
-                     SessionId = session.Id,
 
-                     QueueableMediaTypes = queueableMediaTypes.Split(',').ToList()
 
-                 };
 
-                 _sessionManager.OnPlaybackStart(info);
 
-             }
 
-         }
 
-     }
 
- }
 
 
  |