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