From 4ebba2b2e87e33f083c095957a2294b6f8ae3828 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Sat, 15 Feb 2014 17:42:06 -0500 Subject: change usage reporting to a timer --- .../Security/UsageReporter.cs | 40 ++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 MediaBrowser.Common.Implementations/Security/UsageReporter.cs (limited to 'MediaBrowser.Common.Implementations/Security/UsageReporter.cs') diff --git a/MediaBrowser.Common.Implementations/Security/UsageReporter.cs b/MediaBrowser.Common.Implementations/Security/UsageReporter.cs new file mode 100644 index 000000000..e32940be9 --- /dev/null +++ b/MediaBrowser.Common.Implementations/Security/UsageReporter.cs @@ -0,0 +1,40 @@ +using MediaBrowser.Common.Net; +using System; +using System.Collections.Generic; +using System.Threading; +using System.Threading.Tasks; + +namespace MediaBrowser.Common.Implementations.Security +{ + public class UsageReporter + { + private readonly IApplicationHost _applicationHost; + private readonly INetworkManager _networkManager; + private readonly IHttpClient _httpClient; + + public UsageReporter(IApplicationHost applicationHost, INetworkManager networkManager, IHttpClient httpClient) + { + _applicationHost = applicationHost; + _networkManager = networkManager; + _httpClient = httpClient; + } + + public Task ReportUsage(CancellationToken cancellationToken) + { + cancellationToken.ThrowIfCancellationRequested(); + + var mac = _networkManager.GetMacAddress(); + + var data = new Dictionary + { + { "feature", _applicationHost.Name }, + { "mac", mac }, + { "ver", _applicationHost.ApplicationVersion.ToString() }, + { "platform", Environment.OSVersion.VersionString }, + { "isservice", _applicationHost.IsRunningAsService.ToString().ToLower()} + }; + + return _httpClient.Post(Constants.Constants.MbAdminUrl + "service/registration/ping", data, cancellationToken); + } + } +} -- cgit v1.2.3