aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.Telemetry/Sources
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy.mail.net@gmail.com>2025-08-17 19:50:32 +0300
committerRoy Ben Shabat <Roy.mail.net@gmail.com>2025-08-17 19:50:32 +0300
commit4fcf044cc0a4265f6c9c2aad2a3a7aad92eafefa (patch)
treea3b146dadddc5bd67350ee837af0499c53308478 /Software/Visual_Studio/Tango.Telemetry/Sources
parentd150ca010285dc76add9d9f5606dd6d150a610c5 (diff)
downloadTango-4fcf044cc0a4265f6c9c2aad2a3a7aad92eafefa.tar.gz
Tango-4fcf044cc0a4265f6c9c2aad2a3a7aad92eafefa.zip
Telemetry Logs & Events.
Diffstat (limited to 'Software/Visual_Studio/Tango.Telemetry/Sources')
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsHistorySource.cs79
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsStreamingSource.cs64
-rw-r--r--Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryLogsStreamingSource.cs19
3 files changed, 146 insertions, 16 deletions
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsHistorySource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsHistorySource.cs
new file mode 100644
index 000000000..57abee66b
--- /dev/null
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsHistorySource.cs
@@ -0,0 +1,79 @@
+using System;
+using System.Collections.Generic;
+using System.Data.Entity;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.BL;
+using Tango.Telemetry.Mappers;
+using Tango.Telemetry.Telemetries;
+
+namespace Tango.Telemetry.Sources
+{
+ public class TelemetryEventsHistorySource : ITelemetryHistorySource
+ {
+ private bool _isBusy;
+
+ public TelemetryHistorySourceDirection Direction { get; } = TelemetryHistorySourceDirection.Descending;
+ public string Name { get; } = "Events History";
+ public bool RequiresTelemetryDuplicationTracking { get; } = true;
+
+ public async Task<bool> CanRequestHistory(DateTime from)
+ {
+ if (_isBusy)
+ {
+ return false;
+ }
+ else
+ {
+ try
+ {
+ using (ObservablesContext db = ObservablesContext.CreateDefault())
+ {
+ return await db.MachinesEvents.CountAsync(x => x.LastUpdated < from) > 0;
+ }
+ }
+ catch
+ {
+ return false;
+ }
+ }
+ }
+
+ public async Task<IEnumerable<ITelemetry>> RequestHistory(DateTime from)
+ {
+ try
+ {
+ _isBusy = true;
+
+ using (ObservablesContext db = ObservablesContext.CreateDefault())
+ {
+ var events = await db.MachinesEvents
+ .OrderByDescending(x => x.LastUpdated)
+ .Where(x => x.LastUpdated < from)
+ .Take(10)
+ .ToListAsync();
+
+ List<TelemetryEvent> tRuns = new List<TelemetryEvent>();
+
+ foreach (var ev in events)
+ {
+ var tEvent = EventMapper.MapEvent(ev);
+ tRuns.Add(tEvent);
+ }
+
+ return tRuns;
+ }
+ }
+ finally
+ {
+ _isBusy = false;
+ }
+ }
+
+ public void Dispose()
+ {
+
+ }
+ }
+}
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsStreamingSource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsStreamingSource.cs
new file mode 100644
index 000000000..4b00c49ce
--- /dev/null
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryEventsStreamingSource.cs
@@ -0,0 +1,64 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Tango.BL.Entities;
+using Tango.Integration.Operation;
+using Tango.Telemetry.Mappers;
+using Tango.Telemetry.Telemetries;
+
+namespace Tango.Telemetry.Sources
+{
+ public class TelemetryEventsStreamingSource : ITelemetryStreamingSource
+ {
+ private IMachineOperator _machineOperator;
+
+ public bool IsStarted { get; private set; }
+ public string Name { get; } = "Events Streaming";
+ public bool RequiresTelemetryDuplicationTracking { get; } = true;
+
+ public event EventHandler<TelemetryAvailableEventArgs> TelemetryAvailable;
+
+ public TelemetryEventsStreamingSource(IMachineOperator machineOperator)
+ {
+ _machineOperator = machineOperator;
+ }
+
+ private void MachineEventsStateProvider_NewEvents(object sender, IEnumerable<MachinesEvent> events)
+ {
+ if (IsStarted)
+ {
+ foreach (var ev in events)
+ {
+ TelemetryEvent t = EventMapper.MapEvent(ev);
+
+ TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = t });
+ }
+ }
+ }
+
+ public void Start()
+ {
+ if (!IsStarted)
+ {
+ IsStarted = true;
+ _machineOperator.MachineEventsStateProvider.NewEvents += MachineEventsStateProvider_NewEvents;
+ }
+ }
+
+ public void Stop()
+ {
+ if (IsStarted)
+ {
+ IsStarted = false;
+ _machineOperator.MachineEventsStateProvider.NewEvents -= MachineEventsStateProvider_NewEvents;
+ }
+ }
+
+ public void Dispose()
+ {
+ Stop();
+ }
+ }
+}
diff --git a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryLogsStreamingSource.cs b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryLogsStreamingSource.cs
index 9deb93132..2c8020f7c 100644
--- a/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryLogsStreamingSource.cs
+++ b/Software/Visual_Studio/Tango.Telemetry/Sources/TelemetryLogsStreamingSource.cs
@@ -5,6 +5,7 @@ using System.Text;
using System.Threading.Tasks;
using Tango.Integration.Operation;
using Tango.Logging;
+using Tango.Telemetry.Mappers;
using Tango.Telemetry.Telemetries;
namespace Tango.Telemetry.Sources
@@ -53,14 +54,7 @@ namespace Tango.Telemetry.Sources
_lastFirmwareMessage = new KeyValuePair<DateTime, string>(DateTime.UtcNow, log.Message);
- TelemetryLog tLog = new TelemetryLog();
- tLog.Source = "Firmware";
- tLog.Time = DateTime.UtcNow;
- tLog.Category = log.Category.ToString();
- tLog.Class = log.FileName;
- tLog.Method = $"[{log.ModuleId}] [{log.Filter}] [{log.Parameter}]";
- tLog.Line = log.LineNumber;
- tLog.Message = log.Message;
+ TelemetryLog tLog = LogMapper.MapLog(log);
TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = tLog });
}
}
@@ -71,14 +65,7 @@ namespace Tango.Telemetry.Sources
{
if (!Config.Categories.Contains(log.Category)) return;
- TelemetryLog tLog = new TelemetryLog();
- tLog.Source = "Application";
- tLog.Time = log.TimeStamp.ToUniversalTime();
- tLog.Category = log.Category.ToString();
- tLog.Class = log.ClassName;
- tLog.Method = log.CallerMethodName;
- tLog.Line = log.CallerLineNumber;
- tLog.Message = log.Message;
+ TelemetryLog tLog = LogMapper.MapLog(log);
TelemetryAvailable?.Invoke(this, new TelemetryAvailableEventArgs() { TelemetryObject = tLog });
}
}