| | |
| | | Dt_Task taskOld = BaseDal.QueryFirst(x => x.PalletCode == containerFlowDTO.ContainerCode); |
| | | if (taskOld != null && taskOld.PalletCode == containerFlowDTO.ContainerCode && taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() && taskOld.TaskState == TaskStatusEnum.CL_Executing.ObjToInt() && taskOld.DeviceCode == deviceCode) |
| | | { |
| | | Thread.Sleep(500); |
| | | //Thread.Sleep(500); |
| | | return content.OK(); |
| | | } |
| | | if (taskOld != null && taskOld.PalletCode == containerFlowDTO.ContainerCode && taskOld.TaskType == TaskTypeEnum.Inbound.ObjToInt() && taskOld.TaskState == TaskStatusEnum.CL_Executing.ObjToInt() && taskOld.DeviceCode != deviceCode) |
| | |
| | | } |
| | | return content; |
| | | } |
| | | // å¨ç±»ä¸æ·»å éæé对象 |
| | | private static readonly object _taskCompleteLock = new object(); |
| | | |
| | | /// <summary> |
| | | /// ä»»å¡å®æ |
| | | /// </summary> |
| | |
| | | public WebResponseContent TaskCompleted(int taskNum) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | |
| | | // 使ç¨éç¡®ä¿åä¸ä»»å¡ä¸ä¼å¹¶åå¤ç |
| | | lock (_taskCompleteLock) |
| | | { |
| | | try |
| | | { |
| | | WriteLog.Write_Log("ä»»å¡å®æ", "ä»»å¡å®ææ¥å£", "ä»»å¡å·", $"ä»»å¡ï¼{taskNum}"); |
| | | |
| | | // 忬¡æ¥è¯¢ä»»å¡ç¶æï¼é²æ¢å¨éçå¾
æé´ä»»å¡ç¶æå·²æ¹å |
| | | Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | if (task == null) |
| | | { |
| | | return content.Error($"ä»»å¡{taskNum}ä¸åå¨"); |
| | | } |
| | | |
| | | // æ£æ¥ä»»å¡ç¶æï¼é¿å
éå¤å®æ |
| | | if (task.TaskState == TaskStatusEnum.Finish.ObjToInt()) |
| | | { |
| | | return content.Error($"ä»»å¡{taskNum}已宿ï¼è¯·å¿é夿ä½"); |
| | | } |
| | | |
| | | if (task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)//åºåºä»»å¡å®æé»è¾ |
| | | { |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.PalletCode == task.PalletCode); |
| | |
| | | } |
| | | return content; |
| | | } |
| | | } |
| | | ///// <summary> |
| | | ///// ä»»å¡å®æ |
| | | ///// </summary> |
| | | ///// <param name="taskNum"></param> |
| | | ///// <returns></returns> |
| | | //public WebResponseContent TaskCompleted(int taskNum) |
| | | //{ |
| | | // WebResponseContent content = new WebResponseContent(); |
| | | // try |
| | | // { |
| | | // WriteLog.Write_Log("ä»»å¡å®æ", "ä»»å¡å®ææ¥å£", "ä»»å¡å·", $"ä»»å¡ï¼{taskNum}"); |
| | | // Dt_Task task = BaseDal.QueryFirst(x => x.TaskNum == taskNum); |
| | | // if (task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup)//åºåºä»»å¡å®æé»è¾ |
| | | // { |
| | | // Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.PalletCode == task.PalletCode); |
| | | // if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | // { |
| | | // return content.Error($"{locationInfo.LocationCode}è´§ä½ç¶æä¸æ£ç¡®"); |
| | | // } |
| | | // task.TaskState = TaskStatusEnum.Finish.ObjToInt(); |
| | | // locationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt(); |
| | | // locationInfo.PalletCode = ""; |
| | | // //æç®±åºåºå®æä¸æ¥ç»WMS |
| | | // string? url = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.WMSInOutBoundBack.ToString())?.ApiAddress; |
| | | // if (string.IsNullOrEmpty(url)) |
| | | // { |
| | | // _taskExecuteDetailService.AddTaskExecuteDetail(task, $"æªæ¾å°WMSåºåºä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | // UpdateTaskExceptionMessage(taskNum, $"æªæ¾å°WMSåºåºä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | // return content.Error($"{taskNum},æªæ¾å°WMSåºåºä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | // } |
| | | // ContainerInFinishDTO containerInFinishDTO = new ContainerInFinishDTO() |
| | | // { |
| | | // TaskCode = task.TaskNum.ToString(), |
| | | // ContainerCode = task.PalletCode, |
| | | // StationCode = task.TargetAddress, |
| | | // LocationCode = task.SourceAddress, |
| | | // CompleteType = 1 |
| | | // }; |
| | | // string request = JsonConvert.SerializeObject(containerInFinishDTO, settings); |
| | | |
| | | // _unitOfWorkManage.BeginTran(); |
| | | // _locationInfoRepository.UpdateData(locationInfo); |
| | | // BaseDal.DeleteAndMoveIntoHty(task, App.User?.UserId == 0 ? OperateTypeEnum.èªå¨å®æ : OperateTypeEnum.äººå·¥å®æ); |
| | | // _unitOfWorkManage.CommitTran(); |
| | | // _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfo, LocationStatusEnum.Lock, LocationStatusEnum.Free, LocationChangeType.OutboundCompleted, task.TaskNum); |
| | | // //è°ç¨æ¥å£ |
| | | // string response = HttpHelper.Post(url, request); |
| | | // WriteLog.Write_Log("WMSåºåºä»»å¡å®æåä¼ ", "ä»»å¡å®ææ¥å£", "ä»»å¡ä¿¡æ¯", $"请æ±ï¼{request}ï¼åä¼ ï¼{response}"); |
| | | // WMSResponseContent wMSResponse = JsonConvert.DeserializeObject<WMSResponseContent>(response) ?? throw new Exception($"{taskNum},æªæ¥æ¶å°WMSåºåºä¸æ¥è¿åå¼"); |
| | | // if (wMSResponse.Code != "0") content.Message = $"åºåºä»»å¡{task.TaskNum}WMSåºåºä¸æ¥é误,ä¿¡æ¯:{wMSResponse.Msg}"; |
| | | // } |
| | | // else if (task != null && task.TaskType.GetTaskTypeGroup() == TaskTypeGroup.InboundGroup)//å
¥åºä»»å¡å®æé»è¾ |
| | | // { |
| | | // string? url = _apiInfoRepository.QueryFirst(x => x.ApiCode == APIEnum.WMSInOutBoundBack.ToString())?.ApiAddress; |
| | | // if (string.IsNullOrEmpty(url)) |
| | | // { |
| | | // _taskExecuteDetailService.AddTaskExecuteDetail(task, $"æªæ¾å°WMSå
¥åºä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | // UpdateTaskExceptionMessage(taskNum, $"æªæ¾å°WMSå
¥åºä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | // return content.Error($"{taskNum},æªæ¾å°WMSå
¥åºä¸æ¥æ¥å£,è¯·æ£æ¥æ¥å£é
ç½®"); |
| | | // } |
| | | // ContainerInFinishDTO containerInFinishDTO = new ContainerInFinishDTO() |
| | | // { |
| | | // TaskCode = task.TaskNum.ToString(), |
| | | // ContainerCode = task.PalletCode, |
| | | // StationCode = task.SourceAddress, |
| | | // LocationCode = task.TargetAddress, |
| | | // CompleteType = 2 |
| | | // }; |
| | | // string request = JsonConvert.SerializeObject(containerInFinishDTO, settings); |
| | | |
| | | // Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | // if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | // { |
| | | // return content.Error($"{locationInfo.LocationCode}è´§ä½ç¶æä¸æ£ç¡®"); |
| | | // } |
| | | // task.TaskState = TaskStatusEnum.Finish.ObjToInt(); |
| | | // locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); |
| | | // locationInfo.PalletCode = task.PalletCode; |
| | | // _unitOfWorkManage.BeginTran(); |
| | | // _locationInfoRepository.UpdateData(locationInfo); |
| | | // BaseDal.DeleteAndMoveIntoHty(task, App.User?.UserId == 0 ? OperateTypeEnum.èªå¨å®æ : OperateTypeEnum.äººå·¥å®æ); |
| | | // _unitOfWorkManage.CommitTran(); |
| | | // _locationStatusChangeRecordService.AddLocationStatusChangeRecord(locationInfo, LocationStatusEnum.Lock, LocationStatusEnum.InStock, LocationChangeType.InboundCompleted, task.TaskNum); |
| | | // //è°ç¨æ¥å£ |
| | | // string response = HttpHelper.Post(url, request); |
| | | // WriteLog.Write_Log("WMSå
¥åºä»»å¡å®æåä¼ ", "ä»»å¡å®ææ¥å£", "ä»»å¡ä¿¡æ¯", $"请æ±ï¼{request}ï¼åä¼ ï¼{response}"); |
| | | // WMSResponseContent wMSResponse = JsonConvert.DeserializeObject<WMSResponseContent>(response) ?? throw new Exception($"{taskNum},æªæ¥æ¶å°WMSå
¥åºä¸æ¥è¿åå¼"); |
| | | // if (wMSResponse.Code != "0") content.Message = $"å
¥åºä»»å¡{task.TaskNum}WMSå
¥åºä¸æ¥é误,ä¿¡æ¯:{wMSResponse.Msg}"; |
| | | // } |
| | | // content.OK("ä»»å¡å®æ"); |
| | | // } |
| | | // catch (Exception ex) |
| | | // { |
| | | // _unitOfWorkManage.RollbackTran(); |
| | | // content.Error(ex.Message); |
| | | // } |
| | | // return content; |
| | | //} |
| | | /// <summary> |
| | | /// 人工æå¨åæ¶æå®ä»»å¡ |
| | | /// </summary> |
| | |
| | | { |
| | | // è·åç®æ è´§ä½ |
| | | Dt_LocationInfo locationInfo = _locationInfoRepository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | if (locationInfo == null) return content.Error($"ç®æ è´§ä½{task.TargetAddress}ä¸åå¨"); |
| | | // éªè¯è´§ä½ç¶æ |
| | | if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | return content.Error($"{task.TargetAddress}è´§ä½ç¶æå¼å¸¸ï¼æ æ³åæ¶"); |
| | | |
| | | // æ¢å¤è´§ä½ç¶æ |
| | | if (locationInfo != null) |
| | | { |
| | | locationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt(); // æ¢å¤ä¸ºç©ºé²ç¶æ |
| | | locationInfo.PalletCode = ""; // æ¸
空æçå· |
| | | // æ´æ°æ°æ®åº |
| | | _unitOfWorkManage.BeginTran(); |
| | | _locationInfoRepository.UpdateData(locationInfo); |
| | | _unitOfWorkManage.CommitTran(); |
| | | content.OK("ä»»å¡åæ¶æå"); |
| | | } |
| | | _unitOfWorkManage.BeginTran(); |
| | | BaseDal.DeleteAndMoveIntoHty(task, OperateTypeEnum.人工å é¤); |
| | | _unitOfWorkManage.CommitTran(); |
| | | //return content.Error($"ç®æ è´§ä½{task.TargetAddress}ä¸åå¨"); |
| | | // éªè¯è´§ä½ç¶æ |
| | | //if (locationInfo.LocationStatus != LocationStatusEnum.Lock.ObjToInt()) |
| | | // return content.Error($"{task.TargetAddress}è´§ä½ç¶æå¼å¸¸ï¼æ æ³åæ¶"); |
| | | |
| | | // æ¢å¤è´§ä½ç¶æ |
| | | |
| | | // æ´æ°æ°æ®åº |
| | | //_unitOfWorkManage.BeginTran(); |
| | | //_locationInfoRepository.UpdateData(locationInfo); |
| | | //BaseDal.DeleteAndMoveIntoHty(task, OperateTypeEnum.人工å é¤); |
| | | //_unitOfWorkManage.CommitTran(); |
| | | // è®°å½ç¶æåæ´ |
| | | _locationStatusChangeRecordService.AddLocationStatusChangeRecord( |
| | | locationInfo, |
| | | LocationStatusEnum.Lock, |
| | | LocationStatusEnum.Free, |
| | | LocationChangeType.InboundCancelled, |
| | | task.TaskNum |
| | | ); |
| | | |
| | | content.OK("ä»»å¡åæ¶æå"); |
| | | } |
| | | else |