From 8bbeffb422e8535c399f1eb76a55fdee5a1c65b6 Mon Sep 17 00:00:00 2001 From: Roy Ben Shabat Date: Mon, 4 Aug 2025 01:09:55 +0300 Subject: Telemetry JobRuns. --- .../Sources/TelemetryJobRunsStreamingSource.cs | 63 ++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs (limited to 'Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs') diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs new file mode 100644 index 000000000..b3199eb36 --- /dev/null +++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryJobRunsStreamingSource.cs @@ -0,0 +1,63 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using Tango.Core; +using Tango.Integration.Operation; +using Tango.Telemetry.Mappers; + +namespace Tango.Telemetry.Sources +{ + public class TelemetryJobRunsStreamingSource : ExtendedObject, ITelemetryStreamingSource + { + private IMachineOperator _machineOperator; + + public string Name { get; } = "JobRuns Streaming"; + + public bool RequiresTelemetryDuplicationTracking { get; } = true; + public bool IsStarted { get; private set; } + + public event EventHandler TelemetryAvailable; + + public TelemetryJobRunsStreamingSource(IMachineOperator machineOperator) + { + _machineOperator = machineOperator; + } + + private void JobRunsLogger_JobRunAvailable(object sender, Integration.JobRuns.JobRunAvailableEventArgs e) + { + Task.Factory.StartNew(() => + { + if (IsStarted) + { + var tRun = JobRunMapper.MapJobRun(e.JobRun); + TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = tRun }); + } + }); + } + + public void Dispose() + { + Stop(); + } + + public void Start() + { + if (!IsStarted) + { + _machineOperator.JobRunsLogger.JobRunAvailable += JobRunsLogger_JobRunAvailable; + IsStarted = true; + } + } + + public void Stop() + { + if (IsStarted) + { + _machineOperator.JobRunsLogger.JobRunAvailable -= JobRunsLogger_JobRunAvailable; + IsStarted = false; + } + } + } +} -- cgit v1.3.1