🎐 Makes Analytics service use system service for metrics

This commit is contained in:
Rune Harlyk
2024-11-12 11:50:28 +01:00
parent 1b7ae688a6
commit 316b1a52cb
3 changed files with 16 additions and 22 deletions
+3 -21
View File
@@ -3,7 +3,7 @@
#include <ArduinoJson.h> #include <ArduinoJson.h>
#include <filesystem.h> #include <filesystem.h>
#include <event_socket.h> #include <event_socket.h>
#include <task_manager.h> #include <system_service.h>
#include <WiFi.h> #include <WiFi.h>
#include <timing.h> #include <timing.h>
@@ -24,26 +24,8 @@ class AnalyticsService {
void updateAnalytics() { void updateAnalytics() {
if (!socket.hasSubscribers(EVENT_ANALYTICS)) return; if (!socket.hasSubscribers(EVENT_ANALYTICS)) return;
doc.clear(); doc.clear();
doc["uptime"] = millis() / 1000; JsonObject root = doc.to<JsonObject>();
doc["free_heap"] = ESP.getFreeHeap(); system_service::metrics(root);
doc["total_heap"] = ESP.getHeapSize();
doc["min_free_heap"] = ESP.getMinFreeHeap();
doc["max_alloc_heap"] = ESP.getMaxAllocHeap();
doc["fs_used"] = ESPFS.usedBytes();
doc["fs_total"] = ESPFS.totalBytes();
doc["core_temp"] = temperatureRead();
doc["cpu0_usage"] = g_taskManager.getCpuUsage(0);
doc["cpu1_usage"] = g_taskManager.getCpuUsage(1);
doc["cpu_usage"] = g_taskManager.getCpuUsage();
JsonArray tasks = doc["tasks"].to<JsonArray>();
for (auto const &task : g_taskManager.getTasks()) {
JsonObject nested = tasks.add<JsonObject>();
nested["name"] = task.name;
nested["stackSize"] = task.stackSize;
nested["priority"] = task.priority;
nested["coreId"] = task.coreId;
}
serializeJson(doc, message); serializeJson(doc, message);
socket.emit(EVENT_ANALYTICS, message); socket.emit(EVENT_ANALYTICS, message);
} }
@@ -119,6 +119,17 @@ void metrics(JsonObject &root) {
root["fs_used"] = ESPFS.usedBytes(); root["fs_used"] = ESPFS.usedBytes();
root["fs_total"] = ESPFS.totalBytes(); root["fs_total"] = ESPFS.totalBytes();
root["core_temp"] = temperatureRead(); root["core_temp"] = temperatureRead();
root["cpu0_usage"] = g_taskManager.getCpuUsage(0);
root["cpu1_usage"] = g_taskManager.getCpuUsage(1);
root["cpu_usage"] = g_taskManager.getCpuUsage();
JsonArray tasks = root["tasks"].to<JsonArray>();
for (auto const &task : g_taskManager.getTasks()) {
JsonObject nested = tasks.add<JsonObject>();
nested["name"] = task.name;
nested["stackSize"] = task.stackSize;
nested["priority"] = task.priority;
nested["coreId"] = task.coreId;
}
} }
const char *resetReason(int reason) { const char *resetReason(int reason) {
+2 -1
View File
@@ -1,10 +1,11 @@
#ifndef SYSTEM_SERVICE_H #ifndef SYSTEM_SERVICE_H
#define SYSTEM_SERVICE_H #define SYSTEM_SERVICE_H
#include <filesystem.h>
#include <ESPmDNS.h> #include <ESPmDNS.h>
#include <PsychicHttp.h> #include <PsychicHttp.h>
#include <WiFi.h> #include <WiFi.h>
#include <task_manager.h>
#include <filesystem.h>
#include <global.h> #include <global.h>
namespace system_service { namespace system_service {