using System.Diagnostics; using Aop.Api.Domain; using JNPF; using JNPF.Common.Const; using JNPF.Common.Core.Manager; using JNPF.Common.Enums; using JNPF.Common.Extension; using JNPF.Common.Security; using JNPF.DataEncryption; using JNPF.DependencyInjection; using JNPF.DynamicApiController; using JNPF.Extras.CollectiveOAuth.Models; using JNPF.Extras.CollectiveOAuth.Utils; using JNPF.FriendlyException; using JNPF.Logging; using JNPF.Systems.Entitys.Permission; using JNPF.Systems.Entitys.System; using JNPF.Systems.Interfaces.Permission; using JNPF.Systems.Interfaces.System; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Newtonsoft.Json; using SQLitePCL; using SqlSugar; using SqlSugar.Extensions; using Tnb.BasicData.Entities; using Tnb.Common.Redis; using Tnb.WarehouseMgr.Interfaces; using Tnb.WarehouseMgr.Entities.Dto.Inputs; using Tnb.WarehouseMgr.Entities.Consts; using Tnb.WarehouseMgr.Entities.Dto.Outputs; using Result = Tnb.WarehouseMgr.Entities.Dto.Outputs.Result; using Tnb.BasicData; using Tnb.EquipMgr.Entities; using Tnb.WarehouseMgr; using Tnb.WarehouseMgr.Entities; using Tnb.ProductionMgr.Entities; using Tnb.ProductionMgr.Interfaces; using Tnb.ProductionMgr.Entities.Dto.PrdManage; using Tnb.ProductionMgr.Entities.Entity; using Tnb.ProductionMgr.Entities.Entity.ErpEntity; namespace Tnb.ProductionMgr { [ApiDescriptionSettings(Tag = ModuleConst.Tag, Area = ModuleConst.Area, Order = 700)] [Route("api/[area]/[controller]/[action]")] public class TimeWorkService : IDynamicApiController, ITransient { private readonly ISqlSugarRepository _repository; private readonly ISqlSugarClient _db; private readonly IOrganizeService _organizeService; private readonly IBillRullService _billRullService; private readonly RedisData _redisData; private readonly IWmsEmptyOutstockService _wmsEmptyOutstockService; private readonly IWareHouseService _wareHouseService; private readonly IPrdMoTaskService _prdMoTaskService; public TimeWorkService( RedisData redisData, ISqlSugarRepository repository, IBillRullService billRullService, IOrganizeService organizeService, IWmsEmptyOutstockService wmsEmptyOutstockService, IPrdMoTaskService prdMoTaskService, IWareHouseService wareHouseService ) { _redisData = redisData; _repository = repository; _db = repository.AsSugarClient(); _organizeService = organizeService; _billRullService = billRullService; _wmsEmptyOutstockService = wmsEmptyOutstockService; _wareHouseService = wareHouseService; _prdMoTaskService = prdMoTaskService; } [HttpGet] [AllowAnonymous] public async Task test() { var db = _repository.AsSugarClient(); await db.Ado.BeginTranAsync(); BasUnit basUnit = new BasUnit(); basUnit.id = SnowflakeIdHelper.NextId(); basUnit.unit_name = "aaa"; basUnit.unit_code = "bbb"; await db.Insertable(basUnit).ExecuteCommandAsync(); await db.Ado.CommitTranAsync(); await db.Ado.BeginTranAsync(); BasUnit basUnit2 = new BasUnit(); basUnit2.id = SnowflakeIdHelper.NextId(); basUnit2.unit_name = "ccc"; basUnit2.unit_code = "ddd"; await db.Insertable(basUnit2).ExecuteCommandAsync(); await db.Ado.CommitTranAsync(); return Task.CompletedTask; } /// /// 注塑空载具出库 /// /// [HttpGet] [AllowAnonymous] public async Task EmptyCarryOutStk() { string state = await _redisData.TryGetValueByKeyField("YTCS", "State"); if ("OK" != state) return "YTCS没开机"; string result = ""; bool? cs01 = await _redisData.TryGetValueByKeyField("YTCS", "CallCtuEmptyIn_CS01"); bool? cs03 = await _redisData.TryGetValueByKeyField("YTCS", "CallCtuEmptyIn_CS03"); bool? cs06 = await _redisData.TryGetValueByKeyField("YTCS", "CallCtuEmptyIn_CS06"); bool? wbzxx1 = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x1_AGV_fan"); bool? wbzxx2 = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x2_AGV_fan"); // bool cs01Flag = _redisData.Get("YTCS_CallCtuEmptyIn_CS01_flag"); // bool cs03Flag = _redisData.Get("YTCS_CallCtuEmptyIn_CS03_flag"); // bool cs06Flag = _redisData.Get("YTCS_CallCtuEmptyIn_CS06_flag"); List statusList = new List(){WmsWareHouseConst.PRETASK_BILL_STATUS_DXF_ID,WmsWareHouseConst.PRETASK_BILL_STATUS_YXF_ID,WmsWareHouseConst.PRETASK_BILL_STATUS_START_ID}; bool cs01Flag = await _db.Queryable().AnyAsync(x => x.endlocation_code == "SSX-021-001" && statusList.Contains(x.status) ); bool cs03Flag = await _db.Queryable().AnyAsync(x => x.endlocation_code == "SSX-021-003" && statusList.Contains(x.status) ); bool cs06Flag = await _db.Queryable().AnyAsync(x => x.endlocation_code == "SSX-011-006" && statusList.Contains(x.status) ); bool wbzxx1Flag = await _db.Queryable().AnyAsync(x => x.endlocation_code == "ZZ-01-01" && statusList.Contains(x.status) ); bool wbzxx2Flag = await _db.Queryable().AnyAsync(x => x.endlocation_code == "ZZ-02-01" && statusList.Contains(x.status) ); Log.Information($"空箱入呼叫cs01值{(cs01==null ? "null" : cs01.ToString())},cs03值{(cs03==null ? "null" : cs03.ToString())},cs06值{(cs06==null ? "null" : cs06.ToString())}"); if (cs01Flag) { Log.Information($"【EmptyCarryOutStk】ctu1空箱入呼叫存在未完成的预任务,跳过此次自动呼叫"); } if (cs03Flag) { Log.Information($"【EmptyCarryOutStk】ctu3空箱入呼叫存在未完成的预任务,跳过此次自动呼叫"); } if (cs06Flag) { Log.Information($"【EmptyCarryOutStk】ctu6空箱入呼叫存在未完成的预任务,跳过此次自动呼叫"); } if (wbzxx1Flag) { Log.Information($"【EmptyCarryOutStk】外包装x1空托盘呼叫存在未完成的预任务,跳过此次自动呼叫"); } if (wbzxx2Flag) { Log.Information($"【EmptyCarryOutStk】外包装x2空托盘呼叫存在未完成的预任务,跳过此次自动呼叫"); } if (cs01==true && !cs01Flag) { BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); string response = HttpUtils.RequestGet($"{config.value}/api/production/time-work/empty-carry-out-stk-ctu1"); // string response = HttpUtils.RequestGet($"http://localhost:9232/api/production/time-work/empty-carry-out-stk-left"); AuthResponse authResponse = JsonConvert.DeserializeObject(response); result += authResponse.data.ToString(); } if (cs03==true && !cs03Flag) { BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); string response = HttpUtils.RequestGet($"{config.value}/api/production/time-work/empty-carry-out-stk-ctu3"); // string response = HttpUtils.RequestGet($"http://localhost:9232/api/production/time-work/empty-carry-out-stk-right"); AuthResponse authResponse = JsonConvert.DeserializeObject(response); result += authResponse.data.ToString(); } if (cs06==true && !cs06Flag) { BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); string response = HttpUtils.RequestGet($"{config.value}/api/production/time-work/empty-carry-out-stk-ctu6"); // string response = HttpUtils.RequestGet($"http://localhost:9232/api/production/time-work/empty-carry-out-stk-right"); AuthResponse authResponse = JsonConvert.DeserializeObject(response); result += authResponse.data.ToString(); } if (wbzxx1==true && !wbzxx1Flag) { BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); string response = HttpUtils.RequestGet($"{config.value}/api/production/time-work/empty-carry-out-stk-wbzx1"); // string response = HttpUtils.RequestGet($"http://localhost:9232/api/production/time-work/empty-carry-out-stk-right"); AuthResponse authResponse = JsonConvert.DeserializeObject(response); result += authResponse.data.ToString(); } if (wbzxx2==true && !wbzxx2Flag) { BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); string response = HttpUtils.RequestGet($"{config.value}/api/production/time-work/empty-carry-out-stk-wbzx2"); // string response = HttpUtils.RequestGet($"http://localhost:9232/api/production/time-work/empty-carry-out-stk-right"); AuthResponse authResponse = JsonConvert.DeserializeObject(response); result += authResponse.data.ToString(); } return result; } [HttpGet] [AllowAnonymous] public async Task EmptyCarryOutStkCtu1() { string msg = ""; BasFactoryConfig config = await _db.Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.EmptyCarryOutNum); MESEmptyCarryOutStkInput input = new MESEmptyCarryOutStkInput(); input.org_id = WmsWareHouseConst.AdministratorOrgId; input.location_code = "SSX-021-001"; input.warehouse_id = WmsWareHouseConst.WAREHOUSE_ZC_ID; input.carrystd_id = WmsWareHouseConst.LIAOXIANGID; input.qty = int.Parse(config?.value ?? "5"); input.create_id = WmsWareHouseConst.AdministratorUserId; Log.Information($"【EmptyCarryOutStk】ctu1空箱入呼叫开始,参数:{JsonConvert.SerializeObject(input)}"); Result result = await _wmsEmptyOutstockService.MESEmptyCarryOutStk(input); if (result.code == HttpStatusCode.OK) { msg = "ctu1空箱入呼叫成功"; Log.Information("【EmptyCarryOutStk】ctu1空箱入呼叫成功"); //_redisData.Set("YTCS_CallCtuEmptyIn_CS01_flag", true, TimeSpan.FromMinutes(20)); } else { msg = $"ctu1空箱入呼叫失败:{result.msg}"; Log.Error($"【EmptyCarryOutStk】ctu1空箱入呼叫失败:{result.msg}"); } return msg; } [HttpGet] [AllowAnonymous] public async Task EmptyCarryOutStkCtu3() { string msg = ""; BasFactoryConfig config = await _db.Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.EmptyCarryOutNum); MESEmptyCarryOutStkInput input = new MESEmptyCarryOutStkInput(); input.org_id = WmsWareHouseConst.AdministratorOrgId; input.location_code = "SSX-021-003"; input.warehouse_id = WmsWareHouseConst.WAREHOUSE_ZC_ID; input.carrystd_id = WmsWareHouseConst.LIAOXIANGID; input.qty = int.Parse(config?.value ?? "5"); input.create_id = WmsWareHouseConst.AdministratorUserId; Log.Information($"【EmptyCarryOutStk】ctu3空箱入呼叫开始,参数:{JsonConvert.SerializeObject(input)}"); Result result = await _wmsEmptyOutstockService.MESEmptyCarryOutStk(input); if (result.code == HttpStatusCode.OK) { msg = "ctu3空箱入呼叫成功"; Log.Information("【EmptyCarryOutStk】ctu3空箱入呼叫成功"); //_redisData.Set("YTCS_CallCtuEmptyIn_CS03_flag", true, TimeSpan.FromMinutes(20)); } else { msg = $"ctu3空箱入呼叫失败:{result.msg}"; Log.Error($"【EmptyCarryOutStk】ctu3空箱入呼叫失败:{result.msg}"); } return msg; } [HttpGet] [AllowAnonymous] public async Task EmptyCarryOutStkCtu6() { string msg = ""; BasFactoryConfig config = await _db.Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.EmptyCarryOutNum); MESEmptyCarryOutStkInput input = new MESEmptyCarryOutStkInput(); input.org_id = WmsWareHouseConst.AdministratorOrgId; input.location_code = "SSX-011-006"; input.warehouse_id = WmsWareHouseConst.WAREHOUSE_ZC_ID; input.carrystd_id = WmsWareHouseConst.LIAOXIANGID; input.qty = int.Parse(config?.value ?? "5"); input.create_id = WmsWareHouseConst.AdministratorUserId; Log.Information($"【EmptyCarryOutStk】ctu6空箱入呼叫开始,参数:{JsonConvert.SerializeObject(input)}"); Result result = await _wmsEmptyOutstockService.MESEmptyCarryOutStk(input); if (result.code == HttpStatusCode.OK) { msg = "ctu6空箱入呼叫成功"; Log.Information("【EmptyCarryOutStk】ctu6空箱入呼叫成功"); //_redisData.Set("YTCS_CallCtuEmptyIn_CS06_flag", true, TimeSpan.FromMinutes(20)); } else { msg = $"ctu6空箱入呼叫失败:{result.msg}"; Log.Error($"【EmptyCarryOutStk】ctu6空箱入呼叫失败:{result.msg}"); } return msg; } [HttpGet] [AllowAnonymous] public async Task EmptyCarryOutStkWbzx1() { string msg = ""; MESEmptyCarryOutStkInput input = new MESEmptyCarryOutStkInput(); input.org_id = WmsWareHouseConst.AdministratorOrgId; input.location_code = "ZZ-01-01"; input.warehouse_id = WmsWareHouseConst.WAREHOUSE_F2KTQ_ID; input.carrystd_id = WmsWareHouseConst.CARRY_TP_ID; input.qty = 1; input.create_id = WmsWareHouseConst.AdministratorUserId; Log.Information($"【EmptyCarryOutStk】外包装x1空托盘呼叫开始,参数:{JsonConvert.SerializeObject(input)}"); Result result = await _wmsEmptyOutstockService.MESEmptyCarryOutStk(input); if (result.code == HttpStatusCode.OK) { msg = "外包装x1空托盘呼叫成功"; Log.Information("【EmptyCarryOutStk】外包装x1空托盘呼叫成功"); //_redisData.Set("YTCS_CallCtuEmptyIn_CS06_flag", true, TimeSpan.FromMinutes(20)); } else { msg = $"外包装x1空托盘呼叫失败:{result.msg}"; Log.Error($"【EmptyCarryOutStk】外包装x1空托盘呼叫失败:{result.msg}"); } return msg; } [HttpGet] [AllowAnonymous] public async Task EmptyCarryOutStkWbzx2() { string msg = ""; MESEmptyCarryOutStkInput input = new MESEmptyCarryOutStkInput(); input.org_id = WmsWareHouseConst.AdministratorOrgId; input.location_code = "ZZ-02-01"; input.warehouse_id = WmsWareHouseConst.WAREHOUSE_F2KTQ_ID; input.carrystd_id = WmsWareHouseConst.CARRY_TP_ID; input.qty = 1; input.create_id = WmsWareHouseConst.AdministratorUserId; Log.Information($"【EmptyCarryOutStk】外包装x2空托盘呼叫开始,参数:{JsonConvert.SerializeObject(input)}"); Result result = await _wmsEmptyOutstockService.MESEmptyCarryOutStk(input); if (result.code == HttpStatusCode.OK) { msg = "外包装x2空托盘呼叫成功"; Log.Information("【EmptyCarryOutStk】外包装x2空托盘呼叫成功"); //_redisData.Set("YTCS_CallCtuEmptyIn_CS06_flag", true, TimeSpan.FromMinutes(20)); } else { msg = $"外包装x2空托盘呼叫失败:{result.msg}"; Log.Error($"【EmptyCarryOutStk】外包装x2空托盘呼叫失败:{result.msg}"); } return msg; } // [HttpGet] // [AllowAnonymous] // public async Task FixedPointDelivery() // { // string state = await _redisData.TryGetValueByKeyField("YTCS", "State"); // if ("OK" != state) // { // Log.Error($"TCS没开机"); // return "YTCS没开机"; // } // string stateHxja = await _redisData.TryGetValueByKeyField("hxjA", "State"); // string stateHxjc = await _redisData.TryGetValueByKeyField("hxjC", "State"); // List hxjList = new List(); // if ("OK" == stateHxja) // { // hxjList.Add("hxjA"); // } // if ("OK" == stateHxjc) // { // hxjList.Add("hxjC"); // } // // if (hxjList.IsEmpty()) // { // Log.Error($"hxjA,hxjC不正常"); // return "hxjA,hxjC不正常"; // } // string msg = ""; // List equipments = await _db.Queryable() // .InnerJoin((x, y) => x.id == y.equip_type_id) // .Where((x, y) => x.code == "ZSJ") // .Select((x, y) => y).ToListAsync(); // // int? cs01Count = await _redisData.TryGetValueByKeyField("YTCS", "EmptyNo_CS01"); // int? cs03Count = await _redisData.TryGetValueByKeyField("YTCS", "EmptyNo_CS03"); // // List eqpIds = equipments.Select(x => x.id).ToList(); // List eqpDaqs = await _db.Queryable().Where(x => eqpIds.Contains(x.equip_id) && x.label_name.Contains("允许入空箱")).ToListAsync(); // //BasFactoryConfig config = await _db.Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); // foreach (var equipment in equipments) // { // EqpDaq eqpDaq = eqpDaqs.FirstOrDefault(x => x.equip_id==equipment.id); // if (eqpDaq == null) // { // Log.Error($"{equipment.name}没配置允许入空箱"); // continue; // } // if (!hxjList.Contains(eqpDaq.equip_code)) // { // Log.Error($"{eqpDaq.equip_code}状态不正常"); // continue; // } // if (string.IsNullOrEmpty(equipment.upmat_location_id)) // { // Log.Error($"{equipment.name}未配置上料库位"); // continue; // } // if (await _db.Queryable().AnyAsync(x => // x.endlocation_id == equipment.upmat_location_id && // x.biz_type == WmsWareHouseConst.BIZTYPE_WMSDELIVERY_ID && // (x.status == WmsWareHouseConst.PRETASK_BILL_STATUS_DXF_ID // || x.status == WmsWareHouseConst.PRETASK_BILL_STATUS_YXF_ID // || x.status == WmsWareHouseConst.PRETASK_BILL_STATUS_START_ID // ) // )) // { // Log.Error($"{equipment.name}存在未完成的任务"); // continue; // } // bool? value = await _redisData.TryGetValueByKeyField(eqpDaq.equip_code, eqpDaq.label_name); // bool valueFlag = _redisData.Get($"{eqpDaq.equip_code}_{eqpDaq.label_name}_flag"); // Log.Information($"机台号{eqpDaq.equip_code},标签名{eqpDaq.label_name}redis的值为{value.ToString()}"); // // if (value==true && !valueFlag) // { // bool? cs01 = await _redisData.TryGetValueByKeyField("YTCS", "AllowAgvEmptyOut_CS01"); // bool? cs03 = await _redisData.TryGetValueByKeyField("YTCS", "AllowAgvEmptyOut_CS03"); // string startLocationCode = cs01==true ? "ZSSSXCTU01" : cs03==true ? "ZSSSXCTU02" : ""; // if (cs01==true && cs03==true) // { // string last_fixed_point_delivery = _redisData.Exists("last_fixed_point_delivery") ? _redisData.Get("last_fixed_point_delivery") : ""; // if (string.IsNullOrEmpty(last_fixed_point_delivery)) // { // startLocationCode = "ZSSSXCTU01"; // } // else // { // startLocationCode = "ZSSSXCTU01ZSSSXCTU02".Replace(last_fixed_point_delivery, ""); // } // } // if (startLocationCode.IsEmpty()) // { // Log.Error($"输送线无空载具"); // return "输送线无空载具"; // } // // BasLocation startLocation = await _db.Queryable().Where(x=>x.location_code==startLocationCode).FirstAsync(); // CommonCreatePretaskInput postData = new CommonCreatePretaskInput(); // postData.startlocation_id = startLocation.id; // postData.endlocation_id = equipment.upmat_location_id; // postData.biz_type = WmsWareHouseConst.BIZTYPE_WMSDELIVERY_ID; // postData.task_type = WmsWareHouseConst.WMS_PRETASK_OUTSTOCK_TYPE_ID; // Log.Information($"【FixedPointDelivery】注塑定点配送,参数:{JsonConvert.SerializeObject(postData)}"); // Result result = await _wareHouseService.CommonCreatePretask(postData); // // string sendResult = HttpUtils.RequestPost($"{config.value}/api/wms/ware-house/common-create-pretask", JsonConvert.SerializeObject(postData), null); // // string sendResult = HttpUtils.RequestPost($"http://localhost:9232/api/wms/ware-house/common-create-pretask", JsonConvert.SerializeObject(postData), null); // // AuthResponse authResponse = JsonConvert.DeserializeObject(sendResult); // if(result.code == HttpStatusCode.OK) // { // msg += $"{equipment.name}注塑定点配送成功,"; // Log.Information($"【FixedPointDelivery】{equipment.name}注塑定点配送成功"); // _redisData.Set($"{eqpDaq.equip_code}_{eqpDaq.label_name}_flag", true, TimeSpan.FromMinutes(20)); // _redisData.Set($"last_fixed_point_delivery", startLocationCode); // } // else // { // msg += $"{equipment.name}注塑定点配送失败:{result.msg},"; // Log.Error($"【FixedPointDelivery】{equipment.name}注塑定点配送失败:{result.msg}"); // } // // } // } // // return msg; // } /// /// 定点配送 /// /// [HttpGet] [AllowAnonymous] public async Task FixedPointDelivery() { string state = await _redisData.TryGetValueByKeyField("YTCS", "State"); if ("OK" != state) { Log.Error($"TCS没开机"); return "YTCS没开机"; } string stateHxja = await _redisData.TryGetValueByKeyField("hxjA", "State"); string stateHxjc = await _redisData.TryGetValueByKeyField("hxjC", "State"); List hxjList = new List(); if ("OK" == stateHxja) { hxjList.Add("hxjA"); } if ("OK" == stateHxjc) { hxjList.Add("hxjC"); } if (hxjList.IsEmpty()) { Log.Error($"hxjA,hxjC不正常"); return "hxjA,hxjC不正常"; } string msg = ""; List equipments = await _db.Queryable() .InnerJoin((x, y) => x.id == y.equip_type_id) .Where((x, y) => x.code == "ZSJ") .Select((x, y) => y).ToListAsync(); int cs01Count = await _redisData.TryGetValueByKeyField("YTCS", "EmptyNo_CS01"); int cs03Count = await _redisData.TryGetValueByKeyField("YTCS", "EmptyNo_CS03"); Log.Information($"注塑定点配送cs01数量:{cs01Count},cs03数量:{cs03Count}"); List eqpIds = equipments.Select(x => x.id).ToList(); List eqpDaqs = await _db.Queryable().Where(x => eqpIds.Contains(x.equip_id) && x.label_name.Contains("允许入空箱")).ToListAsync(); //BasFactoryConfig config = await _db.Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); foreach (var equipment in equipments) { EqpDaq eqpDaq = eqpDaqs.FirstOrDefault(x => x.equip_id==equipment.id); if (eqpDaq == null) { Log.Error($"{equipment.name}没配置允许入空箱"); continue; } if (!hxjList.Contains(eqpDaq.equip_code)) { Log.Error($"{eqpDaq.equip_code}状态不正常"); continue; } if (string.IsNullOrEmpty(equipment.upmat_location_id)) { Log.Error($"{equipment.name}未配置上料库位"); continue; } if (await _db.Queryable().AnyAsync(x => x.endlocation_id == equipment.upmat_location_id && x.biz_type == WmsWareHouseConst.BIZTYPE_WMSDELIVERY_ID && (x.status == WmsWareHouseConst.PRETASK_BILL_STATUS_DXF_ID || x.status == WmsWareHouseConst.PRETASK_BILL_STATUS_YXF_ID || x.status == WmsWareHouseConst.PRETASK_BILL_STATUS_START_ID ) )) { Log.Error($"{equipment.name}存在未完成的任务"); continue; } bool? value = await _redisData.TryGetValueByKeyField(eqpDaq.equip_code, eqpDaq.label_name); bool valueFlag = _redisData.Get($"{eqpDaq.equip_code}_{eqpDaq.label_name}_flag"); Log.Information($"机台号{eqpDaq.equip_code},标签名{eqpDaq.label_name}redis的值为{value.ToString()}"); if (value==true && !valueFlag) { bool? cs01 = await _redisData.TryGetValueByKeyField("YTCS", "AllowAgvEmptyOut_CS01"); bool? cs03 = await _redisData.TryGetValueByKeyField("YTCS", "AllowAgvEmptyOut_CS03"); string startLocationCode = ""; if (cs01==true && cs03==true && cs01Count>0 && cs03Count>0) { string last_fixed_point_delivery = _redisData.Exists("last_fixed_point_delivery") ? _redisData.Get("last_fixed_point_delivery") : ""; if (string.IsNullOrEmpty(last_fixed_point_delivery)) { startLocationCode = "ZSSSXCTU01"; } else { startLocationCode = "ZSSSXCTU01ZSSSXCTU02".Replace(last_fixed_point_delivery, ""); } if (startLocationCode == "ZSSSXCTU01") { cs01Count--; } if (startLocationCode == "ZSSSXCTU02") { cs03Count--; } } else { if (cs01==true && cs01Count > 0) { startLocationCode = "ZSSSXCTU01"; cs01Count--; }else if (cs03==true && cs03Count > 0) { startLocationCode = "ZSSSXCTU02"; cs03Count--; } } if (startLocationCode.IsEmpty()) { Log.Error($"输送线无空载具"); return "输送线无空载具"; } BasLocation startLocation = await _db.Queryable().Where(x=>x.location_code==startLocationCode).FirstAsync(); CommonCreatePretaskInput postData = new CommonCreatePretaskInput(); postData.startlocation_id = startLocation.id; postData.endlocation_id = equipment.upmat_location_id; postData.biz_type = WmsWareHouseConst.BIZTYPE_WMSDELIVERY_ID; postData.task_type = WmsWareHouseConst.WMS_PRETASK_OUTSTOCK_TYPE_ID; Log.Information($"【FixedPointDelivery】注塑定点配送,参数:{JsonConvert.SerializeObject(postData)}"); Result result = await _wareHouseService.CommonCreatePretask(postData); // string sendResult = HttpUtils.RequestPost($"{config.value}/api/wms/ware-house/common-create-pretask", JsonConvert.SerializeObject(postData), null); // string sendResult = HttpUtils.RequestPost($"http://localhost:9232/api/wms/ware-house/common-create-pretask", JsonConvert.SerializeObject(postData), null); // AuthResponse authResponse = JsonConvert.DeserializeObject(sendResult); if(result.code == HttpStatusCode.OK) { msg += $"{equipment.name}注塑定点配送成功,"; Log.Information($"【FixedPointDelivery】{equipment.name}注塑定点配送成功"); _redisData.Set($"{eqpDaq.equip_code}_{eqpDaq.label_name}_flag", true, TimeSpan.FromMinutes(20)); _redisData.Set($"last_fixed_point_delivery", startLocationCode); } else { msg += $"{equipment.name}注塑定点配送失败:{result.msg},"; Log.Error($"【FixedPointDelivery】{equipment.name}注塑定点配送失败:{result.msg}"); } } } return msg; } /// /// 自动提报 /// /// [HttpGet] [AllowAnonymous] public async Task AutoPrdReport() { BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); bool qu1 = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x1_AGV_qu"); if (qu1) { Log.Information("血路管1线取"); HttpUtils.RequestGet($"{config.value}/api/production/time-work/x1-auto-prd-report"); } bool qu2 = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x2_AGV_qu"); if (qu2) { Log.Information("血路管2线取"); HttpUtils.RequestGet($"{config.value}/api/production/time-work/x2-auto-prd-report"); } return "true"; } [HttpGet] [AllowAnonymous] public async Task X1AutoPrdReport() { string carryCode = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x1_take_tp"); int num = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x1_Enquantity"); if (string.IsNullOrEmpty(carryCode) || num<=0) { Log.Information("血路管1线无载具或数量为0"); return "无载具或数量为0"; } PrdMoTask prdMoTask = await _db.Queryable().Where(x => x.workline_id == WmsWareHouseConst.XUELUGUAN1XIAN && x.mo_task_status == DictConst.InProgressEnCode && x.parent_id != null).FirstAsync(); if (prdMoTask == null) { Log.Information("血路管1线没有进行中的任务单"); return "血路管1线没有进行中的任务单"; } PrdReportCrInput input = new PrdReportCrInput(); input.mo_task_code = prdMoTask.mo_task_code; input.mo_task_id = prdMoTask.id; input.reported_qty = num; input.station = ""; input.material_box_code = carryCode; await _prdMoTaskService.PrdReport(input); return "true"; } [HttpGet] [AllowAnonymous] public async Task X2AutoPrdReport() { string carryCode = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x2_take_tp"); int num = await _redisData.TryGetValueByKeyField("外包装箱码垛线", "WBZX_x2_Enquantity"); if (string.IsNullOrEmpty(carryCode) || num<=0) { Log.Information("血路管2线无载具或数量为0"); return "无载具或数量为0"; } PrdMoTask prdMoTask = await _db.Queryable().Where(x => x.workline_id == WmsWareHouseConst.XUELUGUAN2XIAN && x.mo_task_status == DictConst.InProgressEnCode && x.parent_id != null).FirstAsync(); if (prdMoTask == null) { Log.Information("血路管2线没有进行中的任务单"); return "血路管2线没有进行中的任务单"; } PrdReportCrInput input = new PrdReportCrInput(); input.mo_task_code = prdMoTask.mo_task_code; input.mo_task_id = prdMoTask.id; input.reported_qty = num; input.station = ""; input.material_box_code = carryCode; await _prdMoTaskService.PrdReport(input); return "true"; } [HttpGet] [AllowAnonymous] public async Task SendThirdApi(string thirdNmaes) { string[] thirdNameArr = thirdNmaes.Split("-"); List records = await _db.Queryable().Where(x => thirdNameArr.Contains(x.third_name) && x.status == 0 && x.is_send == 1).ToListAsync(); DateTime now = DateTime.Now; Stopwatch stopwatch = null; string response = ""; var elapsedMilliseconds = 0l; ThirdResult thirdResult = new ThirdResult(); foreach (var record in records) { now = DateTime.Now; stopwatch = Stopwatch.StartNew(); switch (record.method.ToUpper()) { case "GET": response = HttpUtils.RequestGet(record.url); break; case "POST": response = HttpUtils.RequestPost(record.url, record.request_data); break; } stopwatch.Stop(); elapsedMilliseconds = stopwatch.ElapsedMilliseconds; try { thirdResult = JsonConvert.DeserializeObject(response); } catch (Exception e) { thirdResult.Code = 500; thirdResult.msgResult = response; } if (thirdResult.Code == 200) { await _db.Updateable() .SetColumns(x => x.response_data == response) .SetColumns(x => x.response_code == thirdResult.Code) .SetColumns(x => x.last_send_time == now) .SetColumns(x => x.response_time == elapsedMilliseconds) .SetColumns(x => x.send_type == "自动") .SetColumns(x => x.status == 1) .Where(x=>x.id==record.id) .ExecuteCommandAsync(); } else { await _db.Updateable() .SetColumns(x => x.response_data == response) .SetColumns(x => x.response_code == thirdResult.Code) .SetColumns(x => x.last_send_time == now) .SetColumns(x => x.response_time == elapsedMilliseconds) .Where(x=>x.id==record.id) .ExecuteCommandAsync(); } } return "true"; } /// /// 同步基础数据 /// /// [HttpGet] [AllowAnonymous] public async Task SyncBaseData() { string result = ""; BasFactoryConfig config = await _repository.AsSugarClient().Queryable().FirstAsync(x => x.enabled == 1 && x.key == FactoryConfigConst.DOMAIN); string response1 = HttpUtils.RequestGet($"{config.value}/api/production/time-work/sync-unit"); AuthResponse authResponse1 = JsonConvert.DeserializeObject(response1); result += authResponse1.data.ToString(); string response2 = HttpUtils.RequestGet($"{config.value}/api/production/time-work/sync-material"); AuthResponse authResponse2 = JsonConvert.DeserializeObject(response2); result += ","+authResponse2.data.ToString(); string response3 = HttpUtils.RequestGet($"{config.value}/api/production/time-work/sync-customer"); AuthResponse authResponse3 = JsonConvert.DeserializeObject(response3); result += ","+authResponse3.data.ToString(); string response4 = HttpUtils.RequestGet($"{config.value}/api/production/time-work/sync-supplier"); AuthResponse authResponse4 = JsonConvert.DeserializeObject(response4); result += ","+authResponse4.data.ToString(); string response5 = HttpUtils.RequestGet($"{config.value}/api/production/time-work/sync-user"); AuthResponse authResponse5 = JsonConvert.DeserializeObject(response5); result += ","+authResponse5.data.ToString(); return result; } /// /// 同步物料 /// /// [HttpGet] [AllowAnonymous] public async Task SyncMaterial() { string msg = ""; try { int editCount = 0; string[] tables = new[] { "base_dictionarydata", "bas_material" }; var erpdb = _db.AsTenant().GetConnection("erpdb"); List list = await erpdb.Queryable().ToListAsync(); List bomList = await erpdb.Queryable().ToListAsync(); List erpExtendFields = await _db.Queryable() .Where(x => tables.Contains(x.table_name)).ToListAsync(); Dictionary unitDic = await _db.Queryable() .Where(x => x.DictionaryTypeId == WmsWareHouseConst.UNITTYPEID) .ToDictionaryAsync(x => x.Id, y => y.EnCode); Dictionary unitDic2 = await _db.Queryable() .Where(x => x.DictionaryTypeId == WmsWareHouseConst.UNITTYPEID) .ToDictionaryAsync(x => x.FullName, y => y.EnCode); List materials = await _db.Queryable().ToListAsync(); List basEbomHs = await _db.Queryable().ToListAsync(); List insertMaterial = new List(); List insertMaterialUnits = new List(); List insertBasEbomHs = new List(); List insertBasEbomDs = new List(); List insertExtendFields = new List(); await _db.Ado.BeginTranAsync(); foreach (ErpBdMaterial erpBdMaterial in list) { string unitId = erpExtendFields.Find(x => x.cunitid == erpBdMaterial.PK_MEASDOC)?.table_id ?? ""; unitId = unitDic.ContainsKey(unitId) ? unitDic[unitId].ToString() : ""; string auxiliaryUnitId = erpExtendFields.Find(x => x.cunitid == erpBdMaterial.FMEASDOC)?.table_id ?? ""; auxiliaryUnitId = unitDic.ContainsKey(auxiliaryUnitId) ? unitDic[auxiliaryUnitId].ToString() : ""; string[] unitArr = erpBdMaterial.MEASRATE.Split("/"); if (erpExtendFields.All(x => x.cmaterialoid != erpBdMaterial.ID)) { BasMaterial basMaterial = null; ErpExtendField tempExtendField = insertExtendFields.Find(x => x.cmaterialoid == erpBdMaterial.ID); if (tempExtendField!=null) { basMaterial = insertMaterial.Find(x => x.id == tempExtendField.table_id); } else { basMaterial = new BasMaterial() { id = SnowflakeIdHelper.NextId(), name = erpBdMaterial.NAME, code = erpBdMaterial.CODE, org_id = WmsWareHouseConst.AdministratorOrgId, material_specification = erpBdMaterial.MATERIALSPEC, material_standard = erpBdMaterial.MATERIALTYPE, category_id = "[\"CGJCJ\"]", unit_id = unitId, state = "1", create_time = DateTime.Now }; insertMaterial.Add(basMaterial); ErpExtendField erpExtendField = new ErpExtendField() { table_name = "bas_material", table_id = basMaterial.id, cmaterialoid = erpBdMaterial.ID, cmaterialvid = erpBdMaterial.VID, }; insertExtendFields.Add(erpExtendField); } if (unitId != auxiliaryUnitId) { insertMaterialUnits.Add(new BasMaterialUnit() { id = SnowflakeIdHelper.NextId(), material_id = basMaterial.id, number_of_primary_unit = unitArr[0], number_of_auxiliary_unit = unitArr[1], auxiliary_unit_id = auxiliaryUnitId }); } } else { ErpExtendField extendField = erpExtendFields.Find(x => x.cmaterialoid == erpBdMaterial.ID); string materialId = extendField?.table_id ?? ""; BasMaterial basMaterial = await _db.Queryable().SingleAsync(x => x.id == materialId); if (erpBdMaterial.MODIFIEDTIME != extendField.erp_modify_time) { int updateRow = await _db.Updateable() .SetColumns(x => x.name == erpBdMaterial.NAME) .SetColumns(x => x.code == erpBdMaterial.CODE) .SetColumns(x => x.material_specification == erpBdMaterial.MATERIALSPEC) .SetColumns(x => x.material_standard == erpBdMaterial.MATERIALTYPE) .SetColumns(x => x.unit_id == unitId) .SetColumns(x => x.name == erpBdMaterial.NAME) .Where(x => x.id == materialId) .ExecuteCommandAsync(); await _db.Updateable() .SetColumns(x => x.erp_modify_time == erpBdMaterial.MODIFIEDTIME) .Where(x => x.table_id == extendField.table_id) .ExecuteCommandAsync(); editCount += updateRow; if (updateRow <= 0) { Log.Error($"未找到物料{erpBdMaterial.ID},跳过此条数据"); continue; } BasMaterialUnit basMaterialUnit = await _db.Queryable() .Where(x => x.material_id == materialId && x.auxiliary_unit_id == auxiliaryUnitId) .FirstAsync(); if (basMaterialUnit == null) { if (unitId != auxiliaryUnitId) { insertMaterialUnits.Add(new BasMaterialUnit() { id = SnowflakeIdHelper.NextId(), material_id = materialId, number_of_primary_unit = unitArr[0], number_of_auxiliary_unit = unitArr[1], auxiliary_unit_id = auxiliaryUnitId }); } } else { if (unitId != auxiliaryUnitId) { await _db.Updateable() .SetColumns(x => x.number_of_primary_unit == unitArr[0]) .SetColumns(x => x.number_of_auxiliary_unit == unitArr[1]) .Where(x => x.id == basMaterialUnit.id) .ExecuteCommandAsync(); } } } } } await _db.Insertable(insertMaterial).ExecuteCommandAsync(); await _db.Insertable(insertMaterialUnits).ExecuteCommandAsync(); await _db.Insertable(insertExtendFields).ExecuteCommandAsync(); //物料清单开始同步 materials = await _db.Queryable().ToListAsync(); var groupList = bomList.GroupBy(x => x.BOMID); foreach (var item in groupList) { string key = item.Key; List itemList = item.ToList(); BomList firstItemInList = itemList[0]; BasMaterial material = materials.Find(x => x.code==firstItemInList.MPRODID); if (material == null) continue; string unitId = unitDic2.ContainsKey(firstItemInList.UNIT) ? unitDic2[firstItemInList.UNIT].ToString() : ""; if (basEbomHs.All(x => x.material_id != material.id && x.version != firstItemInList.HVERSION)) { BasEbomH basEbomH = new BasEbomH() { id = SnowflakeIdHelper.NextId(), org_id = WmsWareHouseConst.AdministratorOrgId, material_id = material.id, unit_id = unitId, version = firstItemInList.HVERSION, create_time = DateTime.Now, }; bool flag = false; List tempList = new List(); foreach (var children in itemList) { BasMaterial childrenMaterial = materials.Find(x => x.code==children.SUBPRODID); if (childrenMaterial == null) { flag = true; tempList = new List(); break; } BasEbomD basEbomD = new BasEbomD() { id = SnowflakeIdHelper.NextId(), ebom_id = basEbomH.id, material_id = childrenMaterial.id, denominator = children.DISHU, molecule = children.BATCHAMOUNT, }; tempList.Add(basEbomD); } if (flag) { continue; } insertBasEbomHs.Add(basEbomH); insertBasEbomDs.AddRange(tempList); } else { BasEbomH basEbomH = await _db.Queryable().Where(x=>x.material_id==material.id && x.version==firstItemInList.HVERSION).FirstAsync(); if (basEbomH == null) continue; if (basEbomH.erp_modify_time != firstItemInList.MODIFIEDTIME) { bool flag = false; List tempList = new List(); foreach (var children in itemList) { BasMaterial childrenMaterial = materials.Find(x => x.code==children.SUBPRODID); if (childrenMaterial == null) { flag = true; tempList = new List(); break; } BasEbomD basEbomD = new BasEbomD() { id = SnowflakeIdHelper.NextId(), ebom_id = basEbomH.id, material_id = childrenMaterial.id, denominator = children.DISHU, molecule = children.BATCHAMOUNT, }; tempList.Add(basEbomD); } if (flag) { continue; } insertBasEbomDs.AddRange(tempList); await _db.Updateable() .SetColumns(x => x.unit_id == unitId) .Where(x => x.id == basEbomH.id) .ExecuteCommandAsync(); await _db.Deleteable().Where(x => x.ebom_id == basEbomH.id).ExecuteCommandAsync(); } } } await _db.Insertable(insertBasEbomHs).ExecuteCommandAsync(); await _db.Insertable(insertBasEbomDs).ExecuteCommandAsync(); await _db.Ado.CommitTranAsync(); msg = $"新增物料${insertMaterial.Count}条,修改物料{editCount}条"; Log.Information(msg); } catch (Exception e) { msg = e.Message; Log.Error(e.Message, e); await _db.Ado.RollbackTranAsync(); throw Oops.Bah(e.Message); } return msg; } /// /// 同步单位 /// /// [HttpGet] [AllowAnonymous] public async Task SyncUnit() { string msg = ""; var mysqlDb = _db.AsTenant().GetConnection("erpdb"); List list = await mysqlDb.Queryable().ToListAsync(); List erpExtendFields = await _db.Queryable().Where(x=>x.table_name=="base_dictionarydata").ToListAsync(); List insertUnit = new List(); List insertExtendFields = new List(); foreach (ErpBdMeasdoc erpBdMeasdoc in list) { if (erpExtendFields.All(x => x.cunitid != erpBdMeasdoc.ID)) { DictionaryDataEntity dictionaryDataEntity = new DictionaryDataEntity() { Id = SnowflakeIdHelper.NextId(), FullName = erpBdMeasdoc.NAME, EnCode = erpBdMeasdoc.CODE, ParentId = "0", SortCode = 0, EnabledMark = 1, CreatorTime = DateTime.Now, DictionaryTypeId = WmsWareHouseConst.UNITTYPEID, }; ErpExtendField erpExtendField = new ErpExtendField() { table_id = dictionaryDataEntity.Id, table_name = "base_dictionarydata", cunitid = erpBdMeasdoc.ID, create_time = DateTime.Now }; insertUnit.Add(dictionaryDataEntity); insertExtendFields.Add(erpExtendField); } } if (!insertUnit.IsEmpty() && !insertExtendFields.IsEmpty()) { DbResult result = await _db.Ado.UseTranAsync(async () => { await _db.Insertable(insertUnit).ExecuteCommandAsync(); await _db.Insertable(insertExtendFields).ExecuteCommandAsync(); }); return result.IsSuccess ? $"新增单位{insertUnit.Count}条" : result.ErrorMessage; } return msg; } /// /// 同步客户 /// /// [HttpGet] [AllowAnonymous] public async Task SyncCustomer() { string msg = ""; try { int editCount = 0; var erpdb = _db.AsTenant().GetConnection("erpdb"); List list = await erpdb.Queryable().ToListAsync(); List erpExtendFields = await _db.Queryable().Where(x=>x.table_name=="bas_customer").ToListAsync(); List insertCustomers = new List(); List insertExtendFields = new List(); await _db.Ado.BeginTranAsync(); foreach (ErpBdCustomer erpBdCustomer in list) { if (erpExtendFields.All(x => x.customer_id != erpBdCustomer.ID)) { BasCustomer basCustomer = new BasCustomer() { id = SnowflakeIdHelper.NextId(), customer_code = erpBdCustomer.CODE, customer_name = erpBdCustomer.NAME, create_time = DateTime.Now }; ErpExtendField erpExtendField = new ErpExtendField() { table_id = basCustomer.id, table_name = "bas_customer", cunitid = erpBdCustomer.ID, create_time = DateTime.Now }; insertCustomers.Add(basCustomer); insertExtendFields.Add(erpExtendField); } else { ErpExtendField erpExtendField = erpExtendFields.Find(x => x.customer_id == erpBdCustomer.ID); if (erpBdCustomer.MODIFIEDTIME != erpExtendField.erp_modify_time) { int updateRow = await _db.Updateable() .SetColumns(x => x.customer_code == erpBdCustomer.CODE) .SetColumns(x => x.customer_name == erpBdCustomer.NAME) .Where(x => x.id == erpExtendField.table_id) .ExecuteCommandAsync(); await _db.Updateable() .SetColumns(x => x.erp_modify_time == erpBdCustomer.MODIFIEDTIME) .Where(x => x.table_id == erpExtendField.table_id) .ExecuteCommandAsync(); editCount += updateRow; } } } await _db.Insertable(insertCustomers).ExecuteCommandAsync(); await _db.Insertable(insertExtendFields).ExecuteCommandAsync(); await _db.Ado.CommitTranAsync(); msg = $"新增客户${insertCustomers.Count}条,修改客户{editCount}条"; } catch (Exception e) { Log.Error(e.Message, e); msg = e.Message; await _db.Ado.RollbackTranAsync(); throw Oops.Bah(e.Message); } return msg; } /// /// 同步供应商 /// /// [HttpGet] [AllowAnonymous] public async Task SyncSupplier() { string msg = ""; try { int editCount = 0; var erpdb = _db.AsTenant().GetConnection("erpdb"); List list = await erpdb.Queryable().ToListAsync(); List erpExtendFields = await _db.Queryable().Where(x=>x.table_name=="bas_supplier").ToListAsync(); List insertSuppliers = new List(); List insertExtendFields = new List(); await _db.Ado.BeginTranAsync(); foreach (ErpBdSupplier erpBdSupplier in list) { if (erpExtendFields.All(x => x.supplier_id != erpBdSupplier.ID)) { BasSupplier basSupplier = new BasSupplier() { id = SnowflakeIdHelper.NextId(), supplier_code = erpBdSupplier.CODE, supplier_name = erpBdSupplier.NAME, create_time = DateTime.Now }; ErpExtendField erpExtendField = new ErpExtendField() { table_id = basSupplier.id, table_name = "bas_supplier", cunitid = erpBdSupplier.ID, create_time = DateTime.Now }; insertSuppliers.Add(basSupplier); insertExtendFields.Add(erpExtendField); } else { ErpExtendField erpExtendField = erpExtendFields.Find(x => x.supplier_id == erpBdSupplier.ID); if (erpBdSupplier.MODIFIEDTIME != erpExtendField.erp_modify_time) { int updateRow = await _db.Updateable() .SetColumns(x => x.supplier_code == erpBdSupplier.CODE) .SetColumns(x => x.supplier_name == erpBdSupplier.NAME) .Where(x => x.id == erpExtendField.table_id) .ExecuteCommandAsync(); await _db.Updateable() .SetColumns(x => x.erp_modify_time == erpBdSupplier.MODIFIEDTIME) .Where(x => x.table_id == erpExtendField.table_id) .ExecuteCommandAsync(); editCount += updateRow; } } } await _db.Insertable(insertSuppliers).ExecuteCommandAsync(); await _db.Insertable(insertExtendFields).ExecuteCommandAsync(); await _db.Ado.CommitTranAsync(); msg = $"新增供应商${insertSuppliers.Count}条,修改供应商{editCount}条"; } catch (Exception e) { Log.Error(e.Message, e); msg = e.Message; await _db.Ado.RollbackTranAsync(); throw Oops.Bah(e.Message); } return msg; } /// /// 同步用户 /// /// [HttpGet] [AllowAnonymous] public async Task SyncUser() { string msg = ""; try { var erpdb = _db.AsTenant().GetConnection("erpdb"); List users = await erpdb.Queryable().ToListAsync(); List erpExtendFields = await _db.Queryable().Where(x=>x.table_name=="base_user").ToListAsync(); List insertUsers = new List(); List insertUserRelations = new List(); List insertErpExtendFields = new List(); await _db.Ado.BeginTranAsync(); foreach (var user in users) { if (erpExtendFields.All(x => x.user_id != user.ID)) { UserEntity userEntity = new UserEntity(); userEntity.Id = SnowflakeIdHelper.NextId(); userEntity.Account = user.CODE; userEntity.RealName = user.NAME; userEntity.Gender = 1; userEntity.OrganizeId = WmsWareHouseConst.AdministratorOrgId; userEntity.RoleId = "30327535942933"; userEntity.Secretkey = Guid.NewGuid().ToString(); userEntity.Password = MD5Encryption.Encrypt(MD5Encryption.Encrypt(CommonConst.DEFAULTPASSWORD) + userEntity.Secretkey); userEntity.EntryDate = DateTime.Now; userEntity.EnabledMark = 1; userEntity.CreatorTime = DateTime.Now; insertUsers.Add(userEntity); UserRelationEntity userRelationEntity = new UserRelationEntity(); userRelationEntity.Id = SnowflakeIdHelper.NextId(); userRelationEntity.UserId = userEntity.Id; userRelationEntity.ObjectType = "Role"; userRelationEntity.ObjectId = "30327535942933"; userRelationEntity.CreatorTime = DateTime.Now; insertUserRelations.Add(userRelationEntity); UserRelationEntity userRelationEntity2 = new UserRelationEntity(); userRelationEntity2.Id = SnowflakeIdHelper.NextId(); userRelationEntity2.UserId = userEntity.Id; userRelationEntity2.ObjectType = "Organize"; userRelationEntity2.ObjectId = WmsWareHouseConst.AdministratorOrgId; userRelationEntity2.CreatorTime = DateTime.Now; insertUserRelations.Add(userRelationEntity2); ErpExtendField extendField = new ErpExtendField(); extendField.org_id = WmsWareHouseConst.AdministratorOrgId; extendField.table_name = "base_user"; extendField.table_id = userEntity.Id; extendField.user_id = user.ID; insertErpExtendFields.Add(extendField); } } await _db.Insertable(insertUsers).ExecuteCommandAsync(); await _db.Insertable(insertUserRelations).ExecuteCommandAsync(); await _db.Insertable(insertErpExtendFields).ExecuteCommandAsync(); await _db.Ado.CommitTranAsync(); msg = $"新增用户${insertUsers.Count}条"; } catch (Exception e) { Log.Error(e.Message, e); msg = e.Message; await _db.Ado.RollbackTranAsync(); throw Oops.Bah(e.Message); } return msg; } } }