#region << 版 本 注 释 >> /*---------------------------------------------------------------- * 命名空间:WIDESEAWCS_TaskInfoService * 创建者:胡童庆 * 创建时间:2024/8/2 16:13:36 * 版本:V1.0.0 * 描述: * * ---------------------------------------------------------------- * 修改人: * 修改时间: * 版本:V1.0.1 * 修改说明: * *----------------------------------------------------------------*/ #endregion << 版 本 注 释 >> using AutoMapper; using HslCommunication; using Microsoft.AspNetCore.Mvc.RazorPages; using NetTaste; using Newtonsoft.Json; using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime; using OfficeOpenXml.FormulaParsing.Excel.Functions.Math; using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; using SqlSugar; using StackExchange.Profiling.Internal; using System; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.Linq; using System.Linq.Expressions; using System.Reflection; using System.Reflection.Metadata; using System.Security.Policy; using System.Text; using System.Threading.Tasks; using WIDESEA_Comm.Http; using WIDESEA_Common.Log; using WIDESEA_Core.Enums; using WIDESEAWCS_Common.TaskEnum; using WIDESEAWCS_Core; using WIDESEAWCS_Core.BaseRepository; using WIDESEAWCS_Core.BaseServices; using WIDESEAWCS_Core.Enums; using WIDESEAWCS_Core.Utilities; using WIDESEAWCS_DTO.Enum; using WIDESEAWCS_DTO.TaskInfo; using WIDESEAWCS_ISystemRepository; using WIDESEAWCS_ISystemServices; using WIDESEAWCS_ITaskInfoRepository; using WIDESEAWCS_ITaskInfoService; using WIDESEAWCS_Model; using WIDESEAWCS_Model.Models; using WIDESEAWCS_Model.Models.System; using WIDESEAWCS_QuartzJob; using WIDESEAWCS_QuartzJob.DTO; using WIDESEAWCS_QuartzJob.Models; using WIDESEAWCS_QuartzJob.Service; using WIDESEAWCS_TaskInfoRepository; using static Microsoft.IO.RecyclableMemoryStreamManager; namespace WIDESEAWCS_TaskInfoService { public partial class TaskService : ServiceBase, ITaskService { private readonly IRouterService _routerService; private readonly ITaskExecuteDetailService _taskExecuteDetailService; private readonly ITaskExecuteDetailRepository _taskExecuteDetailRepository; private readonly ITask_HtyService _task_HtyService; private readonly ITask_HtyRepository _task_HtyRepository; private readonly IMapper _mapper; private readonly IUnitOfWorkManage _unitOfWorkManage; private readonly IDt_roadwayinfoService _Dt_roadwayinfoService; private readonly IDt_PlatformStationRepository _dt_PlatformStation; private Dictionary _taskOrderBy = new() { {nameof(Dt_Task.Grade),OrderByType.Desc }, {nameof(Dt_Task.CreateDate),OrderByType.Asc}, }; public Dictionary TaskOrderBy { get { return _taskOrderBy; } set { _taskOrderBy = value; } } public string urlWMStaskreturn = WIDESEAWCS_Core.Helper.AppSettings.Configuration["urlWMStaskreturn"]; public string urlWMSdeverror = WIDESEAWCS_Core.Helper.AppSettings.Configuration["urlWMSdeverror"]; public string urlWMSliftinposition = WIDESEAWCS_Core.Helper.AppSettings.Configuration["urlWMSliftinposition"]; public TaskService(ITaskRepository BaseDal, IDt_PlatformStationRepository dt_PlatformStation, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper, ITask_HtyService task_HtyService, ITask_HtyRepository task_HtyRepository, IUnitOfWorkManage unitOfWork, IDt_roadwayinfoService dt_RoadwayinfoService) : base(BaseDal) { _routerService = routerService; _taskExecuteDetailService = taskExecuteDetailService; _taskExecuteDetailRepository = taskExecuteDetailRepository; _task_HtyService = task_HtyService; _task_HtyRepository = task_HtyRepository; _mapper = mapper; _unitOfWorkManage = unitOfWork; _Dt_roadwayinfoService = dt_RoadwayinfoService; _dt_PlatformStation = dt_PlatformStation; } //根据任务号,查询任务 public Dt_Task? CurrtaskInfo(int taskNum) { return BaseDal.QueryData().Where(x => x.TaskNum == taskNum).FirstOrDefault(); } /// /// 任务完成 /// /// 任务号 /// public WebResponseContent StackCraneTaskCompleted(int taskNum,string PalletCode) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); if (task.TaskType == (int)TaskTypeEnum.Outbound && task.TaskState == (int)TaskOutStatusEnum.SC_OutExecuting) { task.TaskState = (int)TaskOutStatusEnum.OutFinish; BaseDal.UpdateData(task); string Result = WMSTaskStatusEnum.outsuccess.GetDescription(); if (task.Creater.Equals("WMS")) { //同步给上游反馈任务完成 Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") { WriteLog.Write_Log("调取上游返回失败", "完成堆垛机任务失败", $"条码:【{task.PalletCode}】,任务号:【{task.TaskNum}】"); return content.Error($"调取上游返回失败,完成堆垛机任务失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } } task.ModifyDate = DateTime.Now; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"出库完成"); } else if (task.TaskType == (int)TaskTypeEnum.Inbound && task.TaskState == (int)TaskInStatusEnum.SC_InExecuting) { task.TaskState = (int)TaskInStatusEnum.InFinish; BaseDal.UpdateData(task); string Result = WMSTaskStatusEnum.insuccess.GetDescription(); if (task.Creater.Equals("WMS")) { Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") { WriteLog.Write_Log("调取上游返回失败", "完成堆垛机任务失败", $"条码:【{task.PalletCode}】,任务号:【{task.TaskNum}】"); return content.Error($"调取上游返回失败,完成堆垛机任务失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } } task.ModifyDate = DateTime.Now; task.Modifier = "System"; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"入库完成"); } else if (task.TaskType == (int)TaskTypeEnum.Inventorybound && task.TaskState == (int)TaskinventoryStatusEnum.SC_inventoryExecuting) { task.TaskState = (int)TaskinventoryStatusEnum.inventoryFinish; BaseDal.UpdateData(task); string Result = WMSTaskStatusEnum.insuccess.GetDescription(); if (task.Creater.Equals("WMS")) { Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") { WriteLog.Write_Log("调取上游返回失败", "完成堆垛机任务失败", $"条码:【{task.PalletCode}】,任务号:【{task.TaskNum}】"); return content.Error($"调取上游返回失败,完成堆垛机任务失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } } task.ModifyDate = DateTime.Now; task.Modifier = "System"; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"盘点完成"); } else { throw new Exception($"任务类型错误,未找到该任务类型,任务号:【{taskNum}】,任务类型:【{task.TaskType}】"); } content.OK(); } catch (Exception ex) { content.Error($"任务完成异常,任务号:【{taskNum}】,原因:{ex.Message}"); } return content; } /// /// 将任务状态修改为下一个状态 /// /// 任务号 public WebResponseContent UpdateTaskStatusToNext(int taskNum) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); return UpdateTaskStatusToNext(task); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } return content; } /// /// 将任务状态修改为下一个状态 /// /// 任务实体对象 /// public WebResponseContent UpdateTaskStatusToNext([NotNull] Dt_Task task) { WebResponseContent content = new WebResponseContent(); try { int oldState = task.TaskState; if (task.TaskType == (int)TaskTypeEnum.Outbound) { if (task.TaskState >= (int)TaskOutStatusEnum.OutFinish) { return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】"); } task.TaskState = (int)TaskOutStatusEnum.SC_OutExecuting; task.Dispatchertime = DateTime.Now; } else if (task.TaskType == (int)TaskTypeEnum.Inbound) { if (task.TaskState >= (int)TaskInStatusEnum.InFinish) { return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】"); } task.TaskState = (int)TaskInStatusEnum.SC_InExecuting; task.Dispatchertime = DateTime.Now; } else if (task.TaskType == (int)TaskTypeEnum.Inventorybound) { if (task.TaskState >= (int)TaskinventoryStatusEnum.inventoryFinish) { return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】"); } task.TaskState = (int)TaskinventoryStatusEnum.SC_inventoryExecuting; task.Dispatchertime = DateTime.Now; } else { throw new Exception($"任务类型错误,未找到该任务类型,任务号:【{task.TaskNum}】,任务类型:【{task.TaskType}】"); } if (task.TaskState <= 0) { return content = WebResponseContent.Instance.Error($"该任务状态不可跳转到下一步,任务号:【{task.TaskNum}】,任务状态:【{task.TaskState}】"); } string Result = WMSTaskStatusEnum.pickup.GetDescription(); task.ModifyDate = DateTime.Now; task.Modifier = "System"; BaseDal.UpdateData(task); Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); //反馈至上游 CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); Console.WriteLine(command.ToJsonString()); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, App.User.UserId > 0 ? $"人工手动将任务状态从【{oldState}】跳转到【{task.TaskState}】" : $"系统自动流程,任务状态从【{oldState}】转到【{task.TaskState}】"); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } return content; } /// /// 更新任务异常信息显示 /// /// 任务号 /// 异常信息 public WebResponseContent UpdateTaskExceptionMessage(int taskNum, string message) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup) { task.TaskState = (int)TaskOutStatusEnum.OutPending; } else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup) { task.TaskState = (int)TaskInStatusEnum.InPending; } task.ExceptionMessage = message; task.ModifyDate = DateTime.Now; BaseDal.UpdateData(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, task.ExceptionMessage); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } return content; } /// /// 恢复挂起任务 /// /// 任务号 /// 返回处理结果 public WebResponseContent TaskStatusRecovery(int taskNum) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); if (task.TaskState != (int)TaskInStatusEnum.InPending && task.TaskState != (int)TaskOutStatusEnum.OutPending) { return content = WebResponseContent.Instance.Error($"该任务状态不可恢复,任务号:【{taskNum}】,任务状态:【{task.TaskState}】"); } Dt_TaskExecuteDetail taskExecuteDetail = _taskExecuteDetailRepository.QueryFirst(x => x.TaskId == task.TaskId && x.IsNormal, new Dictionary { { nameof(Dt_TaskExecuteDetail.TaskDetailId), OrderByType.Desc } }); if (taskExecuteDetail != null) { task.TaskState = taskExecuteDetail.TaskState; } else { if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup) { task.TaskState = (int)TaskOutStatusEnum.OutNew; } else if (task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup) { task.TaskState = (int)TaskInStatusEnum.InNew; } //todo } task.ExceptionMessage = string.Empty; BaseDal.UpdateData(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"人工恢复挂起任务,恢复挂起时任务状态【{task.TaskState}】"); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } return content; } /// /// 回滚任务状态 /// /// 任务号 /// 返回处理结果 public WebResponseContent RollbackTaskStatusToLast(int taskNum) { WebResponseContent content = new(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); int oldState = task.TaskState; Dt_TaskExecuteDetail taskExecuteDetail = _taskExecuteDetailRepository.QueryFirst(x => x.TaskId == task.TaskId && x.TaskState < task.TaskState && x.TaskState > 0, new Dictionary { { nameof(Dt_TaskExecuteDetail.TaskDetailId), OrderByType.Desc } }); if (taskExecuteDetail != null) { task.TaskState = taskExecuteDetail.TaskState; task.CurrentAddress = taskExecuteDetail.CurrentAddress; task.NextAddress = taskExecuteDetail.NextAddress; } else { return content = WebResponseContent.Instance.Error($"未找到任务明细信息,该任务状态不可回滚到上一步,任务号:【{taskNum}】,任务状态:【{task.TaskState}】"); } task.ExceptionMessage = string.Empty; BaseDal.UpdateData(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"人工将任务状态从【{oldState}】回滚到【{task.TaskState}】"); content = WebResponseContent.Instance.OK(); } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } return content; } public WebResponseContent ReceiveWCSTask(int tasknum) { Dt_Task tasks = BaseDal.QueryFirst(x => x.TaskNum == tasknum); if(tasks == null) { return WebResponseContent.Instance.Error(); } else { try { _task_HtyService.AddTaskHty(tasks); BaseDal.DeleteData(tasks); WriteLog.Write_Log("WMS手动删除任务", "删除成功", $"申请删除的条码:{tasks.TaskNum},托盘条码:{tasks.PalletCode}", new { 信息 = "删除成功" }); return WebResponseContent.Instance.OK(); } catch (Exception ex) { WriteLog.Write_Log("WMS手动删除任务", "删除失败", $"申请删除的条码:{tasks.TaskNum},托盘条码:{tasks.PalletCode}", new { 信息 = ex.Message }); return WebResponseContent.Instance.Error(); } } } public void wcs_PLCto09(string SCLLinStack, string Logtype, string Magessadd) { WriteLog.Write_Log("任务完成交互", SCLLinStack, Logtype, new { 信息 = Magessadd }); } //============================================以下是后续新增内容查找任务============================================================= /// /// 根据设备编号、当前地址按照优先级以及创建时间排序查询任务池新增的任务 /// /// 设备编号 /// 当前地址 /// 返回任务实体对象,可能为null public List QueryStackerCraneTask(string deviceNo, string currentAddress = "") { return BaseDal.QueryData(x => x.Roadway == deviceNo && (x.TaskState == (int)TaskInStatusEnum.InNew || x.TaskState == (int)TaskOutStatusEnum.OutNew || x.TaskState == (int)TaskinventoryStatusEnum.inventoryNew), TaskOrderBy); } public Dt_Task CutStackerCraneTask(string deviceNo) { Dt_Task dt_Task = BaseDal.QueryFirst(x => x.Roadway == deviceNo && (x.TaskState == (int)TaskOutStatusEnum.SC_OutExecuting || x.TaskState == (int)TaskInStatusEnum.SC_InExecuting || x.TaskState == (int)TaskinventoryStatusEnum.SC_inventoryExecuting)); return dt_Task; } /// /// 手动取消任务 /// /// /// public WebResponseContent TaskCancel(int taskNum) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task != null) { //上报入库任务异常 //if (task.TaskType == (int)TaskTypeEnum.Inbound) //{ string Result = WMSTaskStatusEnum.inerror.GetDescription(); if (task.Creater.Equals("WMS")) { Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") return content.Error($"调取上游返回失败,任务取消失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } BaseDal.DeleteData(task); task.ModifyDate = DateTime.Now; task.Modifier = App.User?.UserName; task.Remark = "人工手动取消"; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); content.Status = true; //} //else //{ // return WebResponseContent.Instance.Error($"取消失败,只能取消入库任务"); //} } else { return WebResponseContent.Instance.Error($"取消失败,该任务【{taskNum}】不存在"); } return content; } catch (Exception e) { return WebResponseContent.Instance.Error(); } } /// ///手动完成任务 /// /// /// public WebResponseContent TaskHandCompleted(int taskNum) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); if (task.TaskType == (int)TaskTypeEnum.Outbound) { string Result = WMSTaskStatusEnum.outsuccess.GetDescription(); if (task.Creater.Equals("WMS")) { Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") return content.Error($"调取上游返回失败,完成堆垛机任务失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } task.ModifyDate = DateTime.Now; task.Modifier = App.User?.UserName; task.Remark = "人工手动完成"; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"手动出库完成"); } else if (task.TaskType == (int)TaskTypeEnum.Inbound) { string Result = WMSTaskStatusEnum.insuccess.GetDescription(); if (task.Creater.Equals("WMS")) { Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") return content.Error($"调取上游返回失败,完成堆垛机任务失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } task.ModifyDate = DateTime.Now; task.Modifier = App.User?.UserName; task.Remark = "人工手动完成"; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"手动入库完成"); } else if (task.TaskType == (int)TaskTypeEnum.Inventorybound) {; string Result = WMSTaskStatusEnum.insuccess.GetDescription(); if (task.Creater.Equals("WMS")) { Dt_roadwayinfo roadwayinfo = _Dt_roadwayinfoService.GetRoadwayinfo(task.Roadway); CommandResult command = taskreturn(int.Parse(task.WMStaskid), Result, roadwayinfo.WarehouseInvType, ""); if (command.status != "success") return content.Error($"调取上游返回失败,完成堆垛机任务失败,条码:{task.PalletCode},任务号:{task.TaskNum}"); } task.ModifyDate = DateTime.Now; task.Modifier = App.User?.UserName; task.Remark = "人工手动完成"; BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"手动入库完成"); } else { throw new Exception($"任务类型错误,未找到该任务类型,任务号:【{taskNum}】,任务类型:【{task.TaskType}】"); } content.OK(); } catch (Exception ex) { content.Error($"任务完成异常,任务号:【{taskNum}】,原因:{ex.Message}"); } return content; } /// /// 手动创建任务 /// /// /// public WebResponseContent CreateManualTask(Dt_Task transfer) { WebResponseContent content = new WebResponseContent(); try { IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName.Contains("堆垛机")); // 判断设备是否存在 if (device == null) { content.Error("手动创建任务失败,原因:未找到堆垛机设备"); WriteLog.Write_Log("手动任务创建失败", "创建失败", $"原因:未找到堆垛机设备,托盘编号:{transfer.PalletCode},任务类型:{transfer.TaskType},起始地址:{transfer.SourceAddress},目标地址:{transfer.TargetAddress}"); return content; } // 判断地址是否属于当前设备库 if ((transfer.TaskType == 300 || transfer.SourceAddress.Contains(device.DeviceCode) ) && transfer.TargetAddress.Contains(device.DeviceCode)) { // 入库 if (transfer.TaskType == 200) { Dt_PlatformStation _PlatformStation = _dt_PlatformStation.QueryFirst(x => x.Station_code == transfer.SourceAddress); if (_PlatformStation == null) { content.Error($"手动创建任务失败,原因:{device.DeviceCode}库不存在这个库口:{transfer.SourceAddress}"); WriteLog.Write_Log("手动任务创建失败", "创建失败", $"托盘编号:{transfer.PalletCode},任务类型:{transfer.TaskType},起始地址:{transfer.SourceAddress},目标地址:{transfer.TargetAddress}"); } else { // 正常创建任务 transfer.TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)); transfer.TaskState = 200; transfer.CurrentAddress = transfer.SourceAddress; transfer.NextAddress = transfer.TargetAddress; transfer.Roadway = device.DeviceCode; transfer.Creater = "WCS"; transfer.Grade = 1; transfer.CreateDate = DateTime.Now; _unitOfWorkManage.BeginTran(); BaseDal.AddData(transfer); _unitOfWorkManage.CommitTran(); content.OK("手动入库任务创建成功!"); WriteLog.Write_Log("手动任务创建成功", "创建成功", $",任务类型:【入库】,任务号:【{transfer.TaskNum}】托盘编号:【{transfer.PalletCode}】,起始地址:【{transfer.SourceAddress}】,目标地址:【{transfer.TargetAddress}】"); } return content; } // 出库 else if (transfer.TaskType == 100) { Dt_PlatformStation _PlatformStation = _dt_PlatformStation.QueryFirst(x => x.Station_code == transfer.TargetAddress); if (_PlatformStation == null) { content.Error($"手动创建任务失败,原因:{device.DeviceCode}库不存在这个库口:{transfer.TargetAddress}"); } else { // 正常创建任务 transfer.TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)); transfer.TaskState = 100; transfer.CurrentAddress = transfer.SourceAddress; transfer.NextAddress = transfer.TargetAddress; transfer.Roadway = device.DeviceCode; transfer.Creater = "WCS"; transfer.Grade = 1; transfer.CreateDate = DateTime.Now; _unitOfWorkManage.BeginTran(); BaseDal.AddData(transfer); _unitOfWorkManage.CommitTran(); content.OK("手动出库任务创建成功!"); WriteLog.Write_Log("手动任务创建成功", "创建成功", $"任务类型:【出库】,任务号:【{transfer.TaskNum}】托盘编号:【{transfer.PalletCode}】,,起始地址:【{transfer.SourceAddress}】,目标地址:【{transfer.TargetAddress}】"); } return content; } else if (transfer.TaskType == 300) { // 正常创建任务 transfer.TaskNum = BaseDal.GetTaskNum(nameof(SequenceEnum.SeqTaskNum)); transfer.TaskState = 300; transfer.CurrentAddress = transfer.SourceAddress; transfer.NextAddress = transfer.TargetAddress; transfer.Roadway = device.DeviceCode; transfer.Creater = "WCS"; transfer.Grade = 1; transfer.CreateDate = DateTime.Now; _unitOfWorkManage.BeginTran(); BaseDal.AddData(transfer); _unitOfWorkManage.CommitTran(); content.OK("手动盘点任务创建成功!"); WriteLog.Write_Log("手动任务创建成功", "创建成功", $",任务类型:【盘点】,任务号:【{transfer.TaskNum}】,托盘编号:【{transfer.PalletCode}】,目标地址:【{transfer.TargetAddress}】"); return content; } } else { content.Error($"手动创建任务失败,原因:{device.DeviceCode}库地址不匹配,起始地址:{transfer.SourceAddress},目标地址:{transfer.TargetAddress}"); WriteLog.Write_Log("手动任务创建失败", "创建失败",$"任务号:【{transfer.TaskNum}】,托盘编号:【{transfer.PalletCode}】,目标地址:【{transfer.TargetAddress}】"); } } catch (Exception ex) { content.Error($"手动创建任务失败,系统异常:{ex.Message}"); WriteLog.Write_Log("手动任务异常", "异常", ex.ToString()); } return content; } /// /// 手动删除任务 /// /// /// public WebResponseContent CreateDelete(int taskNum) { WebResponseContent content = new WebResponseContent(); try { Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); if (task == null) return WebResponseContent.Instance.Error($"未找到该任务信息,任务号:【{taskNum}】"); task.ModifyDate = DateTime.Now; task.Modifier = App.User?.UserName; task.Remark = "人工手动删除"; content.Status = BaseDal.DeleteData(task); _task_HtyService.AddTaskHty(task); _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"手动删除任务"); } catch(Exception e) { WebResponseContent.Instance.Error(e.Message); } return content; } /// /// 编辑 /// /// /// public override WebResponseContent UpdateData(SaveModel saveModel) { WebResponseContent content = new WebResponseContent(); try { string json = JsonConvert.SerializeObject(saveModel.MainData); Dt_Task task = JsonConvert.DeserializeObject(json); content.Status = BaseDal.UpdateData(task); }catch(Exception e) { WebResponseContent.Instance.Error(e.Message); } return content; } /// //agv进出状态反馈 public WebResponseContent getManuaAGVStatus(AgvUpdateRequest agvUpdateRequest) { //获取WMS调取的参数 WriteLog.Write_Log("手动agv进出状态反馈接口", "手动agv进出状态信息", $"库口名称:【{agvUpdateRequest.warehousenumber}】,申请状态:【{agvUpdateRequest.agvstatus}】"); WebResponseContent content = new WebResponseContent(); try { string DeciceCodes = "1003"; if (agvUpdateRequest.warehousenumber.StartsWith("C")) DeciceCodes = "1004"; IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceCode == DeciceCodes); if (device == null) return content.Error("WCS未能获取到库口实例"); CommonConveyorLine conveyorLine = (CommonConveyorLine)device; //是否可进出 DeviceProDTO? HandShake = conveyorLine.DeviceProDTOs.FirstOrDefault(x => x.DeviceChildCode == agvUpdateRequest.warehousenumber && x.DeviceProParamName == "HandShake"); if (HandShake == null) return content.Error($"WCS未找到库口:{agvUpdateRequest.warehousenumber},对应的协议"); DeviceProDTO? Request = conveyorLine.DeviceProDTOs.FirstOrDefault(x => x.DeviceChildCode == agvUpdateRequest.warehousenumber && x.DeviceProParamName == "Request"); if (agvUpdateRequest.agvstatus == 1) { bool HandShakebool = conveyorLine.Communicator.Write(HandShake.DeviceProAddress, 1); if (HandShakebool) { if (Request != null) { conveyorLine.Communicator.Write(Request.DeviceProAddress, 1); } //是否可进出 1允许取 2允许放 DeviceProDTO? deviceProDTO = conveyorLine.DeviceProDTOs.FirstOrDefault(x => x.DeviceChildCode == agvUpdateRequest.warehousenumber && x.DeviceProParamName == "PermitHandShake"); //是否有货 DeviceProDTO? StationNumProDTO = conveyorLine.DeviceProDTOs.FirstOrDefault(x => x.DeviceChildCode == agvUpdateRequest.warehousenumber && x.DeviceProParamName == "StationNum"); if (deviceProDTO == null || StationNumProDTO == null) return content.Error($"WCS未找到库口:{agvUpdateRequest.warehousenumber},对应的协议"); int statusValue = 0; int portStatus = conveyorLine.Communicator.Read(deviceProDTO.DeviceProAddress); int StationStatus = conveyorLine.Communicator.Read(StationNumProDTO.DeviceProAddress); //有货,可进信号 statusValue = ((portStatus == 1 && StationStatus == 1) || (portStatus == 2 && StationStatus == 0)) ? 1 : (portStatus == 0) ? 0 : 0; if (agvUpdateRequest.warehousenumber == "G01" || agvUpdateRequest.warehousenumber == "G06" || agvUpdateRequest.warehousenumber == "G07") { if (statusValue == 1) { return content.OK("申请进入成功"); } else { conveyorLine.Communicator.Write(Request.DeviceProAddress, 0); return content.Error("读取plc不可进入信息"); } } else { return content.OK("申请进入成功"); } } else { return content.Error("写入plc进入信号失败"); } } else if (agvUpdateRequest.agvstatus == 2) { //写入输送线信号 bool portStatus = conveyorLine.Communicator.Write(HandShake.DeviceProAddress, 0); if (portStatus) { if (Request != null) { conveyorLine.Communicator.Write(Request.DeviceProAddress, 0); } return content.OK("申请退出成功"); } else { return content.Error("写入plc清除信号失败"); } } else { return content.Error($"agv对应的申请错误,字段:agvstatus,申请的值:{agvUpdateRequest.agvstatus}"); } } catch (Exception ex) { return content.Error($"WCS任务添加错误,原因:{ex.Message}"); } } } }