using HH.WCS.JiaTong.api;
using HH.WCS.JiaTong.core;
using HH.WCS.JiaTong.device;
using HH.WCS.JiaTong.dispatch;
using HH.WCS.JiaTong.LISTA.models;
using HH.WCS.JiaTong.LISTA.process;
using HH.WCS.JiaTong.util;
using HH.WCS.JiaTong.wms;
using Microsoft.Owin.BuilderProperties;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
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 System.Threading;
using System.Threading.Tasks;
using static HH.WCS.JiaTong.api.ApiModel;
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}");
if (!string.IsNullOrEmpty(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
{
LogHelper.Info($"任务{mst.S_CODE} 托盘为空 ,只解锁货位");
LocationHelper.UnlockLoc(mst.S_START_LOC);
}
}
else
{
// Console.WriteLine($"任务{mst.S_CODE} 货位{mst.S_END_LOC}卸货完成,终点绑定容器{mst.S_CNTR_CODE}");
if (!string.IsNullOrEmpty(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());
}
else
{
LogHelper.Info($"任务{mst.S_CODE} 托盘为空 ,只解锁货位");
LocationHelper.UnlockLoc(mst.S_END_LOC);
}
}
}
///
/// 任务取消,缓存位状态更新
///
///
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(AgvTaskState model, string url, WCSTask TN_Task)
{
try
{
LogHelper.Info($"-------开始安全请求------");
if (TN_Task != null)
{
int type = 0;
string loc = "";
if (model.state == 1101)
{
//请求取货,
type = 1;
loc = TN_Task.S_START_LOC;
if (TN_Task.S_TYPE.Contains("电梯2"))
{
var device = Settings.deviceInfos.Where(a => a.TN_Location == TN_Task.S_START_LOC).FirstOrDefault();
var EndLoc = LocationHelper.GetLocByLoc(TN_Task.S_END_LOC);
if (device == null)
{
LogHelper.Info($"根据任务起点:{TN_Task.S_START_LOC},未找到对应电梯配置文件");
}
if (EndLoc == null)
{
LogHelper.Info($"根据任务终点:{TN_Task.S_END_LOC},未找到对应货位");
}
var value = ModbusHelper.ReadHoldingRegisters(40005, 1, device.address, 1024);
var value2 = ModbusHelper.ReadHoldingRegisters(40101, 1, device.address, 1024);
if (value[0] == EndLoc.N_LAYER && value2[0] == 2)
{
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
else
{
int layerValue = 0;
if (EndLoc.N_LAYER == 1) layerValue = 1;
else if (EndLoc.N_LAYER == 2) layerValue = 3;
else if (EndLoc.N_LAYER == 3) layerValue = 5;
ModbusHelper.WriteSingleRegister(40089, layerValue, device.address, 1024);
ModbusHelper.WriteSingleRegister(40101, 2, device.address, 1024);
ModbusHelper.WriteSingleRegister(40003, 2, device.address, 1024);
ModbusHelper.WriteSingleRegister(40102, 1, device.address, 1024);
}
}
else if (TN_Task.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 (TN_Task.S_NOTE == "空托回库")
{
var Device = Settings.deviceInfos.Where(a => a.TN_Location == TN_Task.S_START_LOC).FirstOrDefault();
if (Device != null)
{
if (S7Helper.WriteDpj(Device.address, 1002, 1))
{
int value = S7Helper.ReadDpj(Device.address, 2004, S7.Net.VarType.Byte);
if (value == 1)
{
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
else
{
LogHelper.Info("叠盘机安全交互失败,读取VB2004的值为{2004}");
}
}
else
{
LogHelper.Info("叠盘机安全交互失败,写入VB1002值1失败");
}
}
else
{
LogHelper.Info($"叠盘机安全交互失败,根据任务起点{TN_Task.S_START_LOC},未找到叠盘机配置文件");
}
}
else
{
if (OperateReqByPost(url, TN_Task.S_EQ_NO, TN_Task.S_CODE, loc, type, model.state))
{
// NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18);
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
}
}
}
if (model.state == 1102)
{
type = 3;
if (TN_Task.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 (TN_Task.S_NOTE == "空托回库")
{
var Device = Settings.deviceInfos.Where(a => a.TN_Location == TN_Task.S_START_LOC).FirstOrDefault();
if (Device != null)
{
//写入失败重新写入
if (!S7Helper.WriteDpj(Device.address, 1001, 1))
{
Task.Run(() =>
{
while (!S7Helper.WriteDpj(Device.address, 1001, 1))
{
Thread.Sleep(1000);
}
});
}
if (!S7Helper.WriteDpj(Device.address, 1002, 0))
{
Task.Run(() =>
{
while (!S7Helper.WriteDpj(Device.address, 1002, 0))
{
Thread.Sleep(1000);
}
});
}
}
else
{
LogHelper.Info($"叠盘机安全交互失败,根据任务起点{TN_Task.S_START_LOC},未找到叠盘机配置文件");
}
}
}
if (model.state == 1103)
{
//请求卸货
type = 2;
loc = TN_Task.S_END_LOC;
if (TN_Task.S_TYPE.Contains("电梯1"))
{
var device = Settings.deviceInfos.Where(a => a.TN_Location == TN_Task.S_END_LOC).FirstOrDefault();
var startloc = LocationHelper.GetLocByLoc(TN_Task.S_START_LOC);
if (device == null)
{
LogHelper.Info($"根据任务终点:{TN_Task.S_END_LOC},未找到对应电梯配置文件");
}
if (startloc == null)
{
LogHelper.Info($"根据任务起点:{TN_Task.S_START_LOC},未找到对应货位");
}
var value = ModbusHelper.ReadHoldingRegisters(40005, 1, device.address, 1024);
var value2 = ModbusHelper.ReadHoldingRegisters(40101, 1, device.address, 1024);
if (value[0] == startloc.N_LAYER && value2[0] == 2)
{
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
else
{
int layerValue = 0;
if (startloc.N_LAYER == 1) layerValue = 1;
else if (startloc.N_LAYER == 2) layerValue = 3;
else if (startloc.N_LAYER == 3) layerValue = 5;
ModbusHelper.WriteSingleRegister(40101, 2, device.address, 1024);
ModbusHelper.WriteSingleRegister(40003, 2, device.address, 1024);
ModbusHelper.WriteSingleRegister(40089, layerValue, device.address, 1024);
ModbusHelper.WriteSingleRegister(40102, 1, device.address, 1024);
}
}
else if (TN_Task.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, model.state))
{
NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
}
}
}
if (model.state == 1104)
{
type = 4;
if (TN_Task.S_TYPE.Contains("电梯1"))
{
var db = new SqlHelper