using Admin.NET.Plugin.AiDOP.Entity.S8; namespace Admin.NET.Plugin.AiDOP.Service.S8.Rules; /// /// R2 规则 evaluator 抽象。每个 rule_type 对应一个实现,由 S8WatchSchedulerService 按 rule_type 分派。 /// 首版仅 TIMEOUT;OUT_OF_RANGE 走 S8WatchSchedulerService 内既有兼容分支,不接入此抽象。 /// 不做事件触发、不做 SLA 升级、不做严重度阶梯。 /// public interface IS8RuleEvaluator { /// 支持的 rule_type 字符串(TIMEOUT / SHORTAGE / OUT_OF_RANGE)。 string RuleType { get; } /// 评估一条 WatchRule,产出 0..N 条命中。不做去重、不建单。 Task> EvaluateAsync( long tenantId, long factoryId, AdoS8WatchRule rule, IReadOnlyList alertRules, CancellationToken cancellationToken = default); } /// /// 内部命中模型。供 R2 evaluator 与 S8WatchSchedulerService 的 dedup/建单消费。 /// 字段全部 nullable 以兼容 TIMEOUT / SHORTAGE / OUT_OF_RANGE 三类。R2 仅 TIMEOUT 路径写入。 /// public sealed class S8RuleHit { public long SourceRuleId { get; set; } public string SourceRuleCode { get; set; } = string.Empty; public string SourceObjectType { get; set; } = string.Empty; public string SourceObjectId { get; set; } = string.Empty; public string RelatedObjectCode { get; set; } = string.Empty; public string ExceptionTypeCode { get; set; } = string.Empty; public string SceneCode { get; set; } = string.Empty; public string Severity { get; set; } = "FOLLOW"; public string DedupKey { get; set; } = string.Empty; public string SourcePayload { get; set; } = "{}"; public DateTime DetectedAt { get; set; } = DateTime.Now; public string Title { get; set; } = string.Empty; public long DataSourceId { get; set; } public long? OccurrenceDeptId { get; set; } public long? ResponsibleDeptId { get; set; } /// /// 命中归属模块码(S1-S7)。evaluator 可显式提供以覆盖 scene 默认派生; /// 留 null 时建单方按严格 S1-S7 派生:hit.SceneCode(仅 S1-S7)→ exception_type.scene_code。 /// 不接受 legacy 复合 scene(S8-EXCEPTION-CREATION-MODULE-CODE-FIX-1)。 /// public string? ModuleCode { get; set; } }