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; namespace IStation.Application { /// /// DataDockingProblem /// [Route("Monitor/DataDockingProblem")] [ApiDescriptionSettings("Monitor", Name = "数据对接问题", Order = 700)] public class DataDockingProblem_Controller : IDynamicApiController { private readonly Service.DataDockingProblem _service = new Service.DataDockingProblem(); #region Query /// /// 通过 CorpID 获取 /// [Route("GetByCorpID@V1.0")] [HttpGet] public List GetByCorpID([FromQuery][Required] CorpIDInput input) { var list = _service.GetByCorpID(input.CorpID); var vmList = list?.Select(x => new DataDockingProblemDto(x)).ToList(); return vmList; } /// /// 通过 ID 获取 /// [Route("GetByID@V1.0")] [HttpGet] public DataDockingProblemDto GetByID([FromQuery][Required] IDUnderCorpInput input) { var model = _service.GetByID(input.CorpID, input.ID); if (model == null) return default; var vm=new DataDockingProblemDto(model); return vm; } /// /// 通过 Ids 获取 /// [Route("GetByIds@V1.0")] [HttpGet] public List GetByIds([FromQuery][Required] IdsUnderCorpInput input) { var ids = LongListHelper.ToList(input.Ids); var list = _service.GetByIds(input.CorpID, ids); var vmList = list?.Select(x => new DataDockingProblemDto(x)).ToList(); return vmList; } /// /// 通过 ConfigureID 获取 /// [Route("GetByConfigureID@V1.0")] [HttpGet] public List GetByConfigureID([FromQuery][Required] ConfigureIDUnderCorpInput input) { var list = _service.GetByConfigureID(input.CorpID, input.ConfigureID); var vmList = list?.Select(x => new DataDockingProblemDto(x)).ToList(); return vmList; } #endregion #region Insert /// /// 插入一条 /// [Route("Insert@V1.0")] [HttpPost] public long Insert(AddDataDockingProblemInput input) { if (input == null) return default; var model = input.Adapt(); var id = _service.Insert(model); return id; } /// /// 插入多条 /// [Route("Inserts@V1.0")] [HttpPost] public bool Inserts(List inputList) { if (inputList == null || inputList.Count < 1) return false; var list = inputList.Select(x => x.Adapt()).ToList(); var bol = _service.Inserts(list); return bol; } #endregion #region Update /// /// 更新一条 /// [Route("Update@V1.0")] [HttpPut] public bool Update(UpdateDataDockingProblemInput input) { if (input == null) return false; var model = _service.GetByID(input.CorpID, input.ID); if (model == null) return false; var rhs = new Model.DataDockingProblem(model); input.Adapt(rhs); var bol = _service.Update(rhs); return bol; } /// /// 更新多条 /// [Route("Updates@V1.0")] [HttpPut] public bool Updates(List inputList) { if (inputList == null || inputList.Count() < 1) { return false; } var corpIds = inputList.Select(x => x.CorpID).Distinct().ToList(); if (corpIds.Count > 1) return false; var modelList = _service.GetByIds(corpIds[0], inputList.Select(x => x.ID).ToList()); if (modelList == null || modelList.Count < 1) return false; var rhsList = new List(); modelList.ForEach(x => { var input = inputList.Find(t => t.ID == x.ID); if (input != null) { var rhs = new Model.DataDockingProblem(x); input.Adapt(rhs); rhsList.Add(rhs); } }); if (rhsList.Count < 1) return false; var bol = _service.Updates(rhsList); return bol; } /// /// 更新排序码 /// [Route("UpdateSortCode@V1.0")] [HttpPut] public bool UpdateSortCode([Required] UpdateSortCodeUnderCorpInput input) { var bol = _service.UpdateSortCode(input.CorpID, input.ID, input.SortCode, UserManager.UserID, DateTime.Now); return bol; } /// /// 更新排序 /// [Route("UpdateSorter@V1.0")] [HttpPut] public bool UpdateSorter([Required] UpdateSorterUnderCorpInput input) { if (input.Sorters == null || input.Sorters.Count < 1) return false; var list = input.Sorters.Select(x => x.Adapt()).ToList(); var bol = _service.UpdateSorter(input.CorpID, list); return bol; } /// /// 更新使用状态 /// [Route("UpdateUseStatus@V1.0")] [HttpPut] public bool UpdateUseStatus([Required] UpdateUseStatusUnderCorpInput input) { var bol = _service.UpdateUseStatus(input.CorpID, input.ID, input.UseStatus, UserManager.UserID, DateTime.Now); return bol; } #endregion #region Delete /// /// 删除 /// [Route("DeleteByID@V1.0")] [HttpDelete] public DeleteReasonOutput DeleteByID([FromQuery][Required] IDUnderCorpInput input) { var bol = _service.DeleteByID(input.CorpID, input.ID, out string Msg); return new DeleteReasonOutput() { Success = bol, Reason = Msg }; } #endregion } }