分支自 SuZhouGuanHong/TaiYuanTaiZhong

huanghongfeng
2024-07-15 a765da90e5ee63e04d2d8460a5ad1ebd0e8eb4db
´úÂë¹ÜÀí/WMS/WMS_Server/WIDESEA_WMS/Common/AGVTask/HandleTask_Mes.cs
@@ -1,93 +1,153 @@
using Newtonsoft.Json;
using Confluent.Kafka;
using Newtonsoft.Json;
using OfficeOpenXml.FormulaParsing.Excel.Functions.Text;
using OfficeOpenXml.FormulaParsing.Excel.Operators;
using WIDESEA_Comm.LogInfo;
using WIDESEA_Comm.MES_Info;
using WIDESEA_Comm.MES_Info.Request;
using WIDESEA_Common;
using WIDESEA_Core.EFDbContext;
using WIDESEA_Core.FreeDB;
using WIDESEA_Entity.DomainModels;
using WIDESEA_Entity.ToAGV;
using WIDESEA_WMS.IRepositories;
using WIDESEA_WMS.Repositories;
using static WIDESEA_Comm.MES_Info.BasicSN;
namespace WIDESEA_WMS.Common.AGVTask
{
    public class HandleTask_Mes
    {
        public void UploadMESInfo(dt_agvtask task)
        static FreeDB FreeDB = new FreeDB();
        /// <summary>
        /// å‘MES反馈出入库信息
        /// </summary>
        /// <param name="task"></param>
        /// <exception cref="Exception"></exception>
        public static void UploadMESInfo(dt_agvtask task)
        {
            object obj = new object();  //上传MES数据
            string ActionName = "";  //调用MES方法名
            string name = "";
            MES_Response requestMes = new MES_Response();
            try
            {
                object obj = new object();  //上传MES数据
                string ActionName = "";  //调用MES方法名
                List<detail> list = new List<detail>(); //车轮信息
                if (task == null)
                {
                    throw new Exception("无任务数据");
                }
                foreach (var item in task.bindSN.Split(","))
                VOLContext context = new VOLContext();
                IVV_Mes_WorkinfoRepository workinfoRepository = new VV_Mes_WorkinfoRepository(context);
                Idt_info_to_mesRepository mesRepository = new dt_info_to_mesRepository(context);
                if (task.agv_tasktype == AGVTaskTypeEnum.TaskType_Outbound.ToString() || task.agv_tasktype == AGVTaskTypeEnum.TaskType_OutsourceCarry.ToString())
                {
                    detail detail = new detail();
                    detail.sn = item;
                    list.Add(detail);
                }
                if (task.agv_tasktype == AGVTaskTypeEnum.TaskType_Outbound.ToString() || task.agv_tasktype == AGVTaskTypeEnum.TaskType_OutsourceOutbound.ToString())
                {
                    agvOutWarehousePara outWarehousePara = new agvOutWarehousePara()
                    if (task.agv_tasktype == AGVTaskTypeEnum.TaskType_Outbound.ToString())
                    {
                        JobID = task.jobID,
                        details = list
                        foreach (var item in task.bindSN.Split(","))
                        {
                            var work = workinfoRepository.Find(x => x.SN == item && x.processCode == task.agv_worktype.ToString()).FirstOrDefault();
                            detail detail = new detail();
                            detail.sn = item;
                            detail.jobID = work.jobID;
                            detail.processCode = work.processCode;
                            list.Add(detail);
                        }
                    }
                    else
                    {
                        foreach (var item in task.bindSN.Split(","))
                        {
                            detail detail = new detail();
                            detail.sn = item;
                            detail.jobID = task.jobID;
                            detail.processCode = task.agv_worktype.ToString();
                            list.Add(detail);
                        }
                    }
                    agvInWarehousePara outWarehousePara = new agvInWarehousePara()
                    {
                        WorkOrder = task.jobID,
                        zoneID = task.agv_fromaddress,
                        details = list,
                        layerNo = 1,
                        stackID = "1",
                        warehouseName = "Agv库",
                        Operator = "AGV自动",
                    };
                    obj = outWarehousePara;
                    ActionName = "agvOutWarehouse";
                    ActionName = "agvOutWarehouse";//AGV->MES车轮出库
                    name = "AGV同步MES车轮出库";
                }
                else if (task.agv_tasktype == AGVTaskTypeEnum.TaskType_Inbound.ToString() || task.agv_tasktype == AGVTaskTypeEnum.TaskType_OutsourceInbound.ToString())
                else if (task.agv_tasktype == AGVTaskTypeEnum.TaskType_Inbound.ToString())
                {
                    foreach (var item in task.bindSN.Split(","))
                    {
                        var work = workinfoRepository.Find(x => x.SN == item && x.processCode == task.agv_worktype.ToString()).FirstOrDefault();
                        detail detail = new detail();
                        detail.sn = item;
                        detail.jobID = work.jobID;
                        detail.processCode = work.processCode;
                        list.Add(detail);
                    }
                    agvInWarehousePara inWarehousePara = new agvInWarehousePara()
                    {
                        details = list,
                        JobID = task.jobID,
                        layerNo = 1,
                        stackID = task.agv_barcode,
                        warehouseName = "Agv库",
                        WorkOrder = task.jobID,
                        zoneID = task.agv_toaddress,
                        details = list,
                        layerNo = 1,
                        stackID = "1",
                        warehouseName = "Agv库",
                        Operator = "AGV自动",
                    };
                    obj = inWarehousePara;
                    ActionName = "agvInWarehouse";
                    ActionName = "agvInWarehouse";//AGV->MES车轮入库
                    name = "AGV同步MES车轮入库";
                }
                else if (task.agv_tasktype == "Transfer")  //移库区分  åº“内移库/外协移库
                else if (task.agv_tasktype == AGVTaskTypeEnum.TaskType_Carry.ToString())  //移库区分  åº“内移库
                {
                    List<detail1> list1 = new List<detail1>(); //车轮信息
                    foreach (var item in task.bindSN.Split(","))
                    {
                        detail1 detail = new detail1();
                        detail.sn = item;
                        list1.Add(detail);
                    }
                    agvMoveWarehousePara moveWarehousePara = new agvMoveWarehousePara()
                    {
                        details = list,
                        fromLayerNo = "1",
                        fromStackID = "",
                        fromWarehouseName = "Agv库",
                        fromZoneID = task.agv_fromaddress,
                        toLayerNo = "1",
                        toStackID = "",
                        toWarehouseName = "Agv库",
                        toZoneID = task.agv_toaddress,
                        details = list1,
                        fromLayerNo = "1",
                        fromStackID = "1",
                        fromWarehouseName = "Agv库",
                        toLayerNo = "1",
                        toStackID = "1",
                        toWarehouseName = "Agv库",
                        Operator = "AGV自动",
                    };
                    obj = moveWarehousePara;
                    ActionName = "agvMoveWarehouse";
                    ActionName = "agvMoveWarehouse";//AGV->MES车轮移库
                    name = "AGV同步MES车轮AB库移库";
                }
                //else if (task.agv_tasktype == "Transfer")
                //{
                //}
                var postJson = JsonConvert.SerializeObject(obj);
                string mesData = Request.RequestData(postJson, MESAPIAddress.IPAddress_MES + ActionName);
                var requestMes = JsonConvert.DeserializeObject<MES_Response>(mesData);
                if (requestMes.code == "200" && requestMes.Type == "success")
                if (!string.IsNullOrEmpty(ActionName))
                {
                    //日志记录上传数据成功
                    dt_info_to_mes info_To_Mes = new dt_info_to_mes()
                    {
                        Info = postJson,
                        ActionName = ActionName,
                        Createtime = DateTime.Now,
                        Remark = name,
                        State = false
                    };
                    mesRepository.Add(info_To_Mes, true);
                }
            }
            catch (Exception ex)
            {
                throw new Exception(ex.Message);
            }
        }
    }