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
}
}