NucuCar/NucuCar.Telemetry/Abstractions/ITelemeter.cs

34 lines
1.5 KiB
C#
Raw Normal View History

2019-11-14 14:45:32 +00:00
using System.Collections.Generic;
2020-08-01 15:07:13 +00:00
namespace NucuCar.Telemetry.Abstractions
2019-11-14 14:45:32 +00:00
{
2019-11-24 13:12:12 +00:00
/// <summary>
/// Interface that specifies that the component implementing it is willing to provide telemetry data and can be
/// registered to a publisher such as <see cref="TelemetryPublisher"/>.
2019-11-24 13:12:12 +00:00
/// </summary>
public interface ITelemeter
2019-11-14 14:45:32 +00:00
{
2019-11-24 13:12:12 +00:00
/// <summary>
/// This function should return an identifier that identifies the component providing the telemetry data.
/// </summary>
/// <returns>An identifier for the telemetry source.</returns>
string GetIdentifier();
2019-11-24 13:12:12 +00:00
// TODO: Perhaps here it's better if we return a string.
2019-11-24 13:12:12 +00:00
/// <summary>
/// This function should return a dictionary containing the telemetry data.
/// When implementing this function you should return null if the telemetry is disabled.
/// See: <see cref="IsTelemetryEnabled"/>
2019-11-24 13:12:12 +00:00
/// </summary>
/// <returns>The telemetry data. It should be JSON serializable.</returns>
Dictionary<string, object> GetTelemetryData();
/// <summary>
/// This function should return whether the sensor has telemetry enabled or not.
/// A value of true indicates that the sensor has enabled telemetry, and a value of false indicates
/// that telemetry is not enabled.
/// </summary>
/// <returns>A boolean indicating if the sensor has enabled telemetry.</returns>
bool IsTelemetryEnabled();
2019-11-14 14:45:32 +00:00
}
}