aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy.mail.net@gmail.com>2025-08-21 15:08:34 +0300
committerRoy Ben Shabat <Roy.mail.net@gmail.com>2025-08-21 15:08:34 +0300
commitcc556a1c4a0813a548bf95d693c4e2748f895e13 (patch)
treed1d3e21e2fa8b3de348c1f8cbb55a15ddaa06d77 /Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs
parent9f440be9a409955d06b5fc8738aac806e46ef85b (diff)
downloadTango-cc556a1c4a0813a548bf95d693c4e2748f895e13.tar.gz
Tango-cc556a1c4a0813a548bf95d693c4e2748f895e13.zip
Telemetry Wire + Machine Status Pumps.
Diffstat (limited to 'Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs')
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs67
1 files changed, 67 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs
new file mode 100644
index 000000000..41ac42324
--- /dev/null
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryWireStreamingSource.cs
@@ -0,0 +1,67 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.Integration.Operation;
+using Tango.Telemetry.Telemetries;
+
+namespace Tango.Telemetry.Sources
+{
+ public class TelemetryWireStreamingSource : ITelemetryStreamingSource
+ {
+ private IMachineOperator _machineOperator;
+
+ public bool IsStarted { get; private set; }
+ public string Name { get; } = "Wire Streaming";
+ public bool RequiresTelemetryDuplicationTracking { get; }
+
+ public event EventHandler<TelemetryAvailableEventArgs> TelemetryAvailable;
+
+ public TelemetryWireStreamingSource(IMachineOperator machineOperator)
+ {
+ _machineOperator = machineOperator;
+ }
+
+ public void Start()
+ {
+ if (!IsStarted)
+ {
+ IsStarted = true;
+ _machineOperator.TelemetryWireAvailable += MachineOperator_TelemetryWireAvailable;
+ }
+ }
+
+ public void Stop()
+ {
+ if (IsStarted)
+ {
+ IsStarted = false;
+ _machineOperator.TelemetryWireAvailable -= MachineOperator_TelemetryWireAvailable;
+ }
+ }
+
+ private void MachineOperator_TelemetryWireAvailable(object sender, PMR.Diagnostics.StartTelemetryWireResponse e)
+ {
+ if (IsStarted)
+ {
+ TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs()
+ {
+ DisableDeliveryRetries = true,
+ TelemetryObject = new TelemetryWire()
+ {
+ ID = String.Empty,
+ Time = DateTime.UtcNow,
+ Name = e.Name,
+ Value = e.Value
+ }
+ });
+ }
+ }
+
+ public void Dispose()
+ {
+ Stop();
+ }
+ }
+}