| | |
| | | using Microsoft.AspNetCore.Authorization; |
| | | using Microsoft.AspNetCore.Http; |
| | | using Microsoft.AspNetCore.Mvc; |
| | | using System.Text; |
| | | using WIDESEA_DTO.Agv; |
| | | using WIDESEAWCS_Common.TaskEnum; |
| | | using WIDESEAWCS_Core; |
| | | using WIDESEAWCS_Core.Enums; |
| | | using WIDESEAWCS_Core.Helper; |
| | | using WIDESEAWCS_Core.LogHelper; |
| | | using WIDESEAWCS_DTO.Agv; |
| | | using WIDESEAWCS_IBasicInfoRepository; |
| | | using WIDESEAWCS_ITaskInfoRepository; |
| | | using WIDESEAWCS_ITaskInfoService; |
| | | using WIDESEAWCS_Model.Models; |
| | | using WIDESEAWCS_QuartzJob; |
| | | using WIDESEAWCS_QuartzJob.DTO; |
| | | using WIDESEAWCS_Tasks; |
| | | using static Dm.net.buffer.ByteArrayBuffer; |
| | | using WIDESEAWCS_Tasks.ConveyorLineJob; |
| | | using WIDESEAWCS_Tasks.DBNames; |
| | | |
| | | namespace WIDESEAWCS_Server.Controllers |
| | | { |
| | |
| | | //return _taskService.AgvSecureApply(secureApplyModel); |
| | | } |
| | | /// <summary> |
| | | /// æåæºç³è¯· AGV-WCS |
| | | /// </summary> |
| | | /// <param name="secureApplyModel"></param> |
| | | /// <returns></returns> |
| | | [HttpPost, HttpGet, Route("AgvHoisterApply"), AllowAnonymous] |
| | | public AgvResponse AgvHoisterApply([FromBody] AgvHoisterApplyDTO agvHoisterApplyDTO) |
| | | { |
| | | AgvResponse agvResponse = new AgvResponse(); |
| | | try |
| | | { |
| | | IDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceCode == agvHoisterApplyDTO.HoisterCode); |
| | | if (device == null) |
| | | { |
| | | return agvResponse.Error($"æªæ¾å°å¯¹åºè®¾å¤{agvHoisterApplyDTO.HoisterCode}"); |
| | | } |
| | | OtherDevice otherDevice = (OtherDevice)device; |
| | | //è·å设å¤åè®® |
| | | DeviceProDTO? deviceProRead = otherDevice.DeviceProDTOs.Where(x => x.DeviceChildCode == device.DeviceCode && x.DeviceProParamType == nameof(R_HoisterDB)).OrderBy(x => x.DeviceProOffset).FirstOrDefault(); |
| | | DeviceProDTO? deviceProWrite = otherDevice.DeviceProDTOs.Where(x => x.DeviceChildCode == device.DeviceCode && x.DeviceProParamType == nameof(W_HoisterDB)).OrderBy(x => x.DeviceProOffset).FirstOrDefault(); |
| | | if (deviceProRead == null || deviceProWrite == null) |
| | | { |
| | | return agvResponse.Error($"æªæ¾å°è®¾å¤{device.DeviceCode}åè®®"); |
| | | } |
| | | //è·å读åååå
¥ |
| | | R_HoisterInfo r_HoisterInfo = otherDevice.Communicator.ReadCustomer<R_HoisterInfo>(deviceProRead.DeviceProAddress); |
| | | W_HoisterInfo w_HoisterInfo = otherDevice.Communicator.ReadCustomer<W_HoisterInfo>(deviceProWrite.DeviceProAddress); |
| | | if (r_HoisterInfo == null || w_HoisterInfo == null) |
| | | { |
| | | return agvResponse.Error($"æªè¯»åå°è®¾å¤{device.DeviceCode}ä¿¡å·"); |
| | | } |
| | | if (r_HoisterInfo.R_HoisterSysStatus!=3) |
| | | { |
| | | return agvResponse.Error($"设å¤ç¶æä¸ä¸ºèªå¨"); |
| | | } |
| | | QuartzLogger.WriteLogToFile("Info_" + device.DeviceCode, $"r_HoisterInfo:{r_HoisterInfo.Serialize()}{Environment.NewLine}w_HoisterInfo:{w_HoisterInfo.Serialize()}{Environment.NewLine}"); |
| | | bool IsSuccess = false; |
| | | switch (agvHoisterApplyDTO.Request) |
| | | { |
| | | case "1": |
| | | //夿æåæºæ¯å¦å¨å½åå± å¦æå½åå±ï¼å
³é¨ç¶æï¼æ è´§å¾
å½ç´æ¥åå
¥å¼é¨ä¿¡å· |
| | | if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 2 && r_HoisterInfo.R_HoisterDoorStatus == 2) |
| | | { |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterDoorStatus, 1); |
| | | IsSuccess = true; |
| | | } |
| | | else if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 2 && r_HoisterInfo.R_HoisterDoorStatus == 1) |
| | | { |
| | | IsSuccess = true; |
| | | } |
| | | else if (r_HoisterInfo.R_HoisterCurrent != agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 2 && r_HoisterInfo.R_HoisterDoorStatus == 1) |
| | | { |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterDoorStatus, 2); |
| | | } |
| | | //夿æåæºä¸å¨å½åå± å¦æä¸å¨å½åå±ï¼å
³é¨ç¶æï¼æ è´§å¾
å½ç´æ¥åå
¥ç§»å¨å¼é¨ä¿¡å·(å½å) |
| | | else if (r_HoisterInfo.R_HoisterCurrent != agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 2 && r_HoisterInfo.R_HoisterDoorStatus == 2) |
| | | { |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterTarget, agvHoisterApplyDTO.CurrentLayer); |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterTask, 99); |
| | | } |
| | | return IsSuccess ? agvResponse.OK($"请æ±{agvHoisterApplyDTO.Request}æå,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}","1"): agvResponse.Error($"请æ±{agvHoisterApplyDTO.Request}失败,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}"); |
| | | case "2": |
| | | //夿æåæºæ¯å¦å¨å½åå± å¦æå½åå±ï¼å¼é¨ç¶æï¼æ è´§å¾
å½ æ¾è¡ |
| | | if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 2 && r_HoisterInfo.R_HoisterDoorStatus == 1) |
| | | { |
| | | IsSuccess = true; |
| | | } |
| | | return IsSuccess ? agvResponse.OK($"请æ±{agvHoisterApplyDTO.Request}æå,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}", "2") : agvResponse.Error($"请æ±{agvHoisterApplyDTO.Request}失败,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}"); |
| | | case "3": |
| | | //夿æåæºæ¯å¦å¨å½åå± å¦æå½åå±ï¼å¼é¨ç¶æï¼æè´§å¾
å½åå
¥å
³é¨ä¿¡å· |
| | | if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 1 && r_HoisterInfo.R_HoisterDoorStatus == 1 && w_HoisterInfo.W_HoisterDoorStatus!=2) |
| | | { |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterDoorStatus, 2); |
| | | } |
| | | //夿æåæºæ¯å¦å¨å½åå± å¦æå½åå±ï¼å
³é¨ç¶æï¼æè´§å¾
å½åå
¥ç§»å¨å¼é¨ä¿¡å·(ç®ç) |
| | | if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.CurrentLayer && r_HoisterInfo.R_HoisterLoadStatus == 1 && r_HoisterInfo.R_HoisterDoorStatus == 2) |
| | | { |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterTarget, agvHoisterApplyDTO.TargetLayer); |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterDoorStatus, 1); |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterTask, 99); |
| | | IsSuccess = true; |
| | | } |
| | | return IsSuccess ? agvResponse.OK($"请æ±{agvHoisterApplyDTO.Request}æå,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}", "3") : agvResponse.Error($"请æ±{agvHoisterApplyDTO.Request}失败,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}"); |
| | | case "4": |
| | | //夿æåæºæ¯å¦å¨ç®çå± å¦æç®çå±ï¼å¼é¨ç¶æï¼æè´§å¾
å½ æ¾è¡ |
| | | if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.TargetLayer && r_HoisterInfo.R_HoisterLoadStatus == 1 && r_HoisterInfo.R_HoisterDoorStatus == 1) |
| | | { |
| | | IsSuccess = true; |
| | | } |
| | | return IsSuccess ? agvResponse.OK($"请æ±{agvHoisterApplyDTO.Request}æå,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}", "4") : agvResponse.Error($"请æ±{agvHoisterApplyDTO.Request}失败,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}"); |
| | | case "5": |
| | | //夿æåæºæ¯å¦å¨ç®çå± å¦æç®çå±ï¼å¼é¨ç¶æï¼æ è´§å¾
å½åå
¥å
³é¨ä¿¡å· |
| | | if (r_HoisterInfo.R_HoisterCurrent == agvHoisterApplyDTO.TargetLayer && r_HoisterInfo.R_HoisterLoadStatus == 2 && r_HoisterInfo.R_HoisterDoorStatus == 1) |
| | | { |
| | | otherDevice.SetValue(W_HoisterDB.W_HoisterDoorStatus, 2); |
| | | IsSuccess = true; |
| | | } |
| | | return IsSuccess ? agvResponse.OK($"请æ±{agvHoisterApplyDTO.Request}æå,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}", "5") : agvResponse.Error($"请æ±{agvHoisterApplyDTO.Request}失败,ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}"); |
| | | default: |
| | | return agvResponse.Error($"æªæ¾å°å¯¹åºè¯·æ±,Request:{agvHoisterApplyDTO.Request}"); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | agvResponse.Error($"请æ±{agvHoisterApplyDTO.Request}失败,é误{ex.Message},ä»»å¡{agvHoisterApplyDTO.ReceiveTaskID}"); |
| | | } |
| | | return agvResponse; |
| | | } |
| | | /// <summary> |
| | | /// AGV任塿´æ°/宿 |
| | | /// </summary> |
| | | /// <param name="agvUpdateModel"></param> |