2025-09-03 12:53:32 +08:00
|
|
|
using System.Collections.Concurrent;
|
2025-09-02 20:28:29 +08:00
|
|
|
using DMS.Application.DTOs;
|
2025-09-02 21:06:39 +08:00
|
|
|
using DMS.Application.DTOs.Events;
|
2025-09-05 07:03:47 +08:00
|
|
|
using DMS.Core.Models;
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
namespace DMS.Application.Interfaces;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 定义数据管理相关的应用服务操作,负责管理所有的数据,包括设备、变量表和变量。
|
|
|
|
|
/// </summary>
|
|
|
|
|
public interface IDataCenterService
|
|
|
|
|
{
|
|
|
|
|
#region 设备管理
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步根据ID获取设备DTO。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<DeviceDto> GetDeviceByIdAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步获取所有设备DTO列表。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<DeviceDto>> GetAllDevicesAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步创建一个新设备及其关联的变量表和菜单(事务性操作)。
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="dto">包含设备、变量表和菜单信息的DTO。</param>
|
|
|
|
|
/// <returns>新创建设备的DTO。</returns>
|
|
|
|
|
Task<CreateDeviceWithDetailsDto> CreateDeviceWithDetailsAsync(CreateDeviceWithDetailsDto dto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步更新一个已存在的设备。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<int> UpdateDeviceAsync(DeviceDto deviceDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步删除一个设备。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<bool> DeleteDeviceByIdAsync(int deviceId);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步切换设备的激活状态。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task ToggleDeviceActiveStateAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中添加设备
|
|
|
|
|
/// </summary>
|
|
|
|
|
void AddDeviceToMemory(DeviceDto deviceDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中更新设备
|
|
|
|
|
/// </summary>
|
|
|
|
|
void UpdateDeviceInMemory(DeviceDto deviceDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中删除设备
|
|
|
|
|
/// </summary>
|
|
|
|
|
void RemoveDeviceFromMemory(int deviceId);
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region 变量表管理
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步根据ID获取变量表DTO。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<VariableTableDto> GetVariableTableByIdAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步获取所有变量表DTO列表。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<VariableTableDto>> GetAllVariableTablesAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步创建一个新变量表及其关联菜单(事务性操作)。
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="dto">包含变量表和菜单信息的DTO。</param>
|
|
|
|
|
/// <returns>新创建变量表的DTO。</returns>
|
|
|
|
|
Task<CreateVariableTableWithMenuDto> CreateVariableTableAsync(CreateVariableTableWithMenuDto dto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步更新一个已存在的变量表。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<int> UpdateVariableTableAsync(VariableTableDto variableTableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步删除一个变量表。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<bool> DeleteVariableTableAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中添加变量表
|
|
|
|
|
/// </summary>
|
|
|
|
|
void AddVariableTableToMemory(VariableTableDto variableTableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中更新变量表
|
|
|
|
|
/// </summary>
|
|
|
|
|
void UpdateVariableTableInMemory(VariableTableDto variableTableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中删除变量表
|
|
|
|
|
/// </summary>
|
|
|
|
|
void RemoveVariableTableFromMemory(int variableTableId);
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
2025-09-03 11:12:42 +08:00
|
|
|
#region 菜单管理
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 异步获取所有菜单DTO列表。
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
Task<List<MenuBeanDto>> GetAllMenusAsync();
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 异步根据ID获取菜单DTO。
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
Task<MenuBeanDto> GetMenuByIdAsync(int id);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 异步创建一个新菜单。
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
Task<int> CreateMenuAsync(MenuBeanDto menuDto);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 异步更新一个已存在的菜单。
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
Task UpdateMenuAsync(MenuBeanDto menuDto);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 异步删除一个菜单。
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
Task DeleteMenuAsync(int id);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 在内存中添加菜单
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
void AddMenuToMemory(MenuBeanDto menuDto);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 在内存中更新菜单
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
void UpdateMenuInMemory(MenuBeanDto menuDto);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 在内存中删除菜单
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
void RemoveMenuFromMemory(int menuId);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 获取根菜单列表
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
List<MenuBeanDto> GetRootMenus();
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// 根据父级ID获取子菜单列表
|
2025-09-02 20:28:29 +08:00
|
|
|
/// </summary>
|
2025-09-03 11:12:42 +08:00
|
|
|
/// <param name="parentId">父级菜单ID</param>
|
|
|
|
|
/// <returns>子菜单列表</returns>
|
|
|
|
|
List<MenuBeanDto> GetChildMenus(int parentId);
|
2025-09-02 20:28:29 +08:00
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
2025-09-03 12:53:32 +08:00
|
|
|
#region 变量管理
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步根据ID获取变量DTO。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<VariableDto> GetVariableByIdAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步获取所有变量DTO列表。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<VariableDto>> GetAllVariablesAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步创建一个新变量。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<VariableDto> CreateVariableAsync(VariableDto variableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步更新一个已存在的变量。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<int> UpdateVariableAsync(VariableDto variableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步批量更新变量。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<int> UpdateVariablesAsync(List<VariableDto> variableDtos);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步删除一个变量。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<bool> DeleteVariableAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步批量删除变量。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<bool> DeleteVariablesAsync(List<int> ids);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中添加变量
|
|
|
|
|
/// </summary>
|
|
|
|
|
void AddVariableToMemory(VariableDto variableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中更新变量
|
|
|
|
|
/// </summary>
|
|
|
|
|
void UpdateVariableInMemory(VariableDto variableDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中删除变量
|
|
|
|
|
/// </summary>
|
|
|
|
|
void RemoveVariableFromMemory(int variableId);
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
2025-09-06 13:19:20 +08:00
|
|
|
#region MQTT服务器管理
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步根据ID获取MQTT服务器DTO。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<MqttServerDto> GetMqttServerByIdAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步获取所有MQTT服务器DTO列表。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<MqttServerDto>> GetAllMqttServersAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步创建一个新的MQTT服务器。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<int> CreateMqttServerAsync(MqttServerDto mqttServerDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步更新一个已存在的MQTT服务器。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task UpdateMqttServerAsync(MqttServerDto mqttServerDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步删除一个MQTT服务器。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task DeleteMqttServerAsync(int id);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中添加MQTT服务器
|
|
|
|
|
/// </summary>
|
|
|
|
|
void AddMqttServerToMemory(MqttServerDto mqttServerDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中更新MQTT服务器
|
|
|
|
|
/// </summary>
|
|
|
|
|
void UpdateMqttServerInMemory(MqttServerDto mqttServerDto);
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 在内存中删除MQTT服务器
|
|
|
|
|
/// </summary>
|
|
|
|
|
void RemoveMqttServerFromMemory(int mqttServerId);
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
2025-09-02 20:28:29 +08:00
|
|
|
#region 数据存储访问
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 获取所有设备的安全字典。
|
|
|
|
|
/// </summary>
|
|
|
|
|
ConcurrentDictionary<int, DeviceDto> Devices { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 获取所有变量表的安全字典。
|
|
|
|
|
/// </summary>
|
|
|
|
|
ConcurrentDictionary<int, VariableTableDto> VariableTables { get; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 获取所有变量的安全字典。
|
|
|
|
|
/// </summary>
|
|
|
|
|
ConcurrentDictionary<int, VariableDto> Variables { get; }
|
|
|
|
|
|
2025-09-03 11:12:42 +08:00
|
|
|
/// <summary>
|
|
|
|
|
/// 获取所有菜单的安全字典。
|
|
|
|
|
/// </summary>
|
|
|
|
|
ConcurrentDictionary<int, MenuBeanDto> Menus { get; }
|
2025-09-03 12:53:32 +08:00
|
|
|
/// <summary>
|
|
|
|
|
/// 获取所有菜单树的安全字典。
|
|
|
|
|
/// </summary>
|
|
|
|
|
ConcurrentDictionary<int, MenuBeanDto> MenuTrees { get; }
|
2025-09-03 11:12:42 +08:00
|
|
|
|
2025-09-06 13:19:20 +08:00
|
|
|
/// <summary>
|
|
|
|
|
/// 获取所有MQTT服务器的安全字典。
|
|
|
|
|
/// </summary>
|
|
|
|
|
ConcurrentDictionary<int, MqttServerDto> MqttServers { get; }
|
|
|
|
|
|
2025-09-02 20:28:29 +08:00
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region 数据加载和初始化
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步加载所有设备及其关联数据到内存中。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task LoadAllDataToMemoryAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步加载所有设备及其关联数据。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<DeviceDto>> LoadAllDevicesAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步加载所有变量表及其关联数据。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<VariableTableDto>> LoadAllVariableTablesAsync();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 异步加载所有变量数据。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<VariableDto>> LoadAllVariablesAsync();
|
|
|
|
|
|
2025-09-03 11:12:42 +08:00
|
|
|
/// <summary>
|
|
|
|
|
/// 异步加载所有菜单数据。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<MenuBeanDto>> LoadAllMenusAsync();
|
|
|
|
|
|
2025-09-06 13:19:20 +08:00
|
|
|
/// <summary>
|
|
|
|
|
/// 异步加载所有MQTT服务器数据。
|
|
|
|
|
/// </summary>
|
|
|
|
|
Task<List<MqttServerDto>> LoadAllMqttServersAsync();
|
|
|
|
|
|
2025-09-03 11:12:42 +08:00
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region 事件定义
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 当数据加载完成时触发
|
|
|
|
|
/// </summary>
|
2025-09-06 15:19:04 +08:00
|
|
|
event EventHandler<DataLoadCompletedEventArgs> OnLoadDataCompleted;
|
2025-09-03 11:12:42 +08:00
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 当设备数据发生变化时触发
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<DeviceChangedEventArgs> DeviceChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 当变量表数据发生变化时触发
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<VariableTableChangedEventArgs> VariableTableChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 当变量数据发生变化时触发
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<VariableChangedEventArgs> VariableChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 当菜单数据发生变化时触发
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<MenuChangedEventArgs> MenuChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2025-09-06 13:19:20 +08:00
|
|
|
/// 当MQTT服务器数据发生变化时触发
|
2025-09-03 11:12:42 +08:00
|
|
|
/// </summary>
|
2025-09-06 13:19:20 +08:00
|
|
|
event EventHandler<MqttServerChangedEventArgs> MqttServerChanged;
|
|
|
|
|
|
2025-09-03 11:12:42 +08:00
|
|
|
|
2025-09-05 07:03:47 +08:00
|
|
|
/// <summary>
|
|
|
|
|
/// 当变量值发生变化时触发
|
|
|
|
|
/// </summary>
|
|
|
|
|
event EventHandler<VariableValueChangedEventArgs> VariableValueChanged;
|
|
|
|
|
|
|
|
|
|
void OnVariableValueChanged(VariableValueChangedEventArgs e);
|
|
|
|
|
|
|
|
|
|
|
2025-09-02 20:28:29 +08:00
|
|
|
#endregion
|
|
|
|
|
}
|