diff options
| author | 7illusions <z@7illusions.com> | 2014-08-30 19:06:58 +0200 |
|---|---|---|
| committer | 7illusions <z@7illusions.com> | 2014-08-30 19:06:58 +0200 |
| commit | 66ad1699e22029b605e17735e8d9450285d8748a (patch) | |
| tree | ffc92c88d24850b2f82b6b3a8bdd904a2ccc77a5 /MediaBrowser.Api/System/ActivityLogWebSocketListener.cs | |
| parent | 34bc54263e886aae777a3537dc50a6535b51330a (diff) | |
| parent | 9d36f518182bc075c19d78084870f5115fa62d1e (diff) | |
Merge pull request #1 from MediaBrowser/master
Update to latest
Diffstat (limited to 'MediaBrowser.Api/System/ActivityLogWebSocketListener.cs')
| -rw-r--r-- | MediaBrowser.Api/System/ActivityLogWebSocketListener.cs | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/MediaBrowser.Api/System/ActivityLogWebSocketListener.cs b/MediaBrowser.Api/System/ActivityLogWebSocketListener.cs new file mode 100644 index 000000000..4629b2a8c --- /dev/null +++ b/MediaBrowser.Api/System/ActivityLogWebSocketListener.cs @@ -0,0 +1,67 @@ +using MediaBrowser.Common.Net; +using MediaBrowser.Controller.Activity; +using MediaBrowser.Model.Activity; +using MediaBrowser.Model.Events; +using MediaBrowser.Model.Logging; +using System.Collections.Generic; +using System.Threading.Tasks; + +namespace MediaBrowser.Api.System +{ + /// <summary> + /// Class SessionInfoWebSocketListener + /// </summary> + class ActivityLogWebSocketListener : BasePeriodicWebSocketListener<List<ActivityLogEntry>, WebSocketListenerState> + { + /// <summary> + /// Gets the name. + /// </summary> + /// <value>The name.</value> + protected override string Name + { + get { return "ActivityLogEntry"; } + } + + /// <summary> + /// The _kernel + /// </summary> + private readonly IActivityManager _activityManager; + + public ActivityLogWebSocketListener(ILogger logger, IActivityManager activityManager) + : base(logger) + { + _activityManager = activityManager; + _activityManager.EntryCreated += _activityManager_EntryCreated; + } + + void _activityManager_EntryCreated(object sender, GenericEventArgs<ActivityLogEntry> e) + { + SendData(true); + } + + /// <summary> + /// Gets the data to send. + /// </summary> + /// <param name="state">The state.</param> + /// <returns>Task{SystemInfo}.</returns> + protected override Task<List<ActivityLogEntry>> GetDataToSend(WebSocketListenerState state) + { + return Task.FromResult(new List<ActivityLogEntry>()); + } + + protected override bool SendOnTimer + { + get + { + return false; + } + } + + protected override void Dispose(bool dispose) + { + _activityManager.EntryCreated -= _activityManager_EntryCreated; + + base.Dispose(dispose); + } + } +} |
