From 2633facbfec13267389edde5c29d6e66645c2356 Mon Sep 17 00:00:00 2001
From: Darker <mr.darker@163.com>
Date: 星期四, 27 二月 2025 18:29:13 +0800
Subject: [PATCH] 1. 报警管理类添加两个表,并且修改了字段,完善修改后的函数
---
SourceCode/Bond/Servo/AlarmManager.h | 97 +++++++++++++++++++++++++++++++++++-------------
1 files changed, 71 insertions(+), 26 deletions(-)
diff --git a/SourceCode/Bond/Servo/AlarmManager.h b/SourceCode/Bond/Servo/AlarmManager.h
index 71cac72..523ca3f 100644
--- a/SourceCode/Bond/Servo/AlarmManager.h
+++ b/SourceCode/Bond/Servo/AlarmManager.h
@@ -17,6 +17,18 @@
std::string strDescription;
};
+struct AlarmData {
+ int nId; // 错误码
+ int nSeverityLevel; // 报警等级
+ int nDeviceId; // 设备ID
+ int nUnitId; // 单元ID
+ std::string strDeviceName; // 设备名称
+ std::string strUnitName; // 单元名称
+ std::string strDescription; // 描述
+ std::string strStartTime; // 开始时间
+ std::string strEndTime; // 结束时间
+};
+
using AlarmMap = std::unordered_map<int, AlarmInfo>;
class AlarmManager {
@@ -51,77 +63,80 @@
bool destroyAlarmTable();
/**
+ * 插入模拟数据
+ */
+ void insertMockData();
+
+ /**
* 添加报警
- * @param id 报警ID
- * @param deviceName 设备名称
- * @param description 报警描述
- * @param startTime 报警开始时间
- * @param endTime 报警结束时间
+ * @param alarmData 报警数据的结构体
* @return 成功返回true,失败返回false
*/
- bool addAlarm(const std::string& id, const std::string& deviceName, const std::string& description, const std::string& startTime, const std::string& endTime);
+ bool addAlarm(const AlarmData& alarmData);
/**
* 查询所有报警数据
- * @return 包含所有报警数据的二维字符串向量
+ * @return 包含所有报警数据的结构体
*/
- std::vector<std::vector<std::string>> getAllAlarms();
+ std::vector<AlarmData> getAllAlarms();
/**
* 根据报警ID查询报警
* @param id 报警ID
- * @return 包含筛选后报警数据的二维字符串向量
+ * @return 包含筛选后报警数据的结构体
*/
- std::vector<std::vector<std::string>> getAlarmsById(const std::string& id);
+ std::vector<AlarmData> getAlarmsById(const std::string& id);
/**
* 根据描述查询报警
* @param description 报警描述的筛选条件
- * @return 包含筛选后报警数据的二维字符串向量
+ * @return 包含筛选后报警数据的结构体
*/
- std::vector<std::vector<std::string>> getAlarmsByDescription(const std::string& description);
+ std::vector<AlarmData> getAlarmsByDescription(const std::string& description);
/**
* 根据时间范围查询报警
* @param startTime 起始时间
* @param endTime 结束时间
- * @return 包含查询结果的二维字符串向量
+ * @return 包含查询结果的报警数据
*/
- std::vector<std::vector<std::string>> getAlarmsByTimeRange(
- const std::string& startTime, const std::string& endTime);
+ std::vector<AlarmData> getAlarmsByTimeRange(const std::string& startTime, const std::string& endTime);
/**
* 根据ID和时间范围查询报警
* @param id 报警ID
* @param startTime 起始时间
* @param endTime 结束时间
- * @return 包含查询结果的二维字符串向量
+ * @return 包含查询结果的报警数据
*/
- std::vector<std::vector<std::string>> getAlarmsByIdAndTimeRange(
- const std::string& id, const std::string& startTime, const std::string& endTime);
+ std::vector<AlarmData> getAlarmsByIdAndTimeRange(const std::string& id, const std::string& startTime, const std::string& endTime);
/**
* 获取报警数据
* @param startPosition 起始位置
* @param count 获取的记录数量
- * @return 包含报警数据的二维字符串向量
+ * @return 包含查询结果的报警数据
*/
- std::vector<std::vector<std::string>> getAlarms(int startPosition, int count);
+ std::vector<AlarmData> getAlarms(int startPosition, int count);
/**
* 获取筛选后的报警数据
* @param id 报警ID的筛选条件
+ * @param severityLevel 报警等级筛选条件
* @param deviceName 设备名称的筛选条件
+ * @param unitName 单元名称的筛选条件
* @param description 报警描述的筛选条件
* @param startTime 起始时间筛选条件
* @param endTime 结束时间筛选条件
* @param pageNumber 页码
* @param pageSize 每页的记录数
- * @return 包含筛选后报警数据的二维字符串向量
+ * @return 包含查询结果的报警数据
*/
- std::vector<std::vector<std::string>> getFilteredAlarms(
+ std::vector<AlarmData> getFilteredAlarms(
const std::string& id,
+ const std::string& severityLevel,
const std::string& deviceName,
+ const std::string& unitName,
const std::string& description,
const std::string& startTime,
const std::string& endTime,
@@ -131,7 +146,9 @@
/**
* 获取符合条件的报警总数
* @param id 报警ID的筛选条件
- * @param deviceName 设备名称的筛选条件
+ * @param severityLevel 报警等级筛选条件
+ * @param deviceName 设备名称的筛选条件
+ * @param unitName 单元名称的筛选条件
* @param description 报警描述的筛选条件
* @param startTime 起始时间筛选条件
* @param endTime 结束时间筛选条件
@@ -139,7 +156,9 @@
*/
int getTotalAlarmCount(
const std::string& id,
+ const std::string& severityLevel,
const std::string& deviceName,
+ const std::string& unitName,
const std::string& description,
const std::string& startTime,
const std::string& endTime);
@@ -147,19 +166,45 @@
/**
* 更新报警结束时间
* @param id 报警ID
+ * @param severityLevel 报警等级筛选条件
+ * @param deviceId 设备ID
+ * @param unitId 单元ID
* @param description 报警描述
* @param startTime 报警开始时间
* @param newEndTime 新的报警结束时间
* @return 成功返回true,失败返回false
*/
- bool updateAlarmEndTime(const std::string& id, const std::string& deviceName, const std::string& description, const std::string& startTime, const std::string& newEndTime);
+ bool updateAlarmEndTime(
+ const std::string& id,
+ const std::string& severityLevel,
+ const std::string& deviceId,
+ const std::string& unitId,
+ const std::string& description,
+ const std::string& startTime,
+ const std::string& newEndTime);
/**
* 清理旧报警
* @param daysToKeep 保留的天数
- * @param deviceName 设备名称
+ * @param deviceId 设备ID
+ * @param unitId 单元ID
*/
- void cleanOldAlarms(int daysToKeep = 30, const std::string& deviceName = "");
+ void cleanOldAlarms(int daysToKeep = 30, const std::string& deviceId = "", const std::string& unitId = "");
+
+ /**
+ * 通过设备ID获取设备名称
+ * @param deviceId 设备ID
+ * @return 成功返回设备名称,失败返回空
+ */
+ std::string getDeviceNameById(int deviceId);
+
+ /**
+ * 通过设备ID和单元ID获取单元名称
+ * @param deviceId 设备ID
+ * @param unitId 单元ID
+ * @return 成功返回单元名称,失败返回空
+ */
+ std::string getUnitNameById(int deviceId, int unitId);
/**
* 读取报警文件
--
Gitblit v1.9.3