aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs
diff options
context:
space:
mode:
authorRoy Ben Shabat <roy.mail.net@gmail.com>2025-08-30 22:05:03 +0300
committerRoy Ben Shabat <roy.mail.net@gmail.com>2025-08-30 22:05:03 +0300
commita1d55aa060450b0a16b597794686b2aa41eea259 (patch)
tree62dfd7829b81335103a3c2d1d17c99d8408a5e54 /Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs
parentd9d5b0161efbce3f0d44e890b435883f49df2963 (diff)
downloadTango-a1d55aa060450b0a16b597794686b2aa41eea259.tar.gz
Tango-a1d55aa060450b0a16b597794686b2aa41eea259.zip
PPC Telemetry First Integration.
Diffstat (limited to 'Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs')
-rw-r--r--Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs61
1 files changed, 61 insertions, 0 deletions
diff --git a/Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs b/Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs
new file mode 100644
index 000000000..7acf7e197
--- /dev/null
+++ b/Software/Visual_Studio/PPC/Tango.PPC.Common/Telemetry/TelemetrySettings.cs
@@ -0,0 +1,61 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.Logging;
+using Tango.Settings;
+
+namespace Tango.PPC.Common.Telemetry
+{
+ public class TelemetrySettings : SettingsBase
+ {
+ public bool Enable { get; set; } = true;
+
+ public bool EnableIoTHub { get; set; } = true;
+ public bool EnableMqtt { get; set; } = false;
+
+ public String IoTHubConnectionString { get; set; } = "HostName=iot-twine-dev-weu.azure-devices.net;DeviceId=telemetry-dev-01;SharedAccessKey=cZhCMhiVL+TF7p13fpX+lFmyxoy8ZqCkbxUwumWw18Q=";
+
+ /// <summary>
+ /// Interval for checking and reprocessing failed/pending telemetry from local storage.
+ /// </summary>
+ public TimeSpan PendingStorageCheckInterval { get; set; } = TimeSpan.FromMinutes(1);
+
+ /// <summary>
+ /// Frequency at which historical sources are polled to request backlogged or missed telemetry.
+ /// </summary>
+ public TimeSpan HistorySourcesRequestInterval { get; set; } = TimeSpan.FromMinutes(1);
+
+ /// <summary>
+ /// Whether exponential backoff should be applied to retry logic per destination.
+ /// </summary>
+ public bool EnableBackoff { get; set; } = false;
+
+ /// <summary>
+ /// The maximum amount of time to delay retries during exponential backoff.
+ /// </summary>
+ public TimeSpan MaxExponentialBackoff { get; set; } = TimeSpan.FromHours(1);
+
+ /// <summary>
+ /// Gets or sets the interval at which the published telemetry cache cleanup process should occur.
+ /// This defines how frequently old published telemetry entries are eligible for pruning,
+ /// based on their publication timestamp.
+ /// </summary>
+ public TimeSpan PublishedTelemetriesCacheCleanupInterval { get; set; } = TimeSpan.FromHours(1);
+
+ public bool SendDiagnostics { get; set; } = true;
+ public TimeSpan DiagnosticsSamplingInterval { get; set; } = TimeSpan.FromSeconds(60);
+ public bool SendEvents { get; set; } = true;
+ public bool SendJobRuns { get; set; } = true;
+ public bool SendJobRunsHistory { get; set; } = true;
+ public bool SendJobStatus { get; set; } = true;
+ public bool SendLogs { get; set; } = true;
+ public bool SendMachineStatus { get; set; } = true;
+ public bool SendMachineUpdates { get; set; } = true;
+ public bool SendMachineUpdatesHistory { get; set; } = true;
+ public bool SendWires { get; set; } = true;
+
+ public HashSet<LogCategory> LogCategories { get; set; } = new HashSet<LogCategory>() { LogCategory.Critical, LogCategory.Error, LogCategory.Warning };
+ }
+}