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
|
|
|
|
2019-01-06 20:50:43 +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;
|
2018-12-13 13:18:25 +00:00
|
|
|
using Microsoft.Extensions.Logging;
|
2016-06-08 06:21:13 +00:00
|
|
|
|
2016-11-03 22:06:00 +00:00
|
|
|
namespace Emby.Server.Implementations.EntryPoints
|
2016-06-08 06:21:13 +00:00
|
|
|
{
|
2020-02-06 14:20:23 +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;
|
|
|
|
|
2020-03-03 22:07:10 +00:00
|
|
|
public RecordingNotifier(
|
|
|
|
ISessionManager sessionManager,
|
|
|
|
IUserManager userManager,
|
|
|
|
ILogger<RecordingNotifier> logger,
|
|
|
|
ILiveTvManager liveTvManager)
|
2016-06-08 06:21:13 +00:00
|
|
|
{
|
|
|
|
_sessionManager = sessionManager;
|
|
|
|
_userManager = userManager;
|
|
|
|
_logger = logger;
|
|
|
|
_liveTvManager = liveTvManager;
|
|
|
|
}
|
|
|
|
|
2020-02-19 20:04:28 +00:00
|
|
|
/// <inheritdoc />
|
2019-01-27 14:40:37 +00:00
|
|
|
public Task RunAsync()
|
2016-06-08 06:21:13 +00:00
|
|
|
{
|
2020-02-19 20:04:28 +00:00
|
|
|
_liveTvManager.TimerCancelled += OnLiveTvManagerTimerCancelled;
|
|
|
|
_liveTvManager.SeriesTimerCancelled += OnLiveTvManagerSeriesTimerCancelled;
|
2020-02-06 14:20:23 +00:00
|
|
|
_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
|
|
|
}
|
|
|
|
|
2020-02-06 14:20:23 +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
|
|
|
}
|
|
|
|
|
2020-02-06 14:20:23 +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
|
|
|
}
|
|
|
|
|
2020-02-19 20:04:28 +00:00
|
|
|
private void OnLiveTvManagerSeriesTimerCancelled(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
|
|
|
}
|
|
|
|
|
2020-02-19 20:04:28 +00:00
|
|
|
private void OnLiveTvManagerTimerCancelled(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
|
|
|
{
|
2020-02-06 14:20:23 +00:00
|
|
|
await _sessionManager.SendMessageToUserSessions(users, name, info, CancellationToken.None).ConfigureAwait(false);
|
2018-09-12 17:26:21 +00:00
|
|
|
}
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-06 14:20:23 +00:00
|
|
|
/// <inheritdoc />
|
2016-06-08 06:21:13 +00:00
|
|
|
public void Dispose()
|
|
|
|
{
|
2020-02-19 20:04:28 +00:00
|
|
|
_liveTvManager.TimerCancelled -= OnLiveTvManagerTimerCancelled;
|
|
|
|
_liveTvManager.SeriesTimerCancelled -= OnLiveTvManagerSeriesTimerCancelled;
|
2020-02-06 14:20:23 +00:00
|
|
|
_liveTvManager.TimerCreated -= OnLiveTvManagerTimerCreated;
|
|
|
|
_liveTvManager.SeriesTimerCreated -= OnLiveTvManagerSeriesTimerCreated;
|
2016-06-08 06:21:13 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|