aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs
diff options
context:
space:
mode:
author7illusions <z@7illusions.com>2014-05-12 16:55:07 +0200
committer7illusions <z@7illusions.com>2014-05-12 16:55:07 +0200
commitbaf5cf2544fcaad2246923f60caaf3fed4a94aaf (patch)
treea808b700095f876e437b95c432c0220e241f9fda /MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs
parent8f3a6279e173dcbaaa05a56556afb410ee12dd4d (diff)
parentb9b568de13d81f9db1a8502d50940475c1d79c72 (diff)
Merge pull request #3 from MediaBrowser/master
Sync with Master
Diffstat (limited to 'MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs')
-rw-r--r--MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs57
1 files changed, 57 insertions, 0 deletions
diff --git a/MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs b/MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs
new file mode 100644
index 000000000..9881bdf18
--- /dev/null
+++ b/MediaBrowser.ServerApplication/EntryPoints/KeepServerAwake.cs
@@ -0,0 +1,57 @@
+using MediaBrowser.Controller.Plugins;
+using MediaBrowser.Controller.Session;
+using MediaBrowser.Model.Logging;
+using MediaBrowser.ServerApplication.Native;
+using System;
+using System.Linq;
+using System.Threading;
+
+namespace MediaBrowser.ServerApplication.EntryPoints
+{
+ public class KeepServerAwake : IServerEntryPoint
+ {
+ private readonly ISessionManager _sessionManager;
+ private readonly ILogger _logger;
+ private Timer _timer;
+
+ public KeepServerAwake(ISessionManager sessionManager, ILogger logger)
+ {
+ _sessionManager = sessionManager;
+ _logger = logger;
+ }
+
+ public void Run()
+ {
+ _timer = new Timer(obj =>
+ {
+ var now = DateTime.UtcNow;
+ if (_sessionManager.Sessions.Any(i => (now - i.LastActivityDate).TotalMinutes < 5))
+ {
+ KeepAlive();
+ }
+
+ }, null, TimeSpan.FromMinutes(5), TimeSpan.FromMinutes(5));
+ }
+
+ private void KeepAlive()
+ {
+ try
+ {
+ NativeApp.PreventSystemStandby();
+ }
+ catch (Exception ex)
+ {
+ _logger.ErrorException("Error resetting system standby timer", ex);
+ }
+ }
+
+ public void Dispose()
+ {
+ if (_timer != null)
+ {
+ _timer.Dispose();
+ _timer = null;
+ }
+ }
+ }
+}