一楼出库工位处理系统.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. using ServiceCenter.Logs;
  2. using ServiceCenter.Redis;
  3. using ServiceCenter.SqlSugars;
  4. using System.ComponentModel;
  5. using WCS.Core;
  6. using WCS.Entity;
  7. using WCS.WorkEngineering.Extensions;
  8. using WCS.WorkEngineering.WebApi.Controllers;
  9. using WCS.WorkEngineering.Worlds;
  10. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  11. namespace WCS.WorkEngineering.Systems
  12. {
  13. /// <summary>
  14. /// 出库站台交互
  15. /// </summary>
  16. [BelongTo(typeof(MainWorld))]
  17. [Description("一楼出库工位处理系统")]
  18. public class 一楼出库工位处理系统 : DeviceSystem<Station>
  19. {
  20. protected override bool ParallelDo => true;
  21. protected override bool SaveLogsToFile => true;
  22. public override void Do(Station obj)
  23. {
  24. var key = $"WCS:Lock:{obj.Entity.Code}";
  25. try
  26. {
  27. if (RedisHub.Default.Get(key) != null)
  28. {
  29. throw new KnownException($"[{obj.Entity.Code}]--触发并发管控", LogLevelEnum.High);
  30. }
  31. RedisHub.Default.Set(key, obj.Entity.Code);
  32. if (!obj.Data3.Status.HasFlag(Entity.Protocol.Station.StatusEunm.PH_Status) && !obj.Data3.Status.HasFlag(Entity.Protocol.Station.StatusEunm.OT_Status))
  33. {
  34. bool result = true; //是否需要申请出库任务,默认需要
  35. SqlSugarHelper.Do(db =>
  36. {
  37. //当前站台是否有任务在执行
  38. var task = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.AddrTo == obj.Entity.Code && v.Status < Entity.TaskStatus.AGVExecution).OrderByDescending(v => v.AddTime).First();
  39. if (db.Default.Queryable<WCS_TaskInfo>().Where(v => v.AddrTo == obj.Entity.Code && v.Status == Entity.TaskStatus.WaitingToExecute).Count() > 1) return;
  40. if (task != null && task.BusType == "一楼立库出空轮") //有任务
  41. {
  42. if (task.AgvTaskID == 0) throw new KnownException($"WCS任务[{task.ID}],等待AGV申请任务", LogLevelEnum.Mid);
  43. else
  44. {
  45. //检查对应的AGV任务状态是否大于退出储位状态
  46. var agv = db.Default.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).First(v => v.ID == task.ID) ?? throw new KnownException($"未找到AGV中间表任务[{task.AgvTaskID}],请检查异常原因", LogLevelEnum.Mid);
  47. if (agv == null)
  48. {
  49. }
  50. else if (agv.AgvStatus >= AGVTaskStatus.Complete3)
  51. {
  52. result = true;
  53. }
  54. else
  55. {
  56. result = false;
  57. }
  58. }
  59. }
  60. else //无任务
  61. {
  62. result = true;
  63. }
  64. });
  65. if (result) WmsApi.ApplyStockOutTask(obj.Entity.Code);
  66. }
  67. //下发满轮任务到agv
  68. else
  69. {
  70. SqlSugarHelper.Do(db =>
  71. {
  72. //当前站台是否有任务在执行
  73. var task = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.ID == obj.Data.TaskNumber && v.Status == Entity.TaskStatus.ConveyorExecution).First();
  74. if(task == null) throw new KnownException($"未找到wcs任务{obj.Data.TaskNumber},请检查光电或任务状态", LogLevelEnum.Low);
  75. if (task.BusType == "一楼出满轮" && task.AgvTaskID > 0)
  76. {
  77. var agvTask = db.Default.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).Where(v => v.ID == task.AgvTaskID).First();
  78. if (agvTask == null)
  79. {
  80. throw new KnownException($"未找到AGV中间表任务[{task.AgvTaskID}],请检查异常原因", LogLevelEnum.Mid);
  81. }
  82. var res = AgvApi.一楼满轮出库(task.BarCode, agvTask.Station,agvTask.Position, Guid.NewGuid().ToString().Replace("-", ""), "1");
  83. agvTask.Status = AGVTaskStatus.Confirm;
  84. agvTask.AgvID = res.data;
  85. db.Default.Updateable(agvTask).SplitTable(x => x.Take(2)).ExecuteCommand();
  86. //更新WCS数据
  87. task.Status = Entity.TaskStatus.AGVExecution;
  88. db.Default.Updateable(task).ExecuteCommand();
  89. task.AddWCS_TASK_DTL(db, task.Device, $"任务下发至AGV-AGV任务ID{agvTask.AgvID}");
  90. }
  91. });
  92. }
  93. }
  94. finally
  95. {
  96. RedisHub.Default.Del(key);
  97. }
  98. }
  99. public override bool Select(Device dev)
  100. {
  101. return dev.HasFlag(DeviceFlags.一楼出库口);
  102. }
  103. }
  104. }