jellyfin-server/MediaBrowser.Server.Implementations/EntryPoints/LoadRegistrations.cs

73 lines
2.1 KiB
C#
Raw Normal View History

using MediaBrowser.Common.Security;
using MediaBrowser.Controller.Plugins;
using MediaBrowser.Model.Logging;
using System;
2014-08-31 19:15:33 +00:00
using System.Threading;
using System.Threading.Tasks;
2016-01-30 02:42:53 +00:00
using MediaBrowser.Common.Threading;
2013-07-04 00:11:11 +00:00
namespace MediaBrowser.Server.Implementations.EntryPoints
{
/// <summary>
/// Class LoadRegistrations
/// </summary>
public class LoadRegistrations : IServerEntryPoint
{
/// <summary>
/// The _security manager
/// </summary>
private readonly ISecurityManager _securityManager;
/// <summary>
/// The _logger
/// </summary>
private readonly ILogger _logger;
2016-01-30 02:42:53 +00:00
private PeriodicTimer _timer;
2014-08-31 19:15:33 +00:00
/// <summary>
/// Initializes a new instance of the <see cref="LoadRegistrations" /> class.
/// </summary>
/// <param name="securityManager">The security manager.</param>
/// <param name="logManager">The log manager.</param>
public LoadRegistrations(ISecurityManager securityManager, ILogManager logManager)
{
_securityManager = securityManager;
_logger = logManager.GetLogger("Registration Loader");
}
/// <summary>
/// Runs this instance.
/// </summary>
2014-08-31 19:15:33 +00:00
public void Run()
{
2016-01-30 02:42:53 +00:00
_timer = new PeriodicTimer(s => LoadAllRegistrations(), null, TimeSpan.FromMilliseconds(100), TimeSpan.FromHours(12));
2014-08-31 19:15:33 +00:00
}
private async Task LoadAllRegistrations()
{
try
{
await _securityManager.LoadAllRegistrationInfo().ConfigureAwait(false);
}
catch (Exception ex)
{
_logger.ErrorException("Error loading registration info", ex);
}
}
/// <summary>
/// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
/// </summary>
public void Dispose()
{
2014-08-31 19:15:33 +00:00
if (_timer != null)
{
_timer.Dispose();
_timer = null;
}
}
}
}