2019-11-17 16:27:58 +00:00
|
|
|
using System.Collections.Generic;
|
2019-11-14 14:45:32 +00:00
|
|
|
using System.Threading;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using Microsoft.Extensions.Configuration;
|
|
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
|
|
|
namespace NucuCar.Sensors.Telemetry
|
|
|
|
{
|
|
|
|
public class BackgroundWorker : BackgroundService
|
|
|
|
{
|
2019-11-17 13:29:33 +00:00
|
|
|
private readonly string _azureIotHubConnectionString;
|
2019-11-14 14:45:32 +00:00
|
|
|
private readonly bool _serviceEnabled;
|
|
|
|
private readonly int _interval;
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
|
|
|
public BackgroundWorker(ILogger<BackgroundWorker> logger, IConfiguration configuration)
|
|
|
|
{
|
|
|
|
_logger = logger;
|
2019-11-17 13:29:33 +00:00
|
|
|
_serviceEnabled = configuration.GetValue<bool>("Telemetry:Enabled");
|
|
|
|
_interval = configuration.GetValue<int>("Telemetry:Interval");
|
|
|
|
_azureIotHubConnectionString = configuration.GetValue<string>("Telemetry:AzureIotHubConnectionString");
|
2019-11-14 14:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
|
|
|
|
{
|
|
|
|
if (!_serviceEnabled)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
2019-11-14 17:23:16 +00:00
|
|
|
|
2019-11-14 14:45:32 +00:00
|
|
|
await Task.Delay(_interval, stoppingToken);
|
|
|
|
|
2019-11-17 16:27:58 +00:00
|
|
|
using var telemetryService = TelemetryPublisher.Instance;
|
2019-11-14 17:23:16 +00:00
|
|
|
|
2019-11-23 17:02:53 +00:00
|
|
|
telemetryService.Logger = _logger;
|
2019-11-17 16:27:58 +00:00
|
|
|
telemetryService.Configure(new Dictionary<string, object>()
|
|
|
|
{
|
|
|
|
["AzureIotHubConnectionString"] = _azureIotHubConnectionString
|
|
|
|
});
|
2019-11-14 17:23:16 +00:00
|
|
|
|
2019-11-17 13:29:33 +00:00
|
|
|
telemetryService.Start();
|
2019-11-14 14:45:32 +00:00
|
|
|
while (!stoppingToken.IsCancellationRequested)
|
|
|
|
{
|
|
|
|
_logger.LogInformation("Publishing telemetry data!");
|
2019-11-17 16:27:58 +00:00
|
|
|
await telemetryService.PublishAsync(stoppingToken);
|
2019-11-14 14:45:32 +00:00
|
|
|
await Task.Delay(_interval, stoppingToken);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|