using Autofac; using Microsoft.AspNetCore.Mvc; using Rhea.Common; using SqlSugar; using System.Collections.Generic; using System.Threading.Tasks; using System.Xml.Linq; using Tiger.Api.iBiz; using Tiger.IBusiness; using Tiger.Model; using Tiger.Model.Entitys.MES.BizPrintInstoreDoc; using Tiger.Model.Entitys.MES.Position; using Tiger.Model.Entitys.MES.U9C; namespace Tiger.Api.Controllers.WMS { public partial class WMSController : ControllerBase { /// /// GetTransaction(ApiAction(Data:InstoreDocInput)) /// /// /// [HttpPost] [Route("api/[controller]/In_SemiProd/GetTransaction")] public IActionResult In_SemiProd_GetTransaction([FromBody] ApiAction action) { ApiAction response; IIn_SemiProd trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_SemiProd; } else { trans = AutoFacContainer.Instance.Resolve().Init(action.ID, Request.Host.Value, action.Data); iBiz.WMS.Context.NewTransaction(HttpContext, trans); } response = action.GetResponse(trans.GetInStoreInfos()); } catch (System.IO.InvalidDataException ex) { response = action.GetResponse(); response.IsSuccessed = false; response.LocaleMsg = new(ex.Message, ex.InnerException.Message.Split('|', System.StringSplitOptions.RemoveEmptyEntries)); } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } /// /// CloseTransaction(ApiAction) /// 关闭事务 /// /// /// [HttpPost] [Route("api/[controller]/In_SemiProd/CloseTransaction")] public IActionResult In_SemiProd_CloseTransaction([FromBody] ApiAction action) { ApiAction response; IIn_SemiProd trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_SemiProd; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(trans.Close()); } else { lock (trans.TransLock) { response = action.GetResponse(trans.Close()); } } response.Message = $"入库单事务[ID:{action.ID}]关闭{(response.IsSuccessed ? "成功" : "失败")}"; } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经关闭", false); } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经被关闭", false); } } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } /// /// Submit(ApiAction(Data:{SubmitInput})) /// 入库单:提交操作数据 /// /// /// [HttpPost] [Route("api/[controller]/In_SemiProd/Submit")] public async Task In_SemiProd_SubmitAsync([FromBody] ApiAction action) { ApiAction response; IIn_SemiProd trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_SemiProd; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.Submit(action.Data)); } else { lock (trans.TransLock) { response = action.GetResponse(trans.Submit(action.Data).Result); } } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经关闭", false); } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经被关闭", false); } } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } /// /// 调用U9C接口生成入库单 /// /// /// [HttpPost] [Route("api/[controller]/In_SemiProd/GenerateInStoreOrder")] public async Task In_SemiProd_GenerateInStoreOrderAsync([FromBody] ApiAction action) { ApiAction response; IIn_SemiProd trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_SemiProd; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.GenerateInStoreOrder()); } else { lock (trans.TransLock) { response = action.GetResponse(trans.GenerateInStoreOrder().Result); } } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经关闭", false); } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经被关闭", false); } } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } /// /// 清除 /// /// /// [HttpPost] [Route("api/[controller]/In_SemiProd/Clear")] public async Task In_SemiProd_ClearAsync([FromBody] ApiAction action) { ApiAction response; IIn_SemiProd trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_SemiProd; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.Clear()); } else { lock (trans.TransLock) { response = action.GetResponse(trans.Clear().Result); } } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经关闭", false); } } else { response = action.GetResponse($"Transaction Error: 入库单事务[ID:{action.ID}]已经被关闭", false); } } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } } }