|
@@ -1,130 +0,0 @@
|
|
|
-using MediaBrowser.Common;
|
|
|
-using MediaBrowser.Common.Net;
|
|
|
-using MediaBrowser.Controller.Library;
|
|
|
-using MediaBrowser.Model.Connect;
|
|
|
-using System;
|
|
|
-using System.Collections.Generic;
|
|
|
-using System.Globalization;
|
|
|
-using System.Linq;
|
|
|
-using System.Threading;
|
|
|
-using System.Threading.Tasks;
|
|
|
-using MediaBrowser.Controller;
|
|
|
-using Microsoft.Extensions.Logging;
|
|
|
-
|
|
|
-namespace Emby.Server.Implementations.EntryPoints
|
|
|
-{
|
|
|
- public class UsageReporter
|
|
|
- {
|
|
|
- private readonly IServerApplicationHost _applicationHost;
|
|
|
- private readonly IHttpClient _httpClient;
|
|
|
- private readonly ILogger _logger;
|
|
|
- private const string MbAdminUrl = "https://www.mb3admin.local/admin/";
|
|
|
-
|
|
|
- public UsageReporter(IServerApplicationHost applicationHost, IHttpClient httpClient, ILogger logger)
|
|
|
- {
|
|
|
- _applicationHost = applicationHost;
|
|
|
- _httpClient = httpClient;
|
|
|
- _logger = logger;
|
|
|
- }
|
|
|
-
|
|
|
- public async Task ReportServerUsage(CancellationToken cancellationToken)
|
|
|
- {
|
|
|
- cancellationToken.ThrowIfCancellationRequested();
|
|
|
-
|
|
|
- var data = new Dictionary<string, string>
|
|
|
- {
|
|
|
- { "feature", _applicationHost.Name },
|
|
|
- { "mac", _applicationHost.SystemId },
|
|
|
- { "serverid", _applicationHost.SystemId },
|
|
|
- { "deviceid", _applicationHost.SystemId },
|
|
|
- { "ver", _applicationHost.ApplicationVersion.ToString() },
|
|
|
- { "platform", _applicationHost.OperatingSystemDisplayName }
|
|
|
- };
|
|
|
-
|
|
|
- data["plugins"] = string.Join(",", _applicationHost.Plugins.Select(i => i.Id).ToArray());
|
|
|
-
|
|
|
- var logErrors = false;
|
|
|
-#if DEBUG
|
|
|
- logErrors = true;
|
|
|
-#endif
|
|
|
- var options = new HttpRequestOptions
|
|
|
- {
|
|
|
- Url = MbAdminUrl + "service/registration/ping",
|
|
|
- CancellationToken = cancellationToken,
|
|
|
-
|
|
|
- // Seeing block length errors
|
|
|
- EnableHttpCompression = false,
|
|
|
-
|
|
|
- LogRequest = false,
|
|
|
- LogErrors = logErrors,
|
|
|
- BufferContent = false
|
|
|
- };
|
|
|
-
|
|
|
- options.SetPostData(data);
|
|
|
-
|
|
|
- using (var response = await _httpClient.SendAsync(options, "POST").ConfigureAwait(false))
|
|
|
- {
|
|
|
-
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public async Task ReportAppUsage(ClientInfo app, CancellationToken cancellationToken)
|
|
|
- {
|
|
|
- if (string.IsNullOrEmpty(app.DeviceId))
|
|
|
- {
|
|
|
- throw new ArgumentException("Client info must have a device Id");
|
|
|
- }
|
|
|
-
|
|
|
- _logger.LogInformation("App Activity: app: {0}, version: {1}, deviceId: {2}, deviceName: {3}",
|
|
|
- app.AppName ?? "Unknown App",
|
|
|
- app.AppVersion ?? "Unknown",
|
|
|
- app.DeviceId,
|
|
|
- app.DeviceName ?? "Unknown");
|
|
|
-
|
|
|
- cancellationToken.ThrowIfCancellationRequested();
|
|
|
-
|
|
|
- var data = new Dictionary<string, string>
|
|
|
- {
|
|
|
- { "feature", app.AppName ?? "Unknown App" },
|
|
|
- { "serverid", _applicationHost.SystemId },
|
|
|
- { "deviceid", app.DeviceId },
|
|
|
- { "mac", app.DeviceId },
|
|
|
- { "ver", app.AppVersion ?? "Unknown" },
|
|
|
- { "platform", app.DeviceName },
|
|
|
- };
|
|
|
-
|
|
|
- var logErrors = false;
|
|
|
-
|
|
|
-#if DEBUG
|
|
|
- logErrors = true;
|
|
|
-#endif
|
|
|
- var options = new HttpRequestOptions
|
|
|
- {
|
|
|
- Url = MbAdminUrl + "service/registration/ping",
|
|
|
- CancellationToken = cancellationToken,
|
|
|
-
|
|
|
- // Seeing block length errors
|
|
|
- EnableHttpCompression = false,
|
|
|
-
|
|
|
- LogRequest = false,
|
|
|
- LogErrors = logErrors,
|
|
|
- BufferContent = false
|
|
|
- };
|
|
|
-
|
|
|
- options.SetPostData(data);
|
|
|
-
|
|
|
- using (var response = await _httpClient.SendAsync(options, "POST").ConfigureAwait(false))
|
|
|
- {
|
|
|
-
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public class ClientInfo
|
|
|
- {
|
|
|
- public string AppName { get; set; }
|
|
|
- public string AppVersion { get; set; }
|
|
|
- public string DeviceName { get; set; }
|
|
|
- public string DeviceId { get; set; }
|
|
|
- }
|
|
|
-}
|