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

89 lines
3.2 KiB
C#
Raw Normal View History

2019-11-01 17:38:54 +00:00
#pragma warning disable CS1591
2019-12-10 23:13:57 +00:00
#pragma warning disable SA1600
2019-11-01 17:38:54 +00:00
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 sealed class RecordingNotifier : IServerEntryPoint
2016-06-08 06:21:13 +00:00
{
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 += LiveTvManagerTimerCancelled;
_liveTvManager.SeriesTimerCancelled += LiveTvManagerSeriesTimerCancelled;
_liveTvManager.TimerCreated += OnLiveTvManagerTimerCreated;
_liveTvManager.SeriesTimerCreated += OnLiveTvManagerSeriesTimerCreated;
2019-01-27 14:40:37 +00:00
return Task.CompletedTask;
2016-06-08 06:21:13 +00:00
}
private void OnLiveTvManagerSeriesTimerCreated(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 OnLiveTvManagerTimerCreated(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 LiveTvManagerSeriesTimerCancelled(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 LiveTvManagerTimerCancelled(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
{
await _sessionManager.SendMessageToUserSessions(users, name, info, CancellationToken.None).ConfigureAwait(false);
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
}
}
/// <inheritdoc />
2016-06-08 06:21:13 +00:00
public void Dispose()
{
_liveTvManager.TimerCancelled -= LiveTvManagerTimerCancelled;
_liveTvManager.SeriesTimerCancelled -= LiveTvManagerSeriesTimerCancelled;
_liveTvManager.TimerCreated -= OnLiveTvManagerTimerCreated;
_liveTvManager.SeriesTimerCreated -= OnLiveTvManagerSeriesTimerCreated;
2016-06-08 06:21:13 +00:00
}
}
}