| | |
| | | using System.Reflection; |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | | using WIDESEAWCS_Common.TaskEnum; |
| | | using WIDESEAWCS_Core; |
| | | using WIDESEAWCS_Core.Helper; |
| | | using WIDESEAWCS_ITaskInfoRepository; |
| | | using WIDESEAWCS_ITaskInfoService; |
| | | using WIDESEAWCS_Model.Models; |
| | | using WIDESEAWCS_QuartzJob; |
| | |
| | | public class CommonConveyorLineJob : JobBase, IJob, IDisposable |
| | | { |
| | | private readonly ITaskService _taskService; |
| | | private readonly ITaskRepository _taskRepository; |
| | | private readonly ITaskCZRepository _taskCZRepository; |
| | | private readonly ITaskExecuteDetailService _taskExecuteDetailService; |
| | | private readonly IRouterService _routerService; |
| | | private readonly IMapper _mapper; |
| | | |
| | | public CommonConveyorLineJob(ITaskService taskService, ITaskExecuteDetailService taskExecuteDetailService, IRouterService routerService, IMapper mapper) |
| | | public CommonConveyorLineJob(ITaskService taskService, ITaskExecuteDetailService taskExecuteDetailService, IRouterService routerService, IMapper mapper, ITaskRepository taskRepository, ITaskCZRepository taskCZRepository) |
| | | { |
| | | _taskService = taskService; |
| | | _taskExecuteDetailService = taskExecuteDetailService; |
| | | _routerService = routerService; |
| | | _mapper = mapper; |
| | | _taskRepository = taskRepository; |
| | | _taskCZRepository = taskCZRepository; |
| | | } |
| | | |
| | | public Task Execute(IJobExecutionContext context) |
| | | { |
| | | //Console.Out.WriteLine(DateTime.Now); |
| | | try |
| | | { |
| | | // ä»ä¸ä¸æä¸è·å JobParams 并转æ¢ä¸º CommonConveyorLine ç±»å |
| | | CommonConveyorLine conveyorLine = (CommonConveyorLine)context.JobDetail.JobDataMap.Get("JobParams"); |
| | | if (conveyorLine != null) |
| | | if (conveyorLine == null) |
| | | { |
| | | short[] values = conveyorLine.Communicator.Read<short>("DB2.0", 20); |
| | | |
| | | //bool result = conveyorLine.Communicator.Write("DB1.0", "AAABBB"); |
| | | //string testVal = conveyorLine.Communicator.Read<string>("DB1.0"); |
| | | |
| | | List<string> childDeviceCodes = _routerService.QueryAllPositions(conveyorLine.DeviceCode); |
| | | List<Task> tasks = new List<Task>(); |
| | | foreach (string childDeviceCode in childDeviceCodes) |
| | | { |
| | | //Task task = Task.Run(() => |
| | | //{ |
| | | ConveyorLineTaskCommand command = conveyorLine.ReadCustomer<ConveyorLineTaskCommand>(childDeviceCode); |
| | | if (command != null) |
| | | { |
| | | DeviceProtocolDetailDTO? deviceProtocolDetail = conveyorLine.DeviceProtocolDetailDTOs.FirstOrDefault(x => x.ProtocalDetailValue == command.InteractiveSignal.ToString() && x.DeviceProParamName == nameof(ConveyorLineTaskCommand.InteractiveSignal)); |
| | | if (deviceProtocolDetail != null) |
| | | { |
| | | MethodInfo? method = GetType().GetMethod(deviceProtocolDetail.ProtocolDetailType); |
| | | if (method != null) |
| | | { |
| | | method.Invoke(this, new object[] { conveyorLine, command, childDeviceCode }); |
| | | } |
| | | else |
| | | { |
| | | //todo æªæ¾å°æ¹æ³æ¶ |
| | | } |
| | | } |
| | | } |
| | | //}); |
| | | //tasks.Add(task); |
| | | } |
| | | |
| | | Task.WaitAll(tasks.ToArray()); |
| | | throw new Exception("JobParams ä¸å
å« CommonConveyorLine ç±»ååæ°"); |
| | | } |
| | | |
| | | // å®ä¹çº¿ä½å®çå
¥åºè¯·æ±çå°ååä»»å¡ç±»å |
| | | var requests = new Dictionary<string, string> |
| | | { |
| | | { "DB1002.293.0", "ZJXL-WLX002" }, |
| | | { "DB1002.1493.0", "FJXL-WLX002" } |
| | | }; |
| | | |
| | | foreach (var request in requests) |
| | | { |
| | | var isDownRequest = conveyorLine.Communicator.Read<bool>(request.Key); |
| | | if (!isDownRequest) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | string fromAdd = request.Value; |
| | | string taskType = request.Value.Contains("ZJXL") ? "æ£æ" : "è´æ"; |
| | | |
| | | // æ¥è¯¢æ¯å¦åå¨å·²çæçæ°ä»»å¡ |
| | | var task = _taskRepository.QueryFirst(x => x.SourceAddress == fromAdd && x.TaskState == (int)TaskInStatusEnum.InNew); |
| | | if (task != null) |
| | | { |
| | | ConsoleHelper.WriteInfoLine($"{nameof(CommonConveyorLineJob)}: {taskType}ä¸çº¿è¯·æ±å
¥åº,ä»»å¡å·²çæåå¨ï¼ç¨åéè¯......"); |
| | | continue; |
| | | } |
| | | |
| | | // æ¥è¯¢ä»»å¡ç±»å对åºçczTask |
| | | DtCZTask czTask = _taskCZRepository.QueryFirst(x => x.TaskType == taskType); |
| | | if (czTask == null) |
| | | { |
| | | ConsoleHelper.WriteInfoLine($"{nameof(CommonConveyorLineJob)}: {taskType}ä¸çº¿è¯·æ±å
¥åº,{taskType}ä»»å¡ä¸åå¨ï¼ç¨åéè¯......"); |
| | | continue; |
| | | } |
| | | |
| | | // å建æ°çä»»å¡å¹¶æ·»å å°ä»»å¡ä»åº |
| | | task = new Dt_Task() |
| | | { |
| | | TaskNum = _taskService.GetTaskNum(), |
| | | CreateDate = DateTime.Now, |
| | | Creater = "system", |
| | | CurrentAddress = fromAdd, |
| | | SourceAddress = fromAdd, |
| | | TaskState = (int)TaskInStatusEnum.InNew, |
| | | TaskType = (int)TaskOutboundTypeEnum.Outbound, |
| | | Grade = 1, |
| | | PalletCode = czTask.TaskProductCode, |
| | | TargetAddress = czTask.TaskEndAddress, |
| | | NextAddress = czTask.TaskEndAddress, |
| | | Roadway = $"{taskType}AGV", |
| | | WMSId = czTask.Id, |
| | | Remark = czTask.TaskOrderNo |
| | | }; |
| | | _taskRepository.AddData(task); |
| | | ConsoleHelper.WriteInfoLine($"{nameof(CommonConveyorLineJob)}: {taskType}ä¸çº¿è¯·æ±å
¥åº,ä»»å¡å·²çæï¼çå¾
æ§è¡......"); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | //Console.Out.WriteLine(nameof(CommonConveyorLineJob) + ":" + ex.ToString()); |
| | | // è®°å½å¼å¸¸ä¿¡æ¯ |
| | | // Console.Out.WriteLine(nameof(CommonConveyorLineJob) + ":" + ex.ToString()); |
| | | ConsoleHelper.WriteErrorLine($"{nameof(CommonConveyorLineJob)}: åçå¼å¸¸ - {ex.Message}"); |
| | | } |
| | | finally |
| | | { |
| | | // åè°è¯ä¿¡æ¯ |
| | | WriteDebug("CommonConveyorLineJob", "test"); |
| | | //Console.Out.WriteLine(DateTime.Now); |
| | | // Console.Out.WriteLine(DateTime.Now); |
| | | } |
| | | |
| | | return Task.CompletedTask; |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// è¾é线请æ±å
¥åº |
| | | /// </summary> |