NucuCar/NucuCar.Sensors/EnvironmentSensor/Bme680Worker.cs

63 lines
2.3 KiB
C#
Raw Normal View History

2019-11-09 13:34:49 +00:00
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.Configuration;
2019-11-09 13:34:49 +00:00
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using NucuCar.Domain.Telemetry;
2019-11-14 14:45:32 +00:00
using NucuCar.Sensors.Telemetry;
using NucuCarSensorsProto;
2019-11-09 13:34:49 +00:00
namespace NucuCar.Sensors.EnvironmentSensor
2019-11-09 13:34:49 +00:00
{
2019-11-24 13:12:12 +00:00
/// <summary>
/// EnvironmentSensor's background service worker.
/// It does periodic reads from the sensors and publishes telemetry data if the option is enabled.
/// </summary>
public class Bme680Worker : BackgroundService
2019-11-09 13:34:49 +00:00
{
2019-11-11 15:58:46 +00:00
private readonly bool _telemetryEnabled;
private readonly int _measurementDelay;
private readonly ILogger<Bme680Worker> _logger;
private readonly TelemetryPublisher _telemetryPublisher;
private readonly Bme680Sensor _bme680Sensor;
2019-11-09 13:34:49 +00:00
2019-11-09 14:54:06 +00:00
public Bme680Worker(ILogger<Bme680Worker> logger, IConfiguration config,
SensorTelemetry sensorTelemetry, Bme680Sensor bme680Sensor)
2019-11-09 13:34:49 +00:00
{
_logger = logger;
_telemetryEnabled = config.GetValue<bool>("EnvironmentSensor:Telemetry");
_measurementDelay = config.GetValue<int>("EnvironmentSensor:MeasurementInterval");
_telemetryPublisher = sensorTelemetry.Publisher;
_bme680Sensor = bme680Sensor;
2019-11-09 13:34:49 +00:00
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
2019-11-14 14:45:32 +00:00
if (_telemetryEnabled)
{
_telemetryPublisher?.RegisterTelemeter(_bme680Sensor);
2019-11-14 14:45:32 +00:00
}
2019-11-09 13:34:49 +00:00
while (!stoppingToken.IsCancellationRequested)
{
/* If sensor is ok attempt to read. */
if (_bme680Sensor.GetState() == SensorStateEnum.Initialized)
2019-11-09 14:54:06 +00:00
{
_logger.LogInformation("Taking measurement!");
await _bme680Sensor.TakeMeasurement();
2019-11-09 14:54:06 +00:00
}
/* Else attempt to re-initialize. */
2019-11-09 14:54:06 +00:00
else
{
await Task.Delay(10000, stoppingToken);
_bme680Sensor.InitializeSensor();
2019-11-09 14:54:06 +00:00
}
2019-11-11 15:58:46 +00:00
await Task.Delay(_measurementDelay, stoppingToken);
2019-11-09 13:34:49 +00:00
}
2019-11-24 13:12:12 +00:00
_telemetryPublisher?.UnRegisterTelemeter(_bme680Sensor);
2019-11-09 13:34:49 +00:00
}
}
}