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