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
{
///
/// OtherObjectMapping
///
[Route("Organize/OtherObjectMapping")]
[ApiDescriptionSettings("Organize", Name = "第三方数据映射", Order = 30)]
public class OtherObjectMapping_Controller : IDynamicApiController
{
private readonly Service.OtherObjectMapping _service = new Service.OtherObjectMapping();
#region Query
///
///获取所有
///
[Route("GetAll@V1.0")]
[HttpGet]
public List GetAll()
{
var list = _service.GetAll();
var vm_list = list?.Select(x => x.Adapt()).ToList();
return vm_list;
}
///
/// 通过 ID 获取
///
[Route("GetByID@V1.0")]
[HttpGet]
public OtherObjectMappingDto GetByID([FromQuery][Required] IDInput input)
{
var model = _service.GetByID(input.ID);
return model?.Adapt();
}
///
/// 通过 Ids 获取
///
[Route("GetByIds@V1.0")]
[HttpGet]
public List GetByIds([FromQuery] IdsInput model)
{
var ids = LongListHelper.ToList(model.Ids);
var list = _service.GetByIds(ids);
var vm_list = list?.Select(x => x.Adapt()).ToList();
return vm_list;
}
///
/// 通过 OtherSystemID 获取
///
[Route("GetByOtherSystemID@V1.0")]
[HttpGet]
public List GetByOtherSystemID
(
[Required,Range(1,long.MaxValue,ErrorMessage ="OtherSystemID 必须大于0")]
long OtherSystemID
)
{
var list = _service.GetByOtherSystemID(OtherSystemID);
var vm_list = list?.Select(x => x.Adapt()).ToList();
return vm_list;
}
///
/// 通过 CorpID 获取
///
[Route("GetByCorpID@V1.0")]
[HttpGet]
public List GetByCorpID
(
[Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")]
long CorpID
)
{
var list = _service.GetByCorpID(CorpID);
var vm_list = list?.Select(x => x.Adapt()).ToList();
return vm_list;
}
///
/// 通过 OtherSystemID 获取 CorpID 下数据
///
[Route("GetByOtherSystemIDUnderCorpID@V1.0")]
[HttpGet]
public List GetByOtherSystemIDUnderCorpID
(
[Required,Range(1,long.MaxValue,ErrorMessage ="OtherSystemID 必须大于0")]
long OtherSystemID,
[Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")]
long CorpID
)
{
var list = _service.GetByOtherSystemIDUnderCorpID(OtherSystemID, CorpID);
var vm_list = list?.Select(x => x.Adapt()).ToList();
return vm_list;
}
///
/// 通过 OtherSystemID 和 SysType 获取 CorpID 下数据
///
[Route("GetByOtherSystemIDAndSysTypeUnderCorpID@V1.0")]
[HttpGet]
public List GetByOtherSystemIDAndSysTypeUnderCorpID
(
[Required,Range(1,long.MaxValue,ErrorMessage ="OtherSystemID 必须大于0")]
long OtherSystemID,
[Required,DataValidation(AllowEmptyStrings =false)]
string SysType,
[Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")]
long CorpID
)
{
var list = _service.GetByOtherSystemIDAndSysTypeUnderCorpID(OtherSystemID, SysType, CorpID);
var vm_list = list?.Select(x => x.Adapt()).ToList();
return vm_list;
}
#endregion
#region Insert
///
/// 插入一条
///
[Route("Insert@V1.0")]
[HttpPost]
public long Insert(AddOtherObjectMappingInput 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(UpdateOtherObjectMappingInput input)
{
if (input == null)
return false;
var model = _service.GetByID(input.ID);
if (model == null)
return false;
var rhs = new Model.OtherObjectMapping(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 modelList = _service.GetByIds(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.OtherObjectMapping(x);
input.Adapt(rhs);
rhsList.Add(rhs);
}
});
if (rhsList.Count < 1)
return false;
var bol = _service.Updates(rhsList);
return bol;
}
#endregion
#region Delete
///
/// 通过 ID 删除
///
[Route("DeleteByID@V1.0")]
[HttpDelete]
public DeleteReasonOutput DeleteByID([FromQuery][Required] IDInput input)
{
var bol = _service.DeleteByID(input.ID, out string msg);
return new DeleteReasonOutput() { Success = bol, Reason = msg };
}
#endregion
}
}