2020-01-24 13:13:09 +00:00
|
|
|
using System;
|
2019-12-18 20:57:33 +00:00
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.IO;
|
|
|
|
using System.Text;
|
|
|
|
using System.Threading;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
using Newtonsoft.Json;
|
2019-12-23 22:23:56 +00:00
|
|
|
using NucuCar.Domain.Utilities;
|
2019-12-18 20:57:33 +00:00
|
|
|
|
|
|
|
namespace NucuCar.Domain.Telemetry
|
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
/// The TelemetryPublisherDisk is used to publish telemetry data to a file residing on the disk.
|
|
|
|
/// </summary>
|
|
|
|
public class TelemetryPublisherDisk : TelemetryPublisher
|
|
|
|
{
|
|
|
|
private readonly FileStream _fileStream;
|
2020-01-24 14:12:58 +00:00
|
|
|
private readonly string _separator;
|
2019-12-18 20:57:33 +00:00
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Constructs an instance of <see cref="TelemetryPublisherDisk"/>.
|
|
|
|
/// <remarks>
|
|
|
|
/// The connection string must contain the following options:
|
|
|
|
/// Filename (required) - The path of the filename in which to log telemetry data.
|
2020-01-24 14:12:58 +00:00
|
|
|
/// FileExtension (optional) - The extension of the filename. Default csv
|
|
|
|
/// Separator (optional) - The separator of the messages. Default ,
|
2019-12-18 20:57:33 +00:00
|
|
|
/// BufferSize (optional) - The buffer size for the async writer. Default: 4096
|
|
|
|
/// </remarks>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="opts"></param>
|
|
|
|
public TelemetryPublisherDisk(TelemetryPublisherBuilderOptions opts) : base(opts)
|
|
|
|
{
|
|
|
|
var connectionStringParams = ConnectionStringParser.Parse(opts.ConnectionString);
|
2020-01-24 13:13:09 +00:00
|
|
|
var fileName = connectionStringParams.GetValueOrDefault("FileName");
|
2020-01-24 14:12:58 +00:00
|
|
|
var fileExtension = connectionStringParams.GetValueOrDefault("FileExtension", "csv");
|
2019-12-18 20:57:33 +00:00
|
|
|
var bufferSize = connectionStringParams.GetValueOrDefault("BufferSize", "4096");
|
2020-01-24 14:12:58 +00:00
|
|
|
_separator = connectionStringParams.GetValueOrDefault("Separator", ",");
|
|
|
|
|
2020-01-24 13:13:09 +00:00
|
|
|
_fileStream = new FileStream(NormalizeFilename(fileName, fileExtension), FileMode.Append, FileAccess.Write,
|
2020-01-24 12:27:36 +00:00
|
|
|
FileShare.Read, int.Parse(bufferSize), true);
|
2019-12-18 20:57:33 +00:00
|
|
|
Logger?.LogDebug("Initialized the TelemetryPublisherDisk!");
|
|
|
|
}
|
|
|
|
|
|
|
|
public override async Task PublishAsync(CancellationToken cancellationToken)
|
|
|
|
{
|
|
|
|
var data = GetTelemetry();
|
|
|
|
var messageString = JsonConvert.SerializeObject(data);
|
|
|
|
Logger?.LogDebug($"Telemetry message: {messageString}");
|
2020-02-01 14:50:40 +00:00
|
|
|
var encodedText = Encoding.UTF8.GetBytes($"{messageString}{_separator}");
|
2019-12-18 20:57:33 +00:00
|
|
|
|
2020-01-24 13:55:40 +00:00
|
|
|
try
|
|
|
|
{
|
|
|
|
await _fileStream.WriteAsync(encodedText, 0,
|
|
|
|
encodedText.Length, cancellationToken);
|
|
|
|
await _fileStream.FlushAsync(cancellationToken);
|
|
|
|
}
|
|
|
|
catch (ObjectDisposedException e)
|
|
|
|
{
|
|
|
|
Logger.LogCritical(e.Message);
|
|
|
|
}
|
|
|
|
|
2019-12-18 20:57:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public override void Dispose()
|
|
|
|
{
|
|
|
|
_fileStream.Close();
|
|
|
|
}
|
2020-01-24 13:13:09 +00:00
|
|
|
|
|
|
|
private static string NormalizeFilename(string filename, string extension)
|
|
|
|
{
|
|
|
|
var date = DateTime.UtcNow;
|
|
|
|
return $"{filename}-{date.Year}-{date.Month}-{date.Day}_{date.ToFileTimeUtc()}.{extension}";
|
|
|
|
}
|
2019-12-18 20:57:33 +00:00
|
|
|
}
|
|
|
|
}
|