| | |
| | | #endregion << ç æ¬ 注 é >> |
| | | |
| | | using AutoMapper; |
| | | using Newtonsoft.Json; |
| | | using OfficeOpenXml.FormulaParsing.Excel.Functions.Text; |
| | | using SqlSugar; |
| | | using SqlSugar.Extensions; |
| | | using System; |
| | | using System.Collections; |
| | | using System.Collections.Generic; |
| | | using System.ComponentModel; |
| | | using System.Diagnostics.CodeAnalysis; |
| | |
| | | private readonly ILocationInfoRepository _locationInfoRepository; |
| | | private readonly IMapper _mapper; |
| | | private readonly IUnitOfWorkManage _unitOfWorkManage; |
| | | private readonly ITaskRepository _taskRepository; |
| | | |
| | | private Dictionary<string, OrderByType> _taskOrderBy = new() |
| | | { |
| | |
| | | |
| | | public List<int> TaskOtherboundTypes => typeof(TaskOtherTypeEnum).GetEnumIndexList(); |
| | | |
| | | public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper, ILocationInfoRepository locationInfoRepository, IUnitOfWorkManage unitOfWorkManage) : base(BaseDal) |
| | | public TaskService(ITaskRepository BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, ITaskExecuteDetailRepository taskExecuteDetailRepository, IMapper mapper, ILocationInfoRepository locationInfoRepository, IUnitOfWorkManage unitOfWorkManage, ITaskRepository taskRepository) : base(BaseDal) |
| | | { |
| | | _routerService = routerService; |
| | | _taskExecuteDetailService = taskExecuteDetailService; |
| | |
| | | _mapper = mapper; |
| | | _locationInfoRepository = locationInfoRepository; |
| | | _unitOfWorkManage = unitOfWorkManage; |
| | | _taskRepository = taskRepository; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | // ServiceLogger.WriteLogToFile(""); |
| | | string inparam = JsonConvert.SerializeObject(taskDTO); |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ReceiveMESTaskæ¹æ³å
¥å{inparam}"); |
| | | Dt_Task task = new Dt_Task(); |
| | | Dt_Task taskinfo = BaseDal.QueryFirst(x => x.TaskNum == taskDTO.task_id); |
| | | if(taskDTO.cmd==101)//妿æ¯101ææ§çä»»å¡å·å»æ¥ |
| | |
| | | |
| | | if (taskDTO.cmd!=3001&& taskDTO.cmd != 101 && taskinfo != null) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ä»»å¡å·éå¤ï¼ä»»å¡å·ï¼{taskDTO.task_id}"); |
| | | return content = WebResponseContent.Instance.Error($"ä»»å¡å·éå¤ï¼ä»»å¡å·ï¼{taskDTO.task_id}"); |
| | | } |
| | | Dt_LocationInfo locationsrc = _locationInfoRepository.QueryFirst(x => x.Remark == taskDTO.src_station.ToString()); |
| | |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | } |
| | | break; |
| | | case 3001://AGVæ¾è´§å®æ WMSå3001çåæ¶ä¼åæåä¿¡å· |
| | | case 3001://AGVæ¾è´§å®æ WMSå3001çåæ¶WCSéå¨jobä¸åæåä¿¡å· |
| | | if (BaseDal.QueryFirst(x => x.TaskNum == taskDTO.task_id) == null)//æå¨å
¥åºç´æ¥å3001ï¼éè¦çæä»»å¡ï¼å 为没æ1001ç¯è |
| | | { |
| | | |
| | |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°æºç«ç¹å¯¹åºçåºä½ï¼æºç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | } |
| | | } |
| | |
| | | { |
| | | UpdateTaskStatus(taskinfo.TaskId, (int)TaskInStatusEnum.AGV_InExecuting); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"AGVå
¥åºæ§è¡ä¸"); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"AGVå
¥åºæ§è¡ä¸ï¼èªå¨3001ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | return content = WebResponseContent.Instance.OK($"AGVå
¥åºæ§è¡ä¸ï¼èªå¨3001ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | } |
| | | else |
| | |
| | | //æ´æ°ä»»å¡è¡¨ä¸NextAddressåæ®µä¸ºæ°çä»»å¡å· taskDTO.weight-æ§çä»»å¡å· taskDTO.task_id-æ°çä»»å¡å· |
| | | UpdateTaskStatus(taskinfo.TaskId, taskDTO.task_id, (int)TaskInStatusEnum.AGV_InFinish); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"AGVæ¬è¿å®æ"); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | return content = WebResponseContent.Instance.OK($"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææåï¼ä»»å¡å·ï¼{taskinfo.TaskId}"); |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææ¶ï¼æ¥è¯¢ä¸å°ä»»å¡å·"); |
| | | return content = WebResponseContent.Instance.Error($"AGVæ¬è¿å®æï¼101ï¼æ´æ°ç¶ææ¶ï¼æ¥è¯¢ä¸å°ä»»å¡å·"); |
| | | } |
| | | break; |
| | |
| | | } |
| | | else |
| | | { |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{taskDTO.dest_station.ToString()}"); |
| | | } |
| | | break; |
| | | case 104://ç»ç«æºä¸æ æåä½-->ç»ç«æº |
| | |
| | | } |
| | | else |
| | | { |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{task.TargetAddress.ToString()}"); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{task.TargetAddress.ToString()}"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç®æ ç«ç¹å¯¹åºçåºä½ï¼ç®æ ç«ç¹ï¼{task.TargetAddress.ToString()}"); |
| | | } |
| | | //æ ¹æ®ç®æ å°åï¼ç»ç«æºï¼æ¥è¯¢é»è®¤çæ§è¡ä»»å¡çå°å åæºç¼å· |
| | | Dt_LocationInfo locationtemp2 = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress.ToString()); |
| | |
| | | } |
| | | else |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"WCSæªæ¥è¯¢å°ç»ç«æºå¯¹åºçé»è®¤å°å åæºé
ç½®"); |
| | | return content = WebResponseContent.Instance.Error($"WCSæªæ¥è¯¢å°ç»ç«æºå¯¹åºçé»è®¤å°å åæºé
ç½®"); |
| | | } |
| | | |
| | |
| | | |
| | | task.TaskNum = taskDTO.task_id; |
| | | task.PalletCode = taskDTO.CarId; |
| | | task.Roadway = "SC01"; |
| | | |
| | | if (string.IsNullOrEmpty(task.SourceAddress))//妿䏿¯ç«ç¹ï¼ç´æ¥åè¡åå± |
| | | { |
| | | task.SourceAddress = $"SC01-{taskDTO.src_rack.ToString().PadLeft(3, '0')}-{taskDTO.src_col.ToString().PadLeft(3, '0')}-{taskDTO.src_row.ToString().PadLeft(3, '0')}"; |
| | |
| | | { |
| | | if (srcLocation.EnableStatus == (int)EnableStatusEnum.Disable) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"æºå°åå·²ç¦ç¨ï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"æºå°åå·²ç¦ç¨ï¼{srcLocation.LocationCode}"); |
| | | } |
| | | if (tarLocation.EnableStatus == (int)EnableStatusEnum.Disable) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç®æ å°åå·²ç¦ç¨ï¼{tarLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç®æ å°åå·²ç¦ç¨ï¼{tarLocation.LocationCode}"); |
| | | } |
| | | if (taskDTO.cmd != 101)//å
¥åºæ¶ä¸éè¦å¤ææ¯å¦éå®ï¼éå®ç¶ææ¯å¨çæä»»å¡æ¶éå® |
| | |
| | | { |
| | | if (srcLocation.LocationStatus == (int)LocationStatusEnum.Lock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"æºå°åå·²éå®ï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"æºå°åå·²éå®ï¼{srcLocation.LocationCode}"); |
| | | } |
| | | if (tarLocation.LocationStatus == (int)LocationStatusEnum.Lock) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç®æ å°åå·²éå®ï¼{tarLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç®æ å°åå·²éå®ï¼{tarLocation.LocationCode}"); |
| | | } |
| | | } |
| | |
| | | //WCSæ¥è¯¢åºä½ç¶ææ¯å¦ä¸ºâ空é²â并䏿ªç¦ç¨ï¼éå®åºä½ä¿®æ¹åºä½ç¶æä¸ºâéå®âï¼çæWCS产åå
¥åºä»»å¡ï¼å å
¥WCSä»»å¡éåä¸ã |
| | | if (tarLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"å
¥åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{tarLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"å
¥åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{tarLocation.LocationCode}"); |
| | | } |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | |
| | | //WCSæ¥è¯¢åºä½ç¶ææ¯å¦ä¸ºâæè´§âï¼åºä½/æååºä½æ¯å¦â空é²â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç§»åº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç§»åº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | if(tarLocation.LocationStatus != (int)LocationStatusEnum.Free) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"ç§»åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"ç§»åº-ç®æ å°å䏿¯ç©ºé²ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | |
| | | //WCSæ¥è¯¢åºä½ç¶ææ¯å¦ä¸ºâæè´§â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"å¼å¸¸åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"å¼å¸¸åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | |
| | | //WCSæ¥è¯¢æååºä½æ¯å¦âæè´§â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"空车åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"空车åºåº-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | |
| | | //WCSæ¥è¯¢æååºä½æ¯å¦âæè´§â |
| | | if (srcLocation.LocationStatus != (int)LocationStatusEnum.InStock) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"䏿任å¡-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | return content = WebResponseContent.Instance.Error($"䏿任å¡-æºå°å䏿¯æè´§ç¶æï¼{srcLocation.LocationCode}"); |
| | | } |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Lock; |
| | |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"åºä½å°åä¸åå¨ï¼ä»»å¡å·:{task.TaskNum}"); |
| | | return content = WebResponseContent.Instance.Error($"åºä½å°åä¸åå¨ï¼ä»»å¡å·:{task.TaskNum}"); |
| | | } |
| | | |
| | |
| | | _unitOfWorkManage.RollbackTran(); |
| | | throw; |
| | | } |
| | | |
| | | content = WebResponseContent.Instance.OK("æå",task); |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"æ¥æ¶ä»»å¡æåï¼ä»»å¡å·:{task.TaskNum}"); |
| | | content = WebResponseContent.Instance.OK($"æ¥æ¶ä»»å¡æåï¼ä»»å¡å·:{task.TaskNum}", task); |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | ServiceLogger.WriteDebug("ReceiveTask", $"任塿¥æ¶é误,é误信æ¯:{ex.StackTrace}"); |
| | | content = WebResponseContent.Instance.Error($"任塿¥æ¶é误,é误信æ¯:{ex.Message}"); |
| | | } |
| | | return content; |
| | |
| | | |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, task.ExceptionMessage); |
| | | |
| | | content = WebResponseContent.Instance.OK(); |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | task.Modifier = "System"; |
| | | task.ModifyDate = DateTime.Now; |
| | | BaseDal.UpdateData(task); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// ä»»å¡å¼ºå¶å®æ å åæºå®é
已宿任å¡ï¼WCSæªæ¶å°å®æä¿¡å·æå
¶ä»æªç¥åå 导è´WCS任塿ªå®æï¼å¯ä»¥æ§è¡è¯¥æ¹æ³å¼ºå¶å®æä»»å¡ |
| | | /// </summary> |
| | | /// <param name="taskNum"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent ForceCompleteTask(int taskNum) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | bool isBack = false; |
| | | //1ï¼å
æ¥è¯¢ä»»å¡ï¼æ ¹æ®ä¸åçä»»å¡ç±»ååä»»å¡å¼ºå¶å®ææä½ |
| | | Dt_Task task = _taskRepository.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task == null) return WebResponseContent.Instance.Error($"æªæ¾å°è¯¥ä»»å¡ä¿¡æ¯,ä»»å¡å·:ã{taskNum}ã"); |
| | | |
| | | Dt_LocationInfo locationsrc = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress.ToString()); |
| | | Dt_LocationInfo locationdsc = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress.ToString()); |
| | | if (task.TaskType == (int)TaskInboundTypeEnum.Inbound) |
| | | { |
| | | if (task.TaskState == (int)TaskInStatusEnum.SC_InExecuting) |
| | | { |
| | | task.TaskState = (int)TaskInStatusEnum.SC_InFinish; |
| | | //éè¦å°ç®æ å°åæ¹ä¸ºæè´§ç¶æ |
| | | locationdsc.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | |
| | | //æ´æ°ç¶æä¸ºä»»å¡å®æ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºå
¥åºå®æ"); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å
¥åºä»»å¡å®æ"); |
| | | //æ´æ°è´§ä½ |
| | | _locationInfoRepository.UpdateData(locationdsc); |
| | | isBack = true; |
| | | |
| | | } |
| | | else |
| | | { |
| | | return content = WebResponseContent.Instance.Error("该任å¡ç®åç¶æï¼ä¸å
计强å¶å®æï¼"); |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | if (task.TaskState == (int)TaskOutStatusEnum.SC_OutExecuting) |
| | | { |
| | | |
| | | if (task.TaskType == (int)TaskOutboundTypeEnum.OutInventory || task.TaskType == (int)TaskOutboundTypeEnum.OutPick)//å¼å¸¸åºåº 空车åºåº |
| | | { |
| | | task.TaskState = (int)TaskOutStatusEnum.OutFinish; |
| | | //æºå°åæ´æ°ä¸ºç©ºé² |
| | | locationsrc.LocationStatus = (int)LocationStatusEnum.Free; |
| | | |
| | | //æ´æ°ç¶æä¸ºä»»å¡å®æ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡å®æ"); |
| | | //æ´æ°è´§ä½ |
| | | _locationInfoRepository.UpdateData(locationsrc); |
| | | isBack = true; |
| | | } |
| | | else if (task.TaskType == (int)TaskRelocationTypeEnum.Relocation)//ç§»åº |
| | | { |
| | | task.TaskState = (int)TaskOutStatusEnum.OutFinish; |
| | | //æºå°åæ´æ°ä¸ºç©ºé² |
| | | locationsrc.LocationStatus = (int)LocationStatusEnum.Free; |
| | | //ç®æ å°åæ´æ°ä¸ºæè´§ |
| | | locationdsc.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | |
| | | |
| | | //æ´æ°ç¶æä¸ºä»»å¡å®æ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡å®æ"); |
| | | //æ´æ°è´§ä½ |
| | | _locationInfoRepository.UpdateData(locationsrc); |
| | | _locationInfoRepository.UpdateData(locationdsc); |
| | | isBack = true; |
| | | |
| | | |
| | | } |
| | | else |
| | | { |
| | | return WebResponseContent.Instance.Error($"䏿任å¡ä¸å
计强å¶å®æï¼"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return WebResponseContent.Instance.Error($"该任å¡ç¶æä¸å
计强å¶å®æï¼"); |
| | | } |
| | | } |
| | | |
| | | //ä»»å¡å¼ºå¶å®æåè°MES |
| | | if (isBack) |
| | | { |
| | | |
| | | if (task.TaskType == (int)TaskInboundTypeEnum.Inbound)//å
¥åºæ¶åä¼ éä¼ æ°ä»»å¡å· |
| | | { |
| | | task.TaskNum =int.Parse(task.NextAddress); |
| | | } |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("ForceCompleteTask", $"ä»»å¡å¼ºå¶å®æååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡å¼ºå¶å®æååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ForceCompleteTask", $"ä»»å¡å¼ºå¶å®æååä¼ MESæåï¼,ä»»å¡å·:ã{taskNum}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æååä¼ MESæåï¼,ä»»å¡å·:ã{taskNum}ã"); |
| | | } |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content = WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | return content; |
| | | |
| | | } |
| | | |
| | | /// <summary> |
| | | /// ä»»å¡åæ¶ |
| | | /// </summary> |
| | | /// <param name="taskid"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent CancelTask(int taskNum) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | //1ï¼å
æ¥è¯¢ä»»å¡ï¼æ ¹æ®ä¸åçä»»å¡ç±»ååä»»å¡åæ¶æä½ |
| | | Dt_Task task = _taskRepository.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task == null) return WebResponseContent.Instance.Error($"æªæ¾å°è¯¥ä»»å¡ä¿¡æ¯,ä»»å¡å·:ã{taskNum}ã"); |
| | | |
| | | Dt_LocationInfo locationsrc = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress.ToString()); |
| | | Dt_LocationInfo locationdsc = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress.ToString()); |
| | | bool isBack = false; |
| | | //妿æ¯å
¥åºåèªå¨åæå¨ä¸¤ç§æ
åµå¤ç |
| | | if (task.TaskType == (int)TaskInboundTypeEnum.Inbound) |
| | | { |
| | | if (task.WMSId == 0 && task.TaskState == (int)TaskInStatusEnum.InNew)//èªå¨å
¥åºï¼1001-AGVè¯·æ±æ¯å¦å
计è¿å
¥ï¼ä»»å¡ç¶æä¸ºâæ°å»ºå
¥åºä»»å¡200âä¹åå¯ä»¥åæ¶ |
| | | { |
| | | task.TaskState = (int)TaskInStatusEnum.InCancel; |
| | | //éè¦å°ç®æ å°åæ¢å¤ä¸ºç©ºé²ç¶æ |
| | | locationdsc.LocationStatus = (int)LocationStatusEnum.Free; |
| | | //æ´æ°ç¶æä¸ºä»»å¡åæ¶ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å
¥åºä»»å¡åæ¶"); |
| | | _locationInfoRepository.UpdateData(locationdsc); |
| | | isBack = true; |
| | | } |
| | | else if (task.WMSId == 1 && task.TaskState == (int)TaskInStatusEnum.AGV_InExecuting)//æå¨å
¥åºï¼3001-AGVæ¾è´§å®æï¼ä»»å¡ç¶æä¸ºâAGVå
¥åºæ§è¡ä¸210âä¹åå¯ä»¥åæ¶ |
| | | { |
| | | task.TaskState = (int)TaskInStatusEnum.InCancel; |
| | | //éè¦å°ç®æ å°åæ¢å¤ç©ºé²ç¶æ |
| | | locationdsc.LocationStatus = (int)LocationStatusEnum.Free; |
| | | //æ´æ°ç¶æä¸ºä»»å¡åæ¶ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å
¥åºä»»å¡åæ¶"); |
| | | _locationInfoRepository.UpdateData(locationdsc); |
| | | isBack = true; |
| | | } |
| | | else |
| | | { |
| | | return WebResponseContent.Instance.Error($"该任å¡ç¶æä¸å
è®¡åæ¶ï¼"); |
| | | } |
| | | } |
| | | else//å
¶ä»ä»»å¡ï¼ä»»å¡ç¶æâæ°å»ºåºåºä»»å¡âä¹åï¼æå¯ä»¥åæ¶ |
| | | { |
| | | if (task.TaskState == (int)TaskOutStatusEnum.OutNew) |
| | | { |
| | | if(task.TaskType == (int)TaskOutboundTypeEnum.OutInventory|| task.TaskType == (int)TaskOutboundTypeEnum.OutPick)//å¼å¸¸åºåº 空车åºåº |
| | | { |
| | | task.TaskState = (int)TaskOutStatusEnum.OutCancel; |
| | | //æºå°åæ¢å¤å°æè´§ |
| | | locationsrc.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | |
| | | //æ´æ°ç¶æä¸ºä»»å¡åæ¶ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡åæ¶"); |
| | | _locationInfoRepository.UpdateData(locationsrc); |
| | | isBack = true; |
| | | } |
| | | else if(task.TaskType == (int)TaskRelocationTypeEnum.Relocation)//ç§»åº |
| | | { |
| | | task.TaskState = (int)TaskOutStatusEnum.OutCancel; |
| | | //æºå°åæ¢å¤å°æè´§ |
| | | locationsrc.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | //éè¦å°ç®æ å°åæ¢å¤ç©ºé²ç¶æ |
| | | locationdsc.LocationStatus = (int)LocationStatusEnum.Free; |
| | | //æ´æ°ç¶æä¸ºä»»å¡åæ¶ |
| | | UpdateTaskStatus(task.TaskId, task.TaskState); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"åºåºä»»å¡åæ¶"); |
| | | _locationInfoRepository.UpdateData(locationsrc); |
| | | _locationInfoRepository.UpdateData(locationdsc); |
| | | isBack = true; |
| | | } |
| | | else |
| | | { |
| | | return WebResponseContent.Instance.Error($"䏿任å¡ä¸å
è®¡åæ¶ï¼"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return WebResponseContent.Instance.Error($"该任å¡ç¶æä¸å
è®¡åæ¶ï¼"); |
| | | } |
| | | } |
| | | |
| | | |
| | | |
| | | //ä»»å¡åæ¶åè°MES |
| | | if (isBack) |
| | | { |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 3 }; |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("ForceCompleteTask", $"ä»»å¡åæ¶åä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡åæ¶åä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("ForceCompleteTask", $"ä»»å¡åæ¶åä¼ MESæåï¼,ä»»å¡å·:ã{taskNum}ã"); |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡åæ¶åä¼ MESæåï¼,ä»»å¡å·:ã{taskNum}ã"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content = WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | |
| | |
| | | _unitOfWorkManage.CommitTran(); |
| | | //åºåºå®æï¼åä¼ WMS |
| | | //åä¼ å°WMS |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | if (task.TaskType == (int)TaskOutboundTypeEnum.OutPick) |
| | | { |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æç©ºè½¦åºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æç©ºè½¦åºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå¼å¸¸åºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æå¼å¸¸åºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | //任塿§è¡å¤±è´¥ï¼è´§ä½ç¶æè¿å |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | |
| | |
| | | |
| | | //å
¥åºå®æï¼åä¼ MES å
¥åºå®æåä¼ task.NextAddress ä¹å101è¯·æ±æ¶åçæ°ä»»å¡å· |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = int.Parse(task.NextAddress), status = 6 }; |
| | | string inparam = JsonConvert.SerializeObject(sendcmd); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå
¥åºä»»å¡ååä¼ MESå
¥å:{inparam}"); |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå
¥åºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æå
¥åºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æå
¥åºä»»å¡ååä¼ MESæåï¼,ä»»å¡å·:ã{taskNum}ã"); |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºæ§è¡å
¥åºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºæ§è¡å
¥åºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | } |
| | |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | |
| | | Dt_LocationInfo tarLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | srcLocation.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | tarLocation.LocationStatus = (int)LocationStatusEnum.InStock; |
| | | UpdateTaskStatus(task.TaskId, (int)TaskOutStatusEnum.SC_OutFinish); |
| | | _taskExecuteDetailService.AddTaskExecuteDetail(task.TaskId, $"å åæºåºåºå®æ"); |
| | | |
| | |
| | | //ç§»åºå®æï¼åä¼ MES |
| | | //åä¼ å°WMS |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | string inparam = JsonConvert.SerializeObject(sendcmd); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æåºåºä»»å¡ååä¼ MESå
¥å:{inparam}"); |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | |
| | |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | content = WebResponseContent.Instance.Error($"大å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | } |
| | |
| | | { |
| | | try |
| | | { |
| | | Dt_LocationInfo srcLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); |
| | | //Dt_LocationInfo srcLocation = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.SourceAddress); |
| | | //srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | |
| | | |
| | |
| | | _unitOfWorkManage.CommitTran(); |
| | | //䏿宿ï¼åä¼ WMS |
| | | MESSendCMD sendcmd = new MESSendCMD { cmd = 201, task_id = task.TaskNum, status = 6 }; |
| | | string inparam = JsonConvert.SerializeObject(sendcmd); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºæ§è¡åºåºä»»å¡åä¼ MESå
¥å{inparam}"); |
| | | MESResponse res = ApiInvoke.SendTaskCMD(sendcmd); |
| | | if (res != null && res.code != 0) |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | content = WebResponseContent.Instance.Error($"å°å åæºå®æåºåºä»»å¡ååä¼ MES失败ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{res.message}ã"); |
| | | } |
| | | else |
| | | { |
| | | //夿æ¯å¦å®æçæåä¸å±ï¼èªå¨çæç©ºè½¦åºåºä»»å¡ |
| | | string[] Levels = task.Remark.Split("-"); |
| | | if (Levels.Length == 2) |
| | | { |
| | | if (!string.IsNullOrEmpty(Levels[0])&& !string.IsNullOrEmpty(Levels[1])) |
| | | { |
| | | //妿å½åæå屿°çäºæ»å±æï¼å表示æè½¦ææç屿°åå® |
| | | if(Convert.ToInt16(Levels[0])== Convert.ToInt16(Levels[1])) |
| | | { |
| | | string[] SourceCodes = task.SourceAddress.Split("-"); |
| | | string startPlan = ""; |
| | | if (SourceCodes.Length == 4) |
| | | { |
| | | startPlan= "101"+ SourceCodes[2].Substring(1,2); |
| | | } |
| | | DeliveryPlan send = new DeliveryPlan { startPlan = startPlan, isQuit = false, CarId = task.PalletCode }; |
| | | ApiInvoke.DeliveryPlanCMD(send);//åè°MESæ¥å£çæç©ºè½¦åºåºä»»å¡ |
| | | |
| | | } |
| | | |
| | | } |
| | | //else |
| | | //{ |
| | | // //夿æ¯å¦å®æçæåä¸å±ï¼èªå¨çæç©ºè½¦åºåºä»»å¡ |
| | | // string[] Levels = task.Remark.Split("-"); |
| | | // if (Levels.Length == 2) |
| | | // { |
| | | // if (!string.IsNullOrEmpty(Levels[0])&& !string.IsNullOrEmpty(Levels[1])) |
| | | // { |
| | | // //妿å½åæå屿°çäºæ»å±æï¼å表示æè½¦ææç屿°åå® |
| | | // if(Convert.ToInt16(Levels[0])== Convert.ToInt16(Levels[1])) |
| | | // { |
| | | // string[] SourceCodes = task.SourceAddress.Split("-"); |
| | | // string startPlan = ""; |
| | | // if (SourceCodes.Length == 4) |
| | | // { |
| | | // startPlan = "101" + SourceCodes[2].Substring(1, 2); |
| | | // } |
| | | // DeliveryPlan send = new DeliveryPlan { startPlan = startPlan, isQuit = false, CarId = task.PalletCode }; |
| | | // string inparam2 = JsonConvert.SerializeObject(send); |
| | | // ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºæ§è¡åºåºä»»å¡åä¼ MESå
¥å{inparam2}"); |
| | | // ApiInvoke.DeliveryPlanCMD(send);//åè°MESæ¥å£çæç©ºè½¦åºåºä»»å¡ |
| | | // ææç屿°é½åå®ï¼éè¦ææåä½ç¶ææ¹ä¸ºç©ºé²ç¶æ |
| | | // srcLocation.LocationStatus = (int)LocationStatusEnum.Free; |
| | | // _locationInfoRepository.UpdateData(srcLocation); |
| | | // } |
| | | |
| | | // } |
| | | |
| | | } |
| | | } |
| | | // } |
| | | //} |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"å°å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.StackTrace}ã"); |
| | | content = WebResponseContent.Instance.Error($"å°å åæºæ§è¡åºåºä»»å¡å¤±è´¥ï¼,ä»»å¡å·:ã{taskNum}ã,失败信æ¯:ã{ex.Message}ã"); |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"ä»»å¡ç±»åé误,æªæ¾å°è¯¥ä»»å¡ç±»å,ä»»å¡å·:ã{taskNum}ã,ä»»å¡ç±»å:ã{task.TaskType}ã"); |
| | | throw new Exception($"ä»»å¡ç±»åé误,æªæ¾å°è¯¥ä»»å¡ç±»å,ä»»å¡å·:ã{taskNum}ã,ä»»å¡ç±»å:ã{task.TaskType}ã"); |
| | | } |
| | | content = WebResponseContent.Instance.OK(); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"ä»»å¡å®ææå,ä»»å¡å·:ã{taskNum}ã"); |
| | | content = WebResponseContent.Instance.OK($"ä»»å¡å®ææå,ä»»å¡å·:ã{taskNum}ã"); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡å®æå¼å¸¸,ä»»å¡å·:ã{taskNum}ã"); |
| | | ServiceLogger.WriteDebug("StackCraneTaskCompleted", $"ä»»å¡å®æå¼å¸¸,ä»»å¡å·:ã{taskNum}ã{ex.Message}"); |
| | | content = WebResponseContent.Instance.Error($"ä»»å¡å®æå¼å¸¸,ä»»å¡å·:ã{taskNum}ã{ex.Message}"); |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ¢å¤æèµ·ä»»å¡ |
| | | /// </summary> |