diff --git a/WcsMain/ApiClient/WMS/SendWmsTaskStatus.cs b/WcsMain/ApiClient/WMS/SendWmsTaskStatus.cs
index 28ea56d..a8a2ea7 100644
--- a/WcsMain/ApiClient/WMS/SendWmsTaskStatus.cs
+++ b/WcsMain/ApiClient/WMS/SendWmsTaskStatus.cs
@@ -71,6 +71,7 @@ public class SendWmsTaskStatus(AppWmsTaskDao wmsTaskDao, WmsBaseWebApi wmsWebApi
return;
}
ConsoleLog.Error($"【异常】发送WMS[任务异常]失败,WMS返回异常,任务号:{wmsTask.TaskId},载具号:{wmsTask.VehicleNo},参考信息:{responseObj.Message}");
+ return;
}
});
}
@@ -249,6 +250,7 @@ public class SendWmsTaskStatus(AppWmsTaskDao wmsTaskDao, WmsBaseWebApi wmsWebApi
return;
}
ConsoleLog.Error($"【异常】发送WMS[开始执行]失败,WMS返回异常,任务号:{wmsTask.TaskId},载具号:{wmsTask.VehicleNo},参考信息:{responseObj.Message}");
+ return;
}
});
}
@@ -309,6 +311,7 @@ public class SendWmsTaskStatus(AppWmsTaskDao wmsTaskDao, WmsBaseWebApi wmsWebApi
return;
}
ConsoleLog.Error($"【异常】发送WMS[任务完成]失败,WMS返回异常,任务号:{wmsTask.TaskId},载具号:{wmsTask.VehicleNo},参考信息:{responseObj.Message}");
+ return;
}
});
}
@@ -350,6 +353,7 @@ public class SendWmsTaskStatus(AppWmsTaskDao wmsTaskDao, WmsBaseWebApi wmsWebApi
return;
}
ConsoleLog.Error($"【异常】发送WMS[任务离开起始位置]失败,WMS返回异常,任务号:{wmsTask.TaskId},载具号:{wmsTask.VehicleNo},参考信息:{responseObj.Message}");
+ return;
}
});
}
diff --git a/WcsMain/ApiServe/Controllers/WmsController/WmsTaskController.cs b/WcsMain/ApiServe/Controllers/WmsController/WmsTaskController.cs
index 3d53ef1..3a972dc 100644
--- a/WcsMain/ApiServe/Controllers/WmsController/WmsTaskController.cs
+++ b/WcsMain/ApiServe/Controllers/WmsController/WmsTaskController.cs
@@ -22,7 +22,7 @@ public class WmsTaskController(WmsTaskService wmsTaskService) : ControllerBase
///
///
[HttpPost("setStackerTask")]
- public WmsApiResponse> GetStackerTask([FromBody] List request) => wmsTaskService.GetStackerTask(request);
+ public WmsApiResponse> GetStackerTask([FromBody] GetStackerRequest request) => wmsTaskService.GetStackerTask(request);
///
/// Wms向Wcs请求修改任务状态
diff --git a/WcsMain/ApiServe/Service/ContainerService/ContainerService.cs b/WcsMain/ApiServe/Service/ContainerService/ContainerService.cs
index fee8faa..cc280a4 100644
--- a/WcsMain/ApiServe/Service/ContainerService/ContainerService.cs
+++ b/WcsMain/ApiServe/Service/ContainerService/ContainerService.cs
@@ -4,11 +4,15 @@ using WcsMain.Constant.Enum.Stacker;
using WcsMain.DataBase.Dao;
using WcsMain.DataBase.TableEntity;
using WcsMain.Constant.WcsAttribute.AutoFacAttribute;
+using WcsMain.ApiClient.WMS;
+using WcsMain.ApiClient.WMS.Dto;
+using WcsMain.Common;
+using WcsMain.Constant.ExtendMethod;
namespace WcsMain.ApiServe.Service.ContainerService;
[Service]
-public class ContainerService(AppWmsTaskDao wmsTaskDao, WCSTaskExecuteEvent taskExecuteEvent)
+public class ContainerService(AppWmsTaskDao wmsTaskDao, WCSTaskExecuteEvent taskExecuteEvent, WmsBaseWebApi wmsBaseWebApi)
{
///
/// 请求四向车任务
@@ -23,13 +27,35 @@ public class ContainerService(AppWmsTaskDao wmsTaskDao, WCSTaskExecuteEvent task
return new() { Code = "400", Message = "缺少必须参数" };
}
List? wmsTasks = wmsTaskDao.Select(new() { VehicleNo = request.PalleetNo, TaskStatus = (int)WmsTaskStatusEnum.arriveMid })?.OrderByDescending(o => o.CreateTime).ToList();
- if(wmsTasks == null)
+ if (wmsTasks == null)
{
return new() { Code = "400", Message = "数据连接失败,请重试" };
}
- if(wmsTasks.Count == 0)
+ if (wmsTasks.Count == 0)
{
- return new() { Code = "400", Message = "该载具暂无待执行的任务" };
+ /* 请求WMS获取任务 */
+ ApplyInRequest applyInRequest = new()
+ {
+ Point = request.FormCellNo,
+ VehicleNo = request.PalleetNo,
+ };
+ var response = wmsBaseWebApi.HttpPost(applyInRequest, CommonData.AppApiBaseInfos.GetAddress("ApplyEnterApiAddress") ?? "");
+ if(response.IsSend && response.ResponseEntity != null && response.ResponseEntity.Code == 0)
+ {
+ int i = 0;
+ while(i < 5)
+ {
+ i++;
+ Thread.Sleep(1000);
+ wmsTasks = wmsTaskDao.Select(new() { VehicleNo = request.PalleetNo, TaskStatus = (int)WmsTaskStatusEnum.create })?.OrderByDescending(o => o.CreateTime).ToList();
+ if (wmsTasks == null || wmsTasks.Count < 1) continue;
+ break;
+ }
+ }
+ }
+ if(wmsTasks == default || wmsTasks.Count < 1)
+ {
+ return new() { Code = "400", Message = "无任务,请重试" };
}
AppWmsTask wmsTask = wmsTasks.First();
/* 更新状态为前往终点 */
diff --git a/WcsMain/ApiServe/Service/WmsService/WmsTaskService.cs b/WcsMain/ApiServe/Service/WmsService/WmsTaskService.cs
index bcc4dda..5119239 100644
--- a/WcsMain/ApiServe/Service/WmsService/WmsTaskService.cs
+++ b/WcsMain/ApiServe/Service/WmsService/WmsTaskService.cs
@@ -13,6 +13,7 @@ using WcsMain.Utils.Plugins;
using WcsMain.Constant.WcsAttribute.AutoFacAttribute;
using WcsMain.Constant.ExtendMethod;
using WcsMain.Common.DataService;
+using WcsMain.DataBase.MixDao;
namespace WcsMain.ApiServe.Service.WmsService;
@@ -27,70 +28,67 @@ public class WmsTaskService(WmsTaskAction wmsTaskAction, AppWmsTaskDao wmsTaskDa
///
///
///
- public WmsApiResponse> GetStackerTask(List request)
+ public WmsApiResponse> GetStackerTask(GetStackerRequest request)
{
- if (request.Count < 1 || request.Count > 20) return WmsApiResponseFactory.RequestErr>(null, "请求的任务数量只能在 1 至 20 范围内");
+ //if (request.Count < 1 || request.Count > 20) return WmsApiResponseFactory.RequestErr>(null, "请求的任务数量只能在 1 至 20 范围内");
List errRequest = []; // 存放错误的请求
/* 插入库存信息 */ // ---- 库存由WMS管理,数据库表也无需操作
List wmsTasks = [];
- foreach (var taskData in request)
+ /* 检验传入的数据格式 */
+ bool checkData = CheckData.CheckDataRules(request);
+ if (!checkData)
{
- /* 检验传入的数据格式 */
- bool checkData = CheckData.CheckDataRules(taskData);
- if (!checkData)
- {
- var errorRequest = ObjectCopy.CopyProperties(taskData);
- errRequest.Add(errorRequest);
- }
- /* 检验起点和终点是否正常 */
- if(taskData.TaskType == (int)WmsTaskTypeEnum.moveTask)
- {
- var existOringin = CommonData.AppLocations.ExistWmsLocation(taskData.Origin);
- var existDestination = CommonData.AppLocations.ExistWmsLocation(taskData.Destination);
- if (!existOringin || !existDestination)
- {
- var errorRequest = ObjectCopy.CopyProperties(taskData);
- errRequest.Add(errorRequest);
- }
- }
- else if(taskData.TaskType == (int)WmsTaskTypeEnum.inTask)
- {
- var existDestination = CommonData.AppLocations.ExistWmsLocation(taskData.Destination);
- if (!existDestination)
- {
- var errorRequest = ObjectCopy.CopyProperties(taskData);
- errRequest.Add(errorRequest);
- }
- }
- else if(taskData.TaskType == (int)WmsTaskTypeEnum.outTask)
- {
- var existOringin = CommonData.AppLocations.ExistWmsLocation(taskData.Origin);
- if (!existOringin)
- {
- var errorRequest = ObjectCopy.CopyProperties(taskData);
- errRequest.Add(errorRequest);
- }
- }
- /* 构造任务 */
- wmsTasks.Add(new AppWmsTask()
- {
- TaskId = taskData.TaskId,
- WcsId = dataBaseData.GetNewUUID2(),
- TaskType = taskData.TaskType,
- TaskStatus = (int)WmsTaskStatusEnum.create,
- Priority = taskData.Priority ?? -1,
- Origin = taskData.Origin,
- MidPoint = taskData.Midpoint,
- Destination = taskData.Destination,
- VehicleNo = taskData.VehicleNo,
- VehicleSize = taskData.VehicleSize ?? -1,
- Weight = taskData.Weight ?? -1,
- CreateTime = DateTime.Now,
- ModifyTime = DateTime.Now,
- CreatePerson = StaticString.WMS,
- });
+ var errorRequest = ObjectCopy.CopyProperties(request);
+ errRequest.Add(errorRequest);
}
- if(errRequest.Count > 0) // 如果有错误请求,则返回错误请求
+ ///* 检验起点和终点是否正常 */
+ //if (request.TaskType == (int)WmsTaskTypeEnum.moveTask)
+ //{
+ // var existOringin = CommonData.AppLocations.ExistWmsLocation(request.Origin);
+ // var existDestination = CommonData.AppLocations.ExistWmsLocation(request.Destination);
+ // if (!existOringin || !existDestination)
+ // {
+ // var errorRequest = ObjectCopy.CopyProperties(request);
+ // errRequest.Add(errorRequest);
+ // }
+ //}
+ //else if (request.TaskType == (int)WmsTaskTypeEnum.inTask)
+ //{
+ // var existDestination = CommonData.AppLocations.ExistWmsLocation(request.Destination);
+ // if (!existDestination)
+ // {
+ // var errorRequest = ObjectCopy.CopyProperties(request);
+ // errRequest.Add(errorRequest);
+ // }
+ //}
+ //else if (request.TaskType == (int)WmsTaskTypeEnum.outTask)
+ //{
+ // var existOringin = CommonData.AppLocations.ExistWmsLocation(request.Origin);
+ // if (!existOringin)
+ // {
+ // var errorRequest = ObjectCopy.CopyProperties(request);
+ // errRequest.Add(errorRequest);
+ // }
+ //}
+ /* 构造任务 */
+ wmsTasks.Add(new AppWmsTask()
+ {
+ TaskId = request.TaskId,
+ WcsId = dataBaseData.GetNewUUID2(),
+ TaskType = request.TaskType,
+ TaskStatus = (int)WmsTaskStatusEnum.create,
+ Priority = request.Priority ?? -1,
+ Origin = request.Origin,
+ MidPoint = request.Midpoint,
+ Destination = request.Destination,
+ VehicleNo = request.VehicleNo,
+ VehicleSize = request.VehicleSize ?? -1,
+ Weight = request.Weight ?? -1,
+ CreateTime = DateTime.Now,
+ ModifyTime = DateTime.Now,
+ CreatePerson = StaticString.WMS,
+ });
+ if (errRequest.Count > 0) // 如果有错误请求,则返回错误请求
{
return WmsApiResponseFactory.RequestErr(errRequest, "请求的任务数据存在异常");
}
diff --git a/WcsMain/CirculationJob/Stacker/ExecuteWmsTask.cs b/WcsMain/CirculationJob/Stacker/ExecuteWmsTask.cs
index 88a58fb..b86d2cb 100644
--- a/WcsMain/CirculationJob/Stacker/ExecuteWmsTask.cs
+++ b/WcsMain/CirculationJob/Stacker/ExecuteWmsTask.cs
@@ -215,7 +215,9 @@ public class ExecuteWmsTask(AppWmsTaskDao wmsTaskDao, StackerConveyOperation sta
if (liftInfo.LiftMode != 2) continue;
}
/* 获取这个站台的任务.没有占用任务即可重新使用 */
- List? tasks = wmsTaskDao.Select(new() { MidPoint = liftInfo.Tag, TaskStatus = (int)WmsTaskStatusEnum.toMid });
+ List tasks = [];
+ tasks.AddRange(wmsTaskDao.Select(new() { MidPoint = liftInfo.Tag!.Split(',')[0], TaskStatus = (int)WmsTaskStatusEnum.toMid }) ?? []);
+ tasks.AddRange(wmsTaskDao.Select(new() { MidPoint = liftInfo.Tag!.Split(',')[1], TaskStatus = (int)WmsTaskStatusEnum.toMid }) ?? []);
if (tasks == default || tasks.Count > 0) continue;
string location = "";
if (!string.IsNullOrEmpty(liftInfo.Tag))
@@ -253,7 +255,9 @@ public class ExecuteWmsTask(AppWmsTaskDao wmsTaskDao, StackerConveyOperation sta
if (liftInfo.LiftMode == 2) continue;
}
/* 获取这个站台的任务.并计数 */
- List? tasks = wmsTaskDao.Select(new() { MidPoint = liftInfo.Tag, TaskStatus = (int)WmsTaskStatusEnum.toMid });
+ List tasks = [];
+ tasks.AddRange(wmsTaskDao.Select(new() { MidPoint = liftInfo.Tag!.Split(',')[0], TaskStatus = (int)WmsTaskStatusEnum.toMid }) ?? []);
+ tasks.AddRange(wmsTaskDao.Select(new() { MidPoint = liftInfo.Tag!.Split(',')[1], TaskStatus = (int)WmsTaskStatusEnum.toMid }) ?? []);
if (tasks == default) continue;
string location = "";
if(!string.IsNullOrEmpty(liftInfo.Tag))
diff --git a/WcsMain/DataBase/Dao/AppWmsTaskDao.cs b/WcsMain/DataBase/Dao/AppWmsTaskDao.cs
index 7242f21..7224005 100644
--- a/WcsMain/DataBase/Dao/AppWmsTaskDao.cs
+++ b/WcsMain/DataBase/Dao/AppWmsTaskDao.cs
@@ -88,6 +88,7 @@ public class AppWmsTaskDao
.WhereIF(appWmsTask.TaskType != null, w => w.TaskType == appWmsTask.TaskType)
.WhereIF(appWmsTask.TaskStatus != null, w => w.TaskStatus == appWmsTask.TaskStatus)
.WhereIF(!string.IsNullOrEmpty(appWmsTask.Origin), w => w.Origin == appWmsTask.Origin)
+ .WhereIF(!string.IsNullOrEmpty(appWmsTask.MidPoint), w => w.MidPoint == appWmsTask.MidPoint)
.WhereIF(!string.IsNullOrEmpty(appWmsTask.Destination),
w => w.Destination == appWmsTask.Destination)
.WhereIF(!string.IsNullOrEmpty(appWmsTask.VehicleNo), w => w.VehicleNo == appWmsTask.VehicleNo)
diff --git a/WcsMain/Properties/PublishProfiles/FolderProfile2.pubxml.user b/WcsMain/Properties/PublishProfiles/FolderProfile2.pubxml.user
index 66e4029..8758d70 100644
--- a/WcsMain/Properties/PublishProfiles/FolderProfile2.pubxml.user
+++ b/WcsMain/Properties/PublishProfiles/FolderProfile2.pubxml.user
@@ -5,7 +5,7 @@ https://go.microsoft.com/fwlink/?LinkID=208121.
<_PublishTargetUrl>F:\A开发项目\A菲达宝开项目\2024-08_上汽试制仓\应用程序\WcsService\WcsMain\bin\Release\net8.0\publish\
- True|2024-11-20T09:08:23.7162943Z||;True|2024-11-20T16:54:01.3629057+08:00||;True|2024-11-20T16:40:49.6894280+08:00||;True|2024-11-20T16:37:47.3670812+08:00||;False|2024-11-20T16:37:04.0777763+08:00||;True|2024-11-20T16:25:26.3145915+08:00||;True|2024-11-20T16:10:13.7558526+08:00||;True|2024-11-20T16:07:37.8681228+08:00||;True|2024-11-20T15:55:28.7196074+08:00||;True|2024-11-20T15:52:40.6653904+08:00||;True|2024-11-20T15:30:21.5138564+08:00||;True|2024-11-20T15:24:40.6286995+08:00||;True|2024-11-18T21:16:47.1821173+08:00||;True|2024-11-18T21:14:40.1209255+08:00||;True|2024-11-18T21:11:32.0010536+08:00||;True|2024-11-18T21:10:56.2142485+08:00||;True|2024-11-18T20:59:50.6846634+08:00||;True|2024-11-16T14:31:14.2653894+08:00||;True|2024-11-16T14:16:17.4271635+08:00||;True|2024-11-16T14:16:08.1284507+08:00||;True|2024-11-16T14:08:02.8639352+08:00||;True|2024-11-16T14:07:06.6785776+08:00||;True|2024-11-16T13:14:33.8282571+08:00||;True|2024-11-16T13:14:09.9233077+08:00||;True|2024-11-16T12:49:45.5891890+08:00||;True|2024-11-16T12:19:05.5997384+08:00||;True|2024-11-16T11:49:43.2660430+08:00||;True|2024-11-16T11:49:12.7318514+08:00||;True|2024-11-16T11:43:41.8128931+08:00||;True|2024-11-16T10:39:25.1387254+08:00||;True|2024-11-16T10:24:19.4879139+08:00||;True|2024-11-15T17:47:10.4630939+08:00||;True|2024-11-15T17:42:25.6985733+08:00||;True|2024-11-15T17:39:43.9409305+08:00||;True|2024-11-15T17:26:18.2886475+08:00||;True|2024-11-15T17:23:05.3112513+08:00||;True|2024-11-15T17:16:40.2960771+08:00||;True|2024-11-15T17:14:12.3416383+08:00||;True|2024-11-15T17:09:43.2642034+08:00||;True|2024-11-15T17:05:04.4694932+08:00||;False|2024-11-15T17:04:34.2335564+08:00||;False|2024-11-15T17:04:12.5281280+08:00||;True|2024-11-15T17:01:49.4325408+08:00||;False|2024-11-15T17:01:29.1872712+08:00||;True|2024-11-15T16:00:18.8617729+08:00||;True|2024-11-15T15:56:13.9285180+08:00||;True|2024-11-15T15:50:53.6121456+08:00||;True|2024-11-15T15:17:41.0508047+08:00||;True|2024-11-15T13:50:06.8021767+08:00||;True|2024-11-15T13:17:48.2695650+08:00||;True|2023-12-21T15:04:28.6290873+08:00||;True|2023-12-21T14:59:03.4454135+08:00||;True|2023-12-21T14:51:08.6690406+08:00||;True|2023-12-21T14:26:42.6801144+08:00||;False|2023-12-21T14:26:14.3256943+08:00||;True|2023-12-21T14:13:42.5511801+08:00||;True|2023-12-21T13:56:38.5871005+08:00||;True|2023-12-19T12:19:57.9900187+08:00||;True|2023-12-19T11:53:33.6930379+08:00||;True|2023-12-17T12:51:32.6510827+08:00||;False|2023-12-17T12:49:32.9022541+08:00||;
+ True|2024-11-21T08:33:23.0082958Z||;True|2024-11-21T16:21:46.1852307+08:00||;True|2024-11-21T13:56:06.5543719+08:00||;True|2024-11-21T11:41:50.4634584+08:00||;True|2024-11-21T11:30:54.9747290+08:00||;False|2024-11-21T11:30:18.2738127+08:00||;True|2024-11-21T10:45:42.5524544+08:00||;True|2024-11-20T17:08:23.7162943+08:00||;True|2024-11-20T16:54:01.3629057+08:00||;True|2024-11-20T16:40:49.6894280+08:00||;True|2024-11-20T16:37:47.3670812+08:00||;False|2024-11-20T16:37:04.0777763+08:00||;True|2024-11-20T16:25:26.3145915+08:00||;True|2024-11-20T16:10:13.7558526+08:00||;True|2024-11-20T16:07:37.8681228+08:00||;True|2024-11-20T15:55:28.7196074+08:00||;True|2024-11-20T15:52:40.6653904+08:00||;True|2024-11-20T15:30:21.5138564+08:00||;True|2024-11-20T15:24:40.6286995+08:00||;True|2024-11-18T21:16:47.1821173+08:00||;True|2024-11-18T21:14:40.1209255+08:00||;True|2024-11-18T21:11:32.0010536+08:00||;True|2024-11-18T21:10:56.2142485+08:00||;True|2024-11-18T20:59:50.6846634+08:00||;True|2024-11-16T14:31:14.2653894+08:00||;True|2024-11-16T14:16:17.4271635+08:00||;True|2024-11-16T14:16:08.1284507+08:00||;True|2024-11-16T14:08:02.8639352+08:00||;True|2024-11-16T14:07:06.6785776+08:00||;True|2024-11-16T13:14:33.8282571+08:00||;True|2024-11-16T13:14:09.9233077+08:00||;True|2024-11-16T12:49:45.5891890+08:00||;True|2024-11-16T12:19:05.5997384+08:00||;True|2024-11-16T11:49:43.2660430+08:00||;True|2024-11-16T11:49:12.7318514+08:00||;True|2024-11-16T11:43:41.8128931+08:00||;True|2024-11-16T10:39:25.1387254+08:00||;True|2024-11-16T10:24:19.4879139+08:00||;True|2024-11-15T17:47:10.4630939+08:00||;True|2024-11-15T17:42:25.6985733+08:00||;True|2024-11-15T17:39:43.9409305+08:00||;True|2024-11-15T17:26:18.2886475+08:00||;True|2024-11-15T17:23:05.3112513+08:00||;True|2024-11-15T17:16:40.2960771+08:00||;True|2024-11-15T17:14:12.3416383+08:00||;True|2024-11-15T17:09:43.2642034+08:00||;True|2024-11-15T17:05:04.4694932+08:00||;False|2024-11-15T17:04:34.2335564+08:00||;False|2024-11-15T17:04:12.5281280+08:00||;True|2024-11-15T17:01:49.4325408+08:00||;False|2024-11-15T17:01:29.1872712+08:00||;True|2024-11-15T16:00:18.8617729+08:00||;True|2024-11-15T15:56:13.9285180+08:00||;True|2024-11-15T15:50:53.6121456+08:00||;True|2024-11-15T15:17:41.0508047+08:00||;True|2024-11-15T13:50:06.8021767+08:00||;True|2024-11-15T13:17:48.2695650+08:00||;True|2023-12-21T15:04:28.6290873+08:00||;True|2023-12-21T14:59:03.4454135+08:00||;True|2023-12-21T14:51:08.6690406+08:00||;True|2023-12-21T14:26:42.6801144+08:00||;False|2023-12-21T14:26:14.3256943+08:00||;True|2023-12-21T14:13:42.5511801+08:00||;True|2023-12-21T13:56:38.5871005+08:00||;True|2023-12-19T12:19:57.9900187+08:00||;True|2023-12-19T11:53:33.6930379+08:00||;True|2023-12-17T12:51:32.6510827+08:00||;False|2023-12-17T12:49:32.9022541+08:00||;
\ No newline at end of file