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.MES { public partial class MESController : ControllerBase { /// /// GetTransaction(ApiAction(Data:InstoreDocInput)) /// /// /// [HttpPost] [Route("api/[controller]/InStoreOrderNo/GetTransaction")] public IActionResult InStoreOrderNo_GetTransaction([FromBody] ApiAction action) { ApiAction response; IInStoreOrderNo trans = null; try { if (iBiz.MES.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.MES.Context.GetTransDic()[action.ID] as IInStoreOrderNo; } else { trans = AutoFacContainer.Instance.Resolve().Init(action.ID, Request.Host.Value, action.Data); iBiz.MES.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]/InStoreOrderNo/CloseTransaction")] public IActionResult InStoreOrderNo_CloseTransaction([FromBody] ApiAction action) { ApiAction response; IInStoreOrderNo trans = null; try { if (iBiz.MES.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.MES.Context.GetTransDic()[action.ID] as IInStoreOrderNo; 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]/InStoreOrderNo/Submit")] public async Task InStoreOrderNo_SubmitAsync([FromBody] ApiAction action) { ApiAction response; IInStoreOrderNo trans = null; try { if (iBiz.MES.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.MES.Context.GetTransDic()[action.ID] as IInStoreOrderNo; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.Submit(action.Data?.ToString())); } else { lock (trans.TransLock) { response = action.GetResponse(trans.Submit(action.Data?.ToString()).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]/InStoreOrderNo/GenerateInStoreOrder")] public async Task InStoreOrderNo_GenerateInStoreOrderAsync([FromBody] ApiAction action) { ApiAction response; IInStoreOrderNo trans = null; try { if (iBiz.MES.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.MES.Context.GetTransDic()[action.ID] as IInStoreOrderNo; 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]/InStoreOrderNo/GetScannedList")] public async Task InStoreOrderNo_GetScannedListAsync([FromBody] ApiAction action) { ApiAction response; IInStoreOrderNo trans = null; try { if (iBiz.MES.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.MES.Context.GetTransDic()[action.ID] as IInStoreOrderNo; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.GetScannedList()); } else { lock (trans.TransLock) { response = action.GetResponse(trans.GetScannedList().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); } } }