jellyfin/Emby.Server.Implementations/EntryPoints/RecordingNotifier.cs

85 lines
3.1 KiB
C#
Raw Normal View History

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