2019-01-06 13:50:43 -07:00
|
|
|
using System;
|
2016-06-07 23:21:13 -07:00
|
|
|
using System.Linq;
|
|
|
|
using System.Threading;
|
2019-01-27 07:40:37 -07:00
|
|
|
using System.Threading.Tasks;
|
2016-06-07 23:21:13 -07:00
|
|
|
using MediaBrowser.Controller.Library;
|
|
|
|
using MediaBrowser.Controller.LiveTv;
|
|
|
|
using MediaBrowser.Controller.Plugins;
|
|
|
|
using MediaBrowser.Controller.Session;
|
2018-12-13 06:18:25 -07:00
|
|
|
using Microsoft.Extensions.Logging;
|
2016-06-07 23:21:13 -07:00
|
|
|
|
2016-11-03 15:06:00 -07:00
|
|
|
namespace Emby.Server.Implementations.EntryPoints
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
|
|
|
public class RecordingNotifier : IServerEntryPoint
|
|
|
|
{
|
|
|
|
private readonly ILiveTvManager _liveTvManager;
|
|
|
|
private readonly ISessionManager _sessionManager;
|
|
|
|
private readonly IUserManager _userManager;
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
|
|
|
public RecordingNotifier(ISessionManager sessionManager, IUserManager userManager, ILogger logger, ILiveTvManager liveTvManager)
|
|
|
|
{
|
|
|
|
_sessionManager = sessionManager;
|
|
|
|
_userManager = userManager;
|
|
|
|
_logger = logger;
|
|
|
|
_liveTvManager = liveTvManager;
|
|
|
|
}
|
|
|
|
|
2019-01-27 07:40:37 -07:00
|
|
|
public Task RunAsync()
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
|
|
|
_liveTvManager.TimerCancelled += _liveTvManager_TimerCancelled;
|
|
|
|
_liveTvManager.SeriesTimerCancelled += _liveTvManager_SeriesTimerCancelled;
|
|
|
|
_liveTvManager.TimerCreated += _liveTvManager_TimerCreated;
|
|
|
|
_liveTvManager.SeriesTimerCreated += _liveTvManager_SeriesTimerCreated;
|
2019-01-27 07:40:37 -07:00
|
|
|
|
|
|
|
return Task.CompletedTask;
|
2016-06-07 23:21:13 -07:00
|
|
|
}
|
|
|
|
|
2016-11-03 15:06:00 -07:00
|
|
|
private void _liveTvManager_SeriesTimerCreated(object sender, MediaBrowser.Model.Events.GenericEventArgs<TimerEventInfo> e)
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
2016-06-08 08:22:10 -07:00
|
|
|
SendMessage("SeriesTimerCreated", e.Argument);
|
2016-06-07 23:21:13 -07:00
|
|
|
}
|
|
|
|
|
2016-11-03 15:06:00 -07:00
|
|
|
private void _liveTvManager_TimerCreated(object sender, MediaBrowser.Model.Events.GenericEventArgs<TimerEventInfo> e)
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
2016-06-08 08:22:10 -07:00
|
|
|
SendMessage("TimerCreated", e.Argument);
|
2016-06-07 23:21:13 -07:00
|
|
|
}
|
|
|
|
|
2016-11-03 15:06:00 -07:00
|
|
|
private void _liveTvManager_SeriesTimerCancelled(object sender, MediaBrowser.Model.Events.GenericEventArgs<TimerEventInfo> e)
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
2016-06-08 08:22:10 -07:00
|
|
|
SendMessage("SeriesTimerCancelled", e.Argument);
|
2016-06-07 23:21:13 -07:00
|
|
|
}
|
|
|
|
|
2016-11-03 15:06:00 -07:00
|
|
|
private void _liveTvManager_TimerCancelled(object sender, MediaBrowser.Model.Events.GenericEventArgs<TimerEventInfo> e)
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
2016-06-08 08:22:10 -07:00
|
|
|
SendMessage("TimerCancelled", e.Argument);
|
2016-06-07 23:21:13 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
private async void SendMessage(string name, TimerEventInfo info)
|
|
|
|
{
|
2018-09-12 10:26:21 -07:00
|
|
|
var users = _userManager.Users.Where(i => i.Policy.EnableLiveTvAccess).Select(i => i.Id).ToList();
|
2016-06-07 23:21:13 -07:00
|
|
|
|
2016-08-20 11:43:13 -07:00
|
|
|
try
|
2016-06-07 23:21:13 -07:00
|
|
|
{
|
2019-01-13 13:37:13 -07:00
|
|
|
await _sessionManager.SendMessageToUserSessions(users, name, info, CancellationToken.None);
|
2018-09-12 10:26:21 -07:00
|
|
|
}
|
|
|
|
catch (ObjectDisposedException)
|
|
|
|
{
|
2019-01-06 13:50:43 -07:00
|
|
|
// TODO Log exception or Investigate and properly fix.
|
2016-08-20 11:43:13 -07:00
|
|
|
}
|
|
|
|
catch (Exception ex)
|
|
|
|
{
|
2018-12-20 05:11:26 -07:00
|
|
|
_logger.LogError(ex, "Error sending message");
|
2016-06-07 23:21:13 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public void Dispose()
|
|
|
|
{
|
|
|
|
_liveTvManager.TimerCancelled -= _liveTvManager_TimerCancelled;
|
|
|
|
_liveTvManager.SeriesTimerCancelled -= _liveTvManager_SeriesTimerCancelled;
|
|
|
|
_liveTvManager.TimerCreated -= _liveTvManager_TimerCreated;
|
|
|
|
_liveTvManager.SeriesTimerCreated -= _liveTvManager_SeriesTimerCreated;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|