using Newtonsoft.Json; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; namespace SHH.Contracts { // ============================================================================== // 1. 物理与运行配置 DTO (对应 CRUD 操作) // 用于设备新增/全量配置查询,包含基础身份、连接信息、运行参数等全量字段 // ============================================================================== public class CameraConfigDto { // --- 基础身份 (Identity) --- /// /// 设备唯一标识 /// [Required(ErrorMessage = "设备ID不能为空")] [Range(1, long.MaxValue, ErrorMessage = "设备ID必须为正整数")] public long Id { get; set; } /// /// 设备友好名称 /// [MaxLength(64, ErrorMessage = "设备名称长度不能超过64个字符")] public string Name { get; set; } /// /// 摄像头品牌类型 (0:HikVision, 1:Dahua, 2:RTSP...) /// [Range(0, 10, ErrorMessage = "品牌类型值必须在0-10范围内")] public int Brand { get; set; } /// /// 设备安装位置描述 /// [MaxLength(128, ErrorMessage = "安装位置长度不能超过128个字符")] public string Location { get; set; } // --- 主板关联信息 (Metadata) --- /// /// 关联主板IP地址 /// [RegularExpression(@"^((25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(25[0-5]|2[0-4]\d|[01]?\d\d?)?$", ErrorMessage = "请输入合法的IPv4地址")] public string MainboardIp { get; set; } = string.Empty; /// /// 关联主板端口 /// [Range(0, 65535, ErrorMessage = "主板端口号必须在1-65535范围内")] public int MainboardPort { get; set; } = 0; // --- 核心连接 (Connectivity) - 修改此类参数触发冷重启 --- /// /// 摄像头IP地址 /// [Required(ErrorMessage = "IP地址不能为空")] [RegularExpression(@"^((25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(25[0-5]|2[0-4]\d|[01]?\d\d?)$", ErrorMessage = "请输入合法的IPv4地址")] public string IpAddress { get; set; } /// /// 登录用户名 /// [MaxLength(32, ErrorMessage = "用户名长度不能超过32个字符")] public string Username { get; set; } /// /// 登录密码 /// [MaxLength(64, ErrorMessage = "密码长度不能超过64个字符")] public string Password { get; set; } /// /// SDK端口 (如海康默认8000) /// [Range(1, 65535, ErrorMessage = "端口号必须在1-65535范围内")] public ushort Port { get; set; } /// /// 通道号 (通常为1) /// [Range(0, 256, ErrorMessage = "通道号必须在0-256范围内")] public int ChannelIndex { get; set; } /// /// 码流类型 (0:主码流, 1:子码流) /// [Range(0, 1, ErrorMessage = "码流类型只能是0(主码流)或1(子码流)")] public int StreamType { get; set; } // 渲染句柄 (通常下发时为0,由本地窗口绑定时再指定,或者此处仅作占位) public long RenderHandle { get; set; } /// /// RTSP流路径 (备用或非SDK模式使用) /// [MaxLength(256, ErrorMessage = "RTSP地址长度不能超过256个字符")] public string RtspPath { get; set; } // --- 运行时参数 (Runtime Options) - 支持热更新 --- /// /// 是否使用灰度图 (用于AI分析场景加速) /// public bool UseGrayscale { get; set; } = false; /// /// 是否启用图像增强 (去噪/锐化等) /// public bool EnhanceImage { get; set; } = true; // --- 画面变换 (Transform) - 支持热更新 --- /// /// 是否允许图像压缩 (降低带宽占用) /// public bool AllowCompress { get; set; } = true; /// /// 是否允许图像放大 (提升渲染质量) /// public bool AllowExpand { get; set; } = false; /// /// 目标分辨率 (格式如 1920x1080,空则保持原图) /// [RegularExpression(@"^\d+x\d+$", ErrorMessage = "分辨率格式必须为 宽度x高度 (如 1920x1080)")] public string TargetResolution { get; set; } = string.Empty; /// /// 随配置一并下发的自动订阅请求 /// public List AutoSubscriptions { get; set; } = new List(); /// /// 是否立即执行 /// [JsonProperty("ImmediateExecution")] // 确保 JSON 里的这个 key 能精准对应到这个属性 public bool ImmediateExecution { get; set; } } /// /// 订阅项 /// public class CameraConfigSubscribeDto { /// /// 订阅标识 /// public string AppId { get; set; } /// /// 订阅业务类型 SubscriptionType /// public int Type { get; set; } /// /// 要求的帧率:8帧或1帧 /// public int TargetFps { get; set; } /// /// 备注 /// public string Memo { get; set; } /// /// 是否需要高清晰度 /// public bool NeedHighDefinition { get; set; } = false; } }