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
{
///
/// SimCard
///
[Route("Product/SimCard")]
[ApiDescriptionSettings("Product", Name = "SIM卡", Order = 600)]
public class SimCard_Controller : IDynamicApiController
{
private readonly Service.Product _service = new Service.Product();
#region Query
///
/// 通过 CorpID 获取
///
[Route("GetByCorpID@V1.0")]
[HttpGet]
public List GetByCorpID([FromQuery][Required] CorpIDInput input)
{
var list = _service.GetByCatalog(input.CorpID, Product.Catalog_Sim);
var vm_list = list?.Select(x => new SimCardDto(x)).ToList();
return vm_list;
}
///
/// 通过 ID 获取
///
[Route("GetByID@V1.0")]
[HttpGet]
public SimCardDto GetByID([FromQuery][Required] IDUnderCorpInput input)
{
var model = _service.GetByID(input.CorpID, input.ID);
if (model == null)
return null;
if (model.Catalog != Product.Catalog_Sim)
return null;
return new SimCardDto(model);
}
///
/// 通过 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);
list = list?.Where(x => x.Catalog == Product.Catalog_Sim).ToList();
var vm_list = list?.Select(x => new SimCardDto(x)).ToList();
return vm_list;
}
///
/// 通过 BelongType and BelongID获取
///
[Route("GetByBelongTypeAndBelongID@V1.0")]
[HttpGet]
public List GetByBelongTypeAndBelongID([FromQuery][Required] BelongUnderCorpInput input)
{
var list = _service.GetByBelongTypeAndBelongID(input.CorpID, input.BelongType, input.BelongID);
list = list?.Where(x => x.Catalog == Product.Catalog_Sim).ToList();
var vm_list = list?.Select(x => new SimCardDto(x)).ToList();
return vm_list; ;
}
///
/// 通过 BelongType and BelongIds 获取
///
[Route("GetByBelongTypeAndBelongIds@V1.0")]
[HttpGet]
public List GetByBelongTypeAndBelongIds([FromQuery][Required] BelongIdsUnderCorpInput input)
{
var list = _service.GetByBelongTypeAndBelongIds(input.CorpID, input.BelongType, LongListHelper.ToList(input.BelongIds));
list = list?.Where(x => x.Catalog == Product.Catalog_Sim).ToList();
var vm_list = list?.Select(x => new SimCardDto(x)).ToList();
return vm_list; ;
}
#endregion
#region Insert
///
/// 插入一条
///
[Route("Insert@V1.0")]
[HttpPost]
public long Insert(AddSimCardInput input)
{
if (input == null)
return default;
var product = input.ToProduct();
var id = _service.Insert(product);
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.ToProduct()).ToList();
var bol = _service.Inserts(list);
return bol;
}
#endregion
#region Update
///
/// 更新一条
///
[Route("Update@V1.0")]
[HttpPut]
public bool Update(UpdateSimCardInput input)
{
if (input == null)
return false;
var product = _service.GetByID(input.CorpID, input.ID);
if (product == null)
return false;
input.UpdateProduct(product);
var bol = _service.Update(product);
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 productList = _service.GetByIds(corpIds[0], inputList.Select(x => x.ID).ToList());
if (productList == null || productList.Count < 1)
return false;
var rhsList = new List();
productList.ForEach(x =>
{
var input = inputList.Find(t => t.ID == x.ID);
if (input != null)
{
var rhs = new Model.Product(x);
input.UpdateProduct(rhs);
rhsList.Add(rhs);
}
});
if (rhsList.Count < 1)
return false;
var bol = _service.Updates(rhsList);
return bol;
}
#endregion
#region Exist
///
/// 判断TagName是否存在
///
[Route("IsExistTagName@V1.0")]
[HttpGet]
public bool IsExistTagName([FromQuery][Required] TagNameUnderCorpInput input)
{
var bol = _service.IsExistTagName(input.CorpID, input.TagName);
return bol;
}
///
/// 判断TagName是否存在 ExceptID
///
[Route("IsExistTagNameExceptID@V1.0")]
[HttpGet]
public bool IsExistTagNameExceptID([FromQuery][Required] TagNameExceptUnderCorpInput input)
{
var bol = _service.IsExistTagNameExceptID(input.CorpID, input.TagName, input.ExceptID);
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
}
}