Save ProcessDataStandardFormat to EC_Metrology_Si
IDescription.GetDescriptions with body
This commit is contained in:
		| @ -6,6 +6,7 @@ using Adaptation.Shared.Methods; | ||||
| using Adaptation.Shared.Metrology; | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Globalization; | ||||
| using System.IO; | ||||
| using System.Linq; | ||||
| using System.Text.Json; | ||||
| @ -16,6 +17,7 @@ public class FileRead : Shared.FileRead, IFileRead | ||||
| { | ||||
|  | ||||
|     private readonly string _OpenInsightMetrologyViewerAPI; | ||||
|     private readonly string _OpenInsightMetrologyViewerFileShare; | ||||
|  | ||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<string>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||
| @ -29,6 +31,7 @@ public class FileRead : Shared.FileRead, IFileRead | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         if (!_IsDuplicator) | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         _OpenInsightMetrologyViewerFileShare = @"\\messv02ecc1.ec.local\EC_Metrology_Si\MetrologyAttachments\TencorRunHeader_"; | ||||
|         _OpenInsightMetrologyViewerAPI = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "OpenInsight.MetrologyViewerAPI"); | ||||
|     } | ||||
|  | ||||
| @ -107,11 +110,15 @@ public class FileRead : Shared.FileRead, IFileRead | ||||
|         return results; | ||||
|     } | ||||
|  | ||||
| #pragma warning disable IDE0060 | ||||
|     private void SendData(DateTime dateTime, List<pcl.Description> descriptions) | ||||
| #pragma warning restore IDE0060 | ||||
|     private void SendData(string reportFullPath, DateTime dateTime, List<pcl.Description> descriptions) | ||||
|     { | ||||
|         WSRequest wsRequest = new(this, _Logistics, descriptions); | ||||
|         int weekOfYear = _Calendar.GetWeekOfYear(dateTime, CalendarWeekRule.FirstDay, DayOfWeek.Sunday); | ||||
|         string directory = Path.Combine(_OpenInsightMetrologyViewerFileShare, dateTime.Year.ToString(), $"WW{weekOfYear:00}", _Logistics.Sequence.ToString()); | ||||
|         if (!Directory.Exists(directory)) | ||||
|             _ = Directory.CreateDirectory(directory); | ||||
|         string fullPath = Path.Combine(directory, Path.GetFileName(reportFullPath)); | ||||
|         File.Copy(reportFullPath, fullPath); | ||||
|         WSRequest wsRequest = new(this, _Logistics, descriptions, fullPath); | ||||
|         (string json, WS.Results wsResults) = WS.SendData(_OpenInsightMetrologyViewerAPI, wsRequest); | ||||
|         if (!wsResults.Success) | ||||
|             throw new Exception(wsResults.ToString()); | ||||
| @ -134,7 +141,7 @@ public class FileRead : Shared.FileRead, IFileRead | ||||
|         List<pcl.Description> descriptions = pcl.ProcessData.GetDescriptions(jsonElements); | ||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||
|             SendData(dateTime, descriptions); | ||||
|             SendData(reportFullPath, dateTime, descriptions); | ||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(pdsf.Item1, tests, jsonElements, new List<FileInfo>()); | ||||
|         return results; | ||||
|     } | ||||
|  | ||||
| @ -68,13 +68,15 @@ public class WSRequest | ||||
| #pragma warning disable IDE1006 | ||||
|     public int i { get; set; } | ||||
|     public List<pcl.Detail> Details { get; protected set; } | ||||
|     public string ProcessDataStandardFormat { get; set; } | ||||
|  | ||||
|     [Obsolete("For json")] public WSRequest() { } | ||||
|  | ||||
| #pragma warning disable IDE0060 | ||||
|     internal WSRequest(IFileRead fileRead, Logistics logistics, List<pcl.Description> descriptions) | ||||
|     internal WSRequest(IFileRead fileRead, Logistics logistics, List<pcl.Description> descriptions, string processDataStandardFormat = null) | ||||
| #pragma warning restore IDE0060 | ||||
|     { | ||||
|         ProcessDataStandardFormat = processDataStandardFormat; | ||||
|         i = -1; | ||||
|         Id = 0; | ||||
|         Zone = null; | ||||
| @ -293,7 +295,7 @@ public class WSRequest | ||||
|         string checkFileName; | ||||
|         if (string.IsNullOrEmpty(json)) | ||||
|         { | ||||
|             WSRequest wsRequest = new(fileRead, logistics, descriptions); | ||||
|             WSRequest wsRequest = new(fileRead, logistics, descriptions, string.Empty); | ||||
|             (json, WS.Results wsResults) = WS.SendData(openInsightMetrologyViewerAPI, wsRequest); | ||||
|             if (!wsResults.Success) | ||||
|                 throw new Exception(wsResults.ToString()); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user