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