using System; using System.Collections.Generic; using System.Linq; using System.Text.Json; using System.Threading.Tasks; using Microsoft.Extensions.Logging; using Win_in.Sfs.Wms.DataExchange.Domain; using Win_in.Sfs.Wms.DataExchange.Domain.Fawtyg.Tyrp; using Win_in.Sfs.Wms.DataExchange.Domain.Shared; using Win_in.Sfs.Wms.DataExchange.WMS.ErpLocation; namespace Win_in.Sfs.Wms.DataExchange.Fawtyg.TyrpAgent.Incoming; public class ErpLocationReader : IReader { private readonly IErpLocationManager _erpLocationManager; private readonly IIncomingFromExternalManager _incomingFromExternalManager; private readonly ILogger _logger; public ErpLocationReader( IErpLocationManager erpLocationManager , IIncomingFromExternalManager incomingFromExternalManager , ILogger logger ) { _erpLocationManager = erpLocationManager; _incomingFromExternalManager = incomingFromExternalManager; _logger = logger; } public virtual async Task> ReadAsync() { //从MES读取待处理locmout var toBeProcessedDatas = await _erpLocationManager.GetToBeProcessedListAsync().ConfigureAwait(false); if (!toBeProcessedDatas.Any()) { _logger.LogInformation("no erpLocations"); return new List(); } //locmout逐一转换为ErpLocation var incomingDataList = BuildIncomingFromExternalFromShipAsync(toBeProcessedDatas); await _incomingFromExternalManager.CreateManyAsync(incomingDataList).ConfigureAwait(false); return incomingDataList; } private static List BuildIncomingFromExternalFromShipAsync(List toBeProcessedDatas) { var incomingDataList = new List(); foreach (var item in toBeProcessedDatas) { var incomingData = BuildIncomingFromExternal(item); incomingData.SetEffectiveDate(DateTime.Now); incomingData.SetSuccess(); try { var erpLocationNote = BuildErpLocationCreateInput(item); incomingData.DestinationDataContent = JsonSerializer.Serialize(erpLocationNote); } catch (Exception ex) { incomingData.SetError(EnumExchangeDataErrorCode.Exception, ex.Message, ex.ToString()); } incomingDataList.Add(incomingData); } return incomingDataList; } private static IncomingFromExternal BuildIncomingFromExternal(locmout locmout) { var incomingData = new IncomingFromExternal() { DataType = EnumIncomingDataType.ErpLocation.ToString(), DataAction = EnumExchangeDataAction.Add, SourceSystem = EnumSystemType.ERP.ToString(), SourceDataId = locmout.locmout_loc, SourceDataGroupCode = locmout.locmout_loc, SourceDataDetailCode = locmout.locmout_loc, SourceDataContent = JsonSerializer.Serialize(locmout), WriteTime = DateTime.Now, Writer = nameof(TyrpIncomingBackgroundWorker), DestinationSystem = EnumSystemType.WMS.ToString(), }; return incomingData; } private static ErpLocationExchangeDto BuildErpLocationCreateInput(locmout locmout) { var erpLocation = new ErpLocationExchangeDto() { Code = locmout.locmout_loc, Name = locmout.locmout_loc, Type = locmout.locmout_stat2, WarehouseCode = locmout.locmout_stat2, }; return erpLocation; } }