using HH.WCS.JiaTong.api;
using HH.WCS.JiaTong.core;
using HH.WCS.JiaTong.dispatch;
using HH.WCS.JiaTong.LISTA.process;
using HH.WCS.JiaTong.util;
using HH.WCS.JiaTong.wms;
using Newtonsoft.Json;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Diagnostics.Eventing.Reader;
using System.IdentityModel.Protocols.WSTrust;
using System.Linq;
using System.Security.Cryptography;
using static HH.WCS.JiaTong.LISTA.process.HttpModel;
namespace HH.WCS.JiaTong.process
{
internal class TaskProcess
{
#region 任务相关
//--------------------------------------------------任务相关--------------------------------------------------
///
/// 取货卸货完成,缓存位状态更新
///
///
///
internal static void CacheBitUpdate(WCSTask mst, bool load)
{
var trayCarryCount = mst.N_CNTR_COUNT > 0 ? mst.N_CNTR_COUNT : 1;
if (load)
{
Console.WriteLine($"任务{mst.S_CODE} 货位{mst.S_START_LOC}取货完成,起点解绑容器{mst.S_CNTR_CODE}");
LogHelper.Info($"任务{mst.S_CODE} 货位{mst.S_START_LOC}取货完成,起点解绑容器{mst.S_CNTR_CODE}");
LocationHelper.UnBindingLoc(mst.S_START_LOC, mst.S_CNTR_CODE.Split(',').ToList());
}
else
{
Console.WriteLine($"任务{mst.S_CODE} 货位{mst.S_END_LOC}卸货完成,终点绑定容器{mst.S_CNTR_CODE}");
LogHelper.Info($"任务{mst.S_CODE} 货位{mst.S_END_LOC}卸货完成,起点解绑容器{mst.S_CNTR_CODE}");
LocationHelper.BindingLoc(mst.S_END_LOC, mst.S_CNTR_CODE.Split(',').ToList());
}
}
///
/// 任务取消,缓存位状态更新
///
///
internal static void CacheBitCancelUpdate(WCSTask mst)
{
//任务取消,取货完成前的,起点的loadingCount和终点unLoadingCount都清除,取货完成的只处理终点
if (WCSHelper.CheckActionRecordExist(mst.S_CODE, 4))
{
//根据客户现场要求,如果取货完成任务失败人工拉到终点,我们就当卸货完成处理;如果是人工拉走到其它区域,我们就解锁终点,删除托盘。
//终点绑定
CacheBitUpdate(mst, false);
LocationHelper.UnLockLoc(mst.S_END_LOC);
}
else
{
//起点终点解锁
LocationHelper.UnLockLoc(mst.S_START_LOC);
LocationHelper.UnLockLoc(mst.S_END_LOC);
}
}
///
/// 安全请求
///
///
///
///
///
internal static void OperateReq(string no, int state, string url, string forkliftNo, string extData, int Z_type)
{
try
{
LogHelper.Info($"-------开始安全请求------");
var TN_Task = WCSHelper.GetTask(no);
if (TN_Task != null)
{
int type = 0;
string loc = "";
if (state == 1101)
{
//请求取货,
type = 1;
loc = TN_Task.S_START_LOC;
if (Z_type == 4)
{
if (GZOperateReqByPost(url, TN_Task.S_EQ_NO, loc, type))
{
// NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18);
// NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
}
else
{
if (OperateReqByPost(url, TN_Task.S_EQ_NO, TN_Task.S_CODE, loc, type, state))
{
// NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18);
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
}
}
if (state == 1102)
{
type = 3;
if (Z_type == 4)
{
loc = TN_Task.S_START_LOC;
if (GZOperateReqByPost(url, TN_Task.S_EQ_NO, loc, type))
{
//NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18);
}
}
}
if (state == 1103)
{
//请求卸货
type = 2;
loc = TN_Task.S_END_LOC;
if (Z_type == 4)
{
loc = TN_Task.S_END_LOC;
if (GZOperateReqByPost(url, TN_Task.S_EQ_NO, loc, type))
{
// NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1103, 18);
// NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
}
else
{
if (OperateReqByPost(url, TN_Task.S_EQ_NO, TN_Task.S_CODE, loc, type, state))
{
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
}
}
if (state == 1104)
{
type = 4;
if (Z_type == 4)
{
loc = TN_Task.S_END_LOC;
if (GZOperateReqByPost(url, TN_Task.S_EQ_NO, loc, type))
{
// NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18);
}
}
}
}
else
{
LogHelper.Info($"安全请求==》根据任务号{no}未找到对应任务");
}
}
catch (Exception ex)
{
LogHelper.Info($"OperateReq Error ==》{ex.ToString()}");
}
}
///
/// 安全请求
///
///
///
///
///
///
///
///
internal static bool OperateReqByPost(string url, string tasknum, string ordernum, string station, int type, int taskStatus)
{
bool permit = false;
try
{
//RequestList requestList = new RequestList();
TaskAccess taskAccess = new TaskAccess() { taskNum = tasknum, orderNum = ordernum, station = station, type = type, taskStatus = taskStatus };
// requestList.data.Add(taskAccess);
HttpHelper httpHelper = new HttpHelper();
Result result = new Result();
string date = JsonConvert.SerializeObject(taskAccess);
// string url = Settings.tableUrls.Find(a => a.id == 2).url;
LogHelper.Info($"安全请求:地址:{url},内容:{date}");
var r = httpHelper.WebPost(url, date);
result = JsonConvert.DeserializeObject(r);
if (result.code == "0")
{
permit = true;
LogHelper.Info($"安全请求成功");
}
else
{
LogHelper.Info($"安全请求失败=>msg:{result.msg}");
}
return permit;
}
catch (Exception)
{
return permit;
}
}
///
/// 安全请求国资
///
///
///
///
///
///
///
///
internal static bool GZOperateReqByPost(string url, string no, string station, int type)
{
bool permit = false;
try
{
LogHelper.Info($"国资安全请求");
//RequestList requestList = new RequestList();
//返回数据
Resultmobox resultmobox = new Resultmobox() { Name = "LocState", Source = "HostToAgv" };
GzTaskAccess taskAccess = new GzTaskAccess() { task_no = no, loc_code = station, type = type.ToString() };
resultmobox.data = taskAccess;
// requestList.data.Add(taskAccess);
HttpHelper httpHelper = new HttpHelper();
GzResult result = new GzResult();
string date = JsonConvert.SerializeObject(resultmobox);
// string url = Settings.tableUrls.Find(a => a.id == 2).url;
LogHelper.Info($"安全请求:地址:{url},内容:{date}");
var r = httpHelper.WebPostycl(url, date);
result = JsonConvert.DeserializeObject(r);
if (result.err_code == "0")
{
permit = true;
LogHelper.Info($"安全请求成功");
}
else
{
LogHelper.Info($"安全请求失败=>msg:{result.err_msg}");
}
return permit;
}
catch (Exception)
{
return permit;
}
}
///
/// 任务拦截
///
///
///
internal static bool Intercept(WCSTask mst)
{
var result = true;
var db = new SqlHelper