NucuCar/NucuCar.Telemetry
2020-11-24 23:39:37 +02:00
..
Abstractions Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
Publishers TelemetryPublisherFirestore.cs Increase authorization renewal from 5min to 15min before expiry time. 2020-11-24 23:39:37 +02:00
NucuCar.Telemetry.csproj Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
Readme.md Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
Telemetry.cs Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
TelemetryConfig.cs Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
TelemetryPublisherFactory.cs Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
TelemetryPublisherOptions.cs Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
TelemetryPublisherType.cs Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
TelemetryWorker.cs Update Readme & directory structure. 2020-11-23 20:41:55 +02:00

Telemetry

It provides useful classes and abstractions for implementing telemetry in individual components. All telemetry publishers use the MQTT protocol unless specified otherwise.

Azure Telemetry

Publisher

You can use cloud telemetry for free via Azure-IoT-Hub. You still need a backend application that will process the messages.

You will need to create a:

  • IoT Hub
  • IoT Device

Then navigate to your device and grab the primary key, you will need it to create a connection string of the form:

HostName=YOUR_IOT_HUB_NAME.azure-devices.net;DeviceId=YOUR_DEVICE_NAME;SharedAccessKey=PRIMARY_OR_SECONDARY_KEY

The connection string can be passed to the application via appsettings.json or command line arguments or environment variables:

dotnet run --Telemetry:ConnectionString=CONNECTION_STRING
export Telemetry:ConnectionString=CONNECTION_STRING

The Telemetry:Publisher must be set to: Azure

You may also use the format from above to override any settings in appsettings.json.

Reader

A telemetry reader can be found in NucuCar.TestClient. You'll need a connection string that can be found in Azure's IoT Hub Build-In Endpoints setting.


Disk Telemetry

Publisher

Publishes telemetry on the disk.

Example connection string: Filename=telemetry;FileExtension=csv;Separator=,;BufferSize=4096

The Telemetry:Publisher must be set to: Disk

See the source code for comments on the ConnectionString.

Reader

You will need to parse the file by yourself.


Firebase Firestore Database

Publisher

Publishes telemetry on the firestore.

The Telemetry:Publisher must be set to: Firestore

Example connection string: ProjectId=nucuhub;CollectionName=sensors-telemetry-test;Timeout=1000

If you want to use Authentication you can do so by providing the following keys in the connection string: WebApiEmail, WebApiPassword, WebApiKey.

Reader

You will need use a firebase client or rest API.