Files
DMS/DMS.Infrastructure/Entities/DbTriggerDefinition.cs
David P.G 72d2440314 1 feat: 重构触发器设计,移除触发条件并添加名称字段
2
    3 - 从Trigger、DbTriggerDefinition和TriggerItem类中移除了所有条件相关的属性(Condition, Threshold, LowerBound, UpperBound)
    4 - 删除了ConditionType枚举,简化了触发器逻辑
    5 - 为触发器添加了Name字段,在核心模型、数据库实体和视图模型中都添加了该属性
    6 - 删除了TriggerDialog界面中的变量选择和搜索功能
    7 - 从TriggerDialog界面中删除了触发条件相关的UI元素
    8 - 更新了TriggerDialogViewModel,移除了条件相关的验证和业务逻辑
    9 - 更新了TriggersViewModel,移除了条件的初始化设置
   10 - 更新了AutoMapper配置文件,增加TriggerItem与Trigger之间的映射
   11 - 在TriggerEvaluationService中移除了条件判断逻辑,现在激活的触发器会直接执行动作
   12 - 更新了App.xaml,移除了对已删除枚举的引用
   13 - 修改了保存验证逻辑,确保触发器名称不能为空
2025-10-18 18:55:08 +08:00

81 lines
2.3 KiB
C#

using System;
using System.Collections.Generic;
using DMS.Core.Models.Triggers;
using SqlSugar;
using SqlSugar.DbConvert;
namespace DMS.Infrastructure.Entities;
/// <summary>
/// 触发器定义实体类,对应数据库中的 TriggerDefinitions 表。
/// </summary>
[SugarTable("TriggerDefinitions")]
public class DbTriggerDefinition
{
/// <summary>
/// 触发器唯一标识符,主键。
/// </summary>
[SugarColumn(IsPrimaryKey = true, IsIdentity = true)]
public int Id { get; set; }
/// <summary>
/// 触发器名称
/// </summary>
[SugarColumn(Length = 200, IsNullable = true)]
public string Name { get; set; } = "";
/// <summary>
/// 触发器是否处于激活状态。
/// </summary>
public bool IsActive { get; set; } = true;
// --- 动作部分 ---
/// <summary>
/// 动作类型。
/// </summary>
[SugarColumn(ColumnDataType = "varchar(20)", SqlParameterDbType = typeof(EnumToStringConvert))]
public ActionType Action { get; set; }
/// <summary>
/// 动作配置 JSON 字符串,存储特定于动作类型的配置(如邮件收件人列表、模板 ID 等)。
/// </summary>
[SugarColumn(Length = 2000, IsNullable = true)]
public string ActionConfigurationJson { get; set; } = "{}";
// --- 抑制与状态部分 ---
/// <summary>
/// 抑制持续时间。如果设置了此值,在触发一次后,在该时间段内不会再触发。
/// </summary>
[SugarColumn(IsNullable = true)]
public long? SuppressionDurationTicks { get; set; }
/// <summary>
/// 上次触发的时间。用于抑制逻辑。
/// </summary>
[SugarColumn(IsNullable = true)]
public DateTime? LastTriggeredAt { get; set; }
/// <summary>
/// 触发器描述。
/// </summary>
[SugarColumn(Length = 500, IsNullable = true)]
public string Description { get; set; } = "";
/// <summary>
/// 创建时间。
/// </summary>
public DateTime CreatedAt { get; set; } = DateTime.UtcNow;
/// <summary>
/// 最后更新时间。
/// </summary>
public DateTime UpdatedAt { get; set; } = DateTime.UtcNow;
/// <summary>
/// 关联的变量 ID 列表(通过中间表关联)。
/// </summary>
[SugarColumn(IsIgnore = true)]
public List<int> VariableIds { get; set; } = new List<int>();
}