using LogLibrary.Log; 
 | 
using Masuit.Tools; 
 | 
using Newtonsoft.Json; 
 | 
using WIDESEA_Common; 
 | 
using WIDESEA_Core; 
 | 
using WIDESEA_Core.Const; 
 | 
using WIDESEA_DTO; 
 | 
using WIDESEA_DTO.MOM; 
 | 
using WIDESEA_IServices; 
 | 
using WIDESEA_IStoragIntegrationServices; 
 | 
  
 | 
namespace WIDESEA_StoragIntegrationServices; 
 | 
  
 | 
public class ProcessApplyService : IProcessApplyService 
 | 
{ 
 | 
    private readonly LogFactory LogFactory = new LogFactory(); 
 | 
    private readonly ISys_ConfigService _configService; 
 | 
  
 | 
    public ProcessApplyService(ISys_ConfigService configRepository) 
 | 
    { 
 | 
        _configService = configRepository; 
 | 
    } 
 | 
  
 | 
    /// <summary> 
 | 
    /// 工艺路线申请 
 | 
    /// </summary> 
 | 
    /// <param name="input"></param> 
 | 
    /// <returns></returns> 
 | 
    public async Task<WebResponseContent> GetProcessApplyAsync(ProcessApplyDto input) 
 | 
    { 
 | 
        WebResponseContent content = new WebResponseContent(); 
 | 
        try 
 | 
        { 
 | 
            input.SessionId = Guid.NewGuid().ToString(); 
 | 
            input.EmployeeNo = "MITest"; 
 | 
            input.RequestTime = TimeZoneInfo.ConvertTimeToUtc(DateTime.Now).ToString("yyyy-MM-ddTHH:mm:ss.fffZ"); 
 | 
            var inputJson = input.ToDictionary(); 
 | 
            var configs = _configService.GetConfigsByCategory(CateGoryConst.SYS_MOMIPAddress); 
 | 
            var wmsBase = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.MOMBaseIP)?.ConfigValue; 
 | 
            var ipAddress = configs.FirstOrDefault(x => x.ConfigKey == SysConfigConst.ProcessApply)?.ConfigValue; 
 | 
            if (wmsBase == null || ipAddress == null) 
 | 
            { 
 | 
                throw new InvalidOperationException("WMS IP 未配置"); 
 | 
            } 
 | 
            var wmsIpAddress = wmsBase + ipAddress; 
 | 
  
 | 
            var result = HttpsClient.PostAsync(wmsIpAddress, inputJson).Result; 
 | 
            //var x = await HttpsClient.PostAsync("http://c24-cellmi3:12020/api/MachineIntegration/ProcessApply", inputJson); 
 | 
            if (result != null) 
 | 
            { 
 | 
                //var ResultProcess = JsonConvert.DeserializeObject<ResultProcessApply>(x); 
 | 
                content.OK(data: result); 
 | 
            } 
 | 
            LogFactory.GetLog("工艺路线申请").Info(true, $"\r\r--------------------------------------"); 
 | 
            LogFactory.GetLog("工艺路线申请").Info(true, result); 
 | 
        } 
 | 
        catch (Exception ex) 
 | 
        { 
 | 
            Console.WriteLine(ex.Message); 
 | 
            LogFactory.GetLog("工艺路线申请").Error(true, $"\r\r--------------------------------------"); 
 | 
            LogFactory.GetLog("工艺路线申请").Error(true, ex.StackTrace); 
 | 
        } 
 | 
        return content; 
 | 
    } 
 | 
} 
 |