using Microsoft.AspNetCore.Mvc; using System.Net; using System.Net.Http.Headers; using Microsoft.Extensions.Hosting.Internal; using Microsoft.AspNetCore.Http.Extensions; using IStation.Untity; using Furion.DynamicApiController; using System.ComponentModel.DataAnnotations; using Mapster; using IStation.Calculation; using IStation.Model; namespace IStation.Application { /// /// MonitorWeekRecord /// [Route("Run/MonitorWeekRecord")] [ApiDescriptionSettings("Run", Name = "监测周记录", Order = 960)] public class MonitorWeekRecord_Controller : IDynamicApiController { //服务 private readonly Service.MonitorWeekRecord _service = new Service.MonitorWeekRecord(); /// /// 通过 MonitorPointID 获取最近一条数据 /// [Route("GetLastRecordByMonitorPointID@V1.0")] [HttpGet] public List GetLastRecordByMonitorPointID([FromQuery][Required] MonitorPointIDUnderCorpInput input) { var list = _service.GetLastRecord(input.CorpID, input.MonitorPointID); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 MonitorPointIds 获取最近一条数据 /// [Route("GetLastRecordByMonitorPointIds@V1.0")] [HttpGet] public List GetLastRecordByMonitorPointIds([FromQuery][Required] MonitorPointIdsUnderCorpInput input) { var ids = LongListHelper.ToList(input.MonitorPointIds); var list = _service.GetLastRecord(input.CorpID, ids); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 SignalID 获取最近一条数据 /// [Route("GetLastRecordBySignalID@V1.0")] [HttpGet] public MonitorWeekRecordDto GetLastRecordBySignalID([FromQuery][Required] SignalIDUnderCorpInput input) { var model = _service.GetLastRecord(input.CorpID, input.MonitorPointID, input.SignalID); return model?.Adapt(); } /// /// 通过 SignalIds 获取最近一条数据 /// [Route("GetLastRecordBySignalIds@V1.0")] [HttpGet] public List GetLastRecordBySignalIds([FromQuery][Required] SignalIdsUnderCorpInput input) { var ids = LongListHelper.ToList(input.SignalIds); var list = _service.GetLastRecord(input.CorpID, input.MonitorPointID, ids); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 MonitorPointID 获取 /// [Route("GetByMonitorPointID@V1.0")] [HttpGet] public List GetByMonitorPointID([FromQuery][Required] MonitorPointIDUnderCorpInput input) { var list = _service.GetByMonitorPointID(input.CorpID, input.MonitorPointID); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 补录一条 /// [Route("InsertSupplement@V1.0")] [HttpPost] public bool InsertSupplement([Required] SupplementMonitorWeekRecordInput input) { var monitor = new Service.MonitorPoint().GetExSignalWithSignalTypeByID(input.CorpID, input.MonitorPointID); if (monitor.CronType != Model.Monitor.eCronType.EachWeek) { return false; } var bol = false; var dataTime = DateTime.Now; switch (monitor.MonitorType) { case Model.eMonitorType.General: { var signal = monitor.SignalList?.FirstOrDefault(); if (signal != null) { var data_status = new List(); var data_value = MonitorHandleHelper.Handle(monitor, signal, lastRecord: null, input.SrcTime, input.SrcValue, data_status); if (!string.IsNullOrEmpty(data_value)) { var record = new Model.MonitorWeekRecordPure(); record.CorpID = input.CorpID; record.MonitorPointID = input.MonitorPointID; record.SignalID = signal.ID; record.RecordType = monitor.MonitorType; record.SrcTime = input.SrcTime; record.SrcValue = input.SrcValue; record.DataTime = dataTime; record.DataValue = data_value; record.DataStatus = data_status; record.StartDay = input.StartDay.Date; record.EndDay = input.EndDay.Date; bol = _service.InsertSupplement(record); } } } break; case Model.eMonitorType.Vibration: { var sub_record_list = AddMonitorSubRecordInput.ToList(input.SrcValue); if (sub_record_list != null && sub_record_list.Count > 0) { var record_list = new List(); foreach (var sub_record in sub_record_list) { var signal = monitor.SignalList?.FirstOrDefault(x => x.ID == sub_record.SignalID); if (signal == null) continue; var data_status = new List(); var data_value = MonitorHandleHelper.Handle(monitor, signal, lastRecord: null, input.SrcTime, sub_record.SrcValue, data_status); if (string.IsNullOrEmpty(data_value)) continue; var record = new Model.MonitorWeekRecordPure(); record.CorpID = input.CorpID; record.MonitorPointID = input.MonitorPointID; record.SignalID = signal.ID; record.RecordType = monitor.MonitorType; record.SrcTime = input.SrcTime; record.SrcValue = sub_record.SrcValue; record.DataTime = dataTime; record.DataValue = data_value; record.DataStatus = data_status; record.StartDay = input.StartDay.Date; record.EndDay = input.EndDay.Date; record_list.Add(record); } if (record_list.Count > 0) { bol = _service.InsertsSupplement(record_list); } } } break; default: break; } return bol; } /// /// 补录多条 /// [Route("InsertsSupplement@V1.0")] [HttpPost] public bool InsertsSupplement([Required] List list) { var corpIds = list.Select(x => x.CorpID).Distinct().ToList(); if (corpIds.Count > 1) { return false; } var dataTime = DateTime.Now; var record_list = new List(); foreach (var item in list) { var monitor = new Service.MonitorPoint().GetExSignalWithSignalTypeByID(item.CorpID, item.MonitorPointID); if (monitor.CronType != Model.Monitor.eCronType.EachWeek) { continue; } switch (monitor.MonitorType) { case Model.eMonitorType.General: { var signal = monitor.SignalList?.FirstOrDefault(); if (signal != null) { var data_status = new List(); var data_value = MonitorHandleHelper.Handle(monitor, signal, lastRecord: null, item.SrcTime, item.SrcValue, data_status); if (!string.IsNullOrEmpty(data_value)) { var record = new Model.MonitorWeekRecordPure(); record.CorpID = item.CorpID; record.MonitorPointID = item.MonitorPointID; record.SignalID = signal.ID; record.RecordType = monitor.MonitorType; record.SrcTime = item.SrcTime; record.SrcValue = item.SrcValue; record.DataTime = dataTime; record.DataValue = data_value; record.DataStatus = data_status; record.StartDay = item.StartDay.Date; record.EndDay = item.EndDay.Date; record_list.Add(record); } } } break; case Model.eMonitorType.Vibration: { var sub_record_list = AddMonitorSubRecordInput.ToList(item.SrcValue); if (sub_record_list != null && sub_record_list.Count > 0) { foreach (var sub_record in sub_record_list) { var signal = monitor.SignalList?.FirstOrDefault(x => x.ID == sub_record.SignalID); if (signal == null) continue; var data_status = new List(); var data_value = MonitorHandleHelper.Handle(monitor, signal, lastRecord: null, item.SrcTime, sub_record.SrcValue, data_status); if (string.IsNullOrEmpty(data_value)) continue; var record = new Model.MonitorWeekRecordPure(); record.CorpID = item.CorpID; record.MonitorPointID = item.MonitorPointID; record.SignalID = signal.ID; record.RecordType = monitor.MonitorType; record.SrcTime = item.SrcTime; record.SrcValue = sub_record.SrcValue; record.DataTime = dataTime; record.DataValue = data_value; record.DataStatus = data_status; record.StartDay = item.StartDay.Date; record.EndDay = item.EndDay.Date; record_list.Add(record); } } } break; default: break; } } if (record_list.Count < 1) { return false; } var bol = _service.InsertsSupplement(record_list); return bol; } } }