123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- 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 MediaBrowser.Model.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.Info("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; }
- }
- }
|