Fixed Archive and Added OpenInsight
This commit is contained in:
		| @ -21,7 +21,13 @@ public class Description : IDescription, Properties.IDescription | ||||
|     public string ReportFullPath { get; set; } | ||||
|     public string ProcessJobID { get; set; } | ||||
|     public string MID { get; set; } | ||||
|     public string Date { get; set; } //2021-10-23 | ||||
|     public string Date { get; set; } | ||||
|     // | ||||
|     public string Employee { get; set; } | ||||
|     public string PSN { get; set; } | ||||
|     public string RDS { get; set; } | ||||
|     public string Reactor { get; set; } | ||||
|     public string Recipe { get; set; } | ||||
|  | ||||
|     string IDescription.GetEventDescription() => "File Has been read and parsed"; | ||||
|  | ||||
| @ -139,4 +145,6 @@ public class Description : IDescription, Properties.IDescription | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     internal static string GetDateFormat() => "MM/dd/yyyy hh:mm:ss tt"; | ||||
|  | ||||
| } | ||||
| @ -54,6 +54,7 @@ public class FileRead : Properties.IFileRead | ||||
|     string Properties.IFileRead.EventName => _EventName; | ||||
|     string Properties.IFileRead.MesEntity => _MesEntity; | ||||
|     bool Properties.IFileRead.IsEAFHosted => _IsEAFHosted; | ||||
|     bool Properties.IFileRead.IsDuplicator => _IsDuplicator; | ||||
|     string Properties.IFileRead.EquipmentType => _EquipmentType; | ||||
|     string Properties.IFileRead.ReportFullPath => _ReportFullPath; | ||||
|     string Properties.IFileRead.CellInstanceName => _CellInstanceName; | ||||
| @ -259,24 +260,23 @@ public class FileRead : Properties.IFileRead | ||||
|         return results; | ||||
|     } | ||||
|  | ||||
|     protected static string GetTupleFile(Logistics logistics, Properties.IScopeInfo scopeInfo, string duplicateDirectory) | ||||
|     protected static string GetTupleFile<T>(Logistics logistics, List<T> descriptions, Properties.IScopeInfo scopeInfo, string duplicateDirectory) where T : Properties.IDescription | ||||
|     { | ||||
|         string result; | ||||
|         string rds; | ||||
|         string dateValue; | ||||
|         string datePlaceholder; | ||||
|         string[] segments = logistics.MID.Split('-'); | ||||
|         if (segments.Length < 2) | ||||
|             rds = "%RDS%"; | ||||
|         string rdsPlaceholder = "%RDS%"; | ||||
|         if (!descriptions.Any() || string.IsNullOrEmpty(descriptions[0].RDS)) | ||||
|             rds = logistics.MID; | ||||
|         else | ||||
|             rds = segments[1]; | ||||
|         segments = scopeInfo.FileName.Split(new string[] { "DateTime:" }, StringSplitOptions.RemoveEmptyEntries); | ||||
|             rds = descriptions[0].RDS; | ||||
|         string[] segments = scopeInfo.FileName.Split(new string[] { "DateTime:" }, StringSplitOptions.RemoveEmptyEntries); | ||||
|         if (segments.Length == 0) | ||||
|             result = string.Concat(duplicateDirectory, @"\", scopeInfo.FileNameWithoutExtension.Replace("%RDS%", rds)); | ||||
|             result = string.Concat(duplicateDirectory, @"\", scopeInfo.FileNameWithoutExtension.Replace(rdsPlaceholder, rds)); | ||||
|         else | ||||
|         { | ||||
|             datePlaceholder = "%DateTime%"; | ||||
|             segments = segments[1].Split('%'); | ||||
|             string datePlaceholder = "%DateTime%"; | ||||
|             dateValue = logistics.DateTimeFromSequence.ToString(segments[0]); | ||||
|             foreach (string segment in scopeInfo.FileName.Split('%')) | ||||
|             { | ||||
| @ -284,18 +284,19 @@ public class FileRead : Properties.IFileRead | ||||
|                     continue; | ||||
|                 datePlaceholder = string.Concat('%', segment, '%'); | ||||
|             } | ||||
|             result = string.Concat(duplicateDirectory, @"\", scopeInfo.FileName.Replace("%RDS%", rds).Replace(datePlaceholder, dateValue)); | ||||
|             result = string.Concat(duplicateDirectory, @"\", scopeInfo.FileName.Replace(rdsPlaceholder, rds).Replace(datePlaceholder, dateValue)); | ||||
|         } | ||||
|         if (result.Contains('%')) | ||||
|             throw new Exception("Placeholder exists!"); | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     protected void WaitForFileConsumption(string sourceDirectoryCloaking, Logistics logistics, DateTime dateTime, string successDirectory, string duplicateDirectory, string duplicateFile, List<(Properties.IScopeInfo, string)> tuples) | ||||
|     protected void WaitForFileConsumption<T>(string sourceDirectoryCloaking, Logistics logistics, DateTime dateTime, List<T> descriptions, string successDirectory, string duplicateDirectory, string duplicateFile, List<(Properties.IScopeInfo, string)> collection) where T : Properties.IDescription | ||||
|     { | ||||
|         bool check; | ||||
|         long preWait; | ||||
|         string tupleFile; | ||||
|         string tupleFileName = string.Empty; | ||||
|         List<string> duplicateFiles = new(); | ||||
|         StringBuilder stringBuilder = new(); | ||||
|         List<int> consumedFileIndices = new(); | ||||
| @ -305,26 +306,28 @@ public class FileRead : Properties.IFileRead | ||||
|             preWait = dateTime.AddMilliseconds(1234).Ticks; | ||||
|         else | ||||
|             preWait = dateTime.AddMilliseconds(_FileConnectorConfiguration.FileHandleWaitTime.Value).Ticks; | ||||
|         if (!tuples.Any()) | ||||
|         if (!collection.Any()) | ||||
|             duplicateFiles.Add(duplicateFile); | ||||
|         string fileName = Path.GetFileNameWithoutExtension(logistics.ReportFullPath); | ||||
|         string successFile = string.Concat(successDirectory, @"\", Path.GetFileName(logistics.ReportFullPath)); | ||||
|         foreach ((Properties.IScopeInfo scopeInfo, string text) in tuples) | ||||
|         foreach ((Properties.IScopeInfo scopeInfo, string text) in collection) | ||||
|         { | ||||
|             if (scopeInfo.FileName.StartsWith(@"\")) | ||||
|                 tupleFile = scopeInfo.FileName; | ||||
|             else if (!scopeInfo.FileName.Contains('%')) | ||||
|                 tupleFile = string.Concat(duplicateDirectory, @"\", fileName, "_", scopeInfo.FileNameWithoutExtension, ".pdsfc"); | ||||
|             else | ||||
|                 tupleFile = GetTupleFile(logistics, scopeInfo, duplicateDirectory); | ||||
|                 tupleFile = GetTupleFile(logistics, descriptions, scopeInfo, duplicateDirectory); | ||||
|             tupleFileName = Path.GetFileNameWithoutExtension(tupleFile).Split('.')[0]; | ||||
|             duplicateFiles.Add(tupleFile); | ||||
|             File.WriteAllText(tupleFile, text); | ||||
|             if (_IsEAFHosted) | ||||
|                 File.WriteAllText(tupleFile, text); | ||||
|         } | ||||
|         for (short i = 0; i < short.MaxValue; i++) | ||||
|         { | ||||
|             if (DateTime.Now.Ticks > preWait) | ||||
|                 break; | ||||
|             Thread.Sleep(500); | ||||
|             Thread.Sleep(100); | ||||
|         } | ||||
|         if (!moreThanAnHour) | ||||
|         { | ||||
| @ -339,7 +342,17 @@ public class FileRead : Properties.IFileRead | ||||
|                         for (int i = 0; i < duplicateFiles.Count; i++) | ||||
|                         { | ||||
|                             if (!File.Exists(duplicateFiles[i])) | ||||
|                                 consumedFileIndices.Add(i); | ||||
|                             { | ||||
|                                 if (string.IsNullOrEmpty(tupleFileName)) | ||||
|                                     consumedFileIndices.Add(i); | ||||
|                                 else if (duplicateFiles.All(l => Path.GetFileNameWithoutExtension(l).Split('.')[0] == tupleFileName)) | ||||
|                                 { | ||||
|                                     for (int j = 0; j < duplicateFiles.Count; j++) | ||||
|                                         consumedFileIndices.Add(j); | ||||
|                                 } | ||||
|                                 else | ||||
|                                     consumedFileIndices.Add(i); | ||||
|                             } | ||||
|                         } | ||||
|                         if (consumedFileIndices.Count == duplicateFiles.Count) | ||||
|                             break; | ||||
| @ -360,7 +373,7 @@ public class FileRead : Properties.IFileRead | ||||
|                     } | ||||
|                     throw new Exception(string.Concat("After {", _BreakAfterSeconds, "} seconds, right side of {", sourceDirectoryCloaking, "} didn't consume file(s) ", stringBuilder)); | ||||
|                 } | ||||
|                 Thread.Sleep(500); | ||||
|                 Thread.Sleep(250); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @ -598,10 +611,10 @@ public class FileRead : Properties.IFileRead | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected void WaitForFileConsumption(DateTime dateTime, bool isDummyRun, string successDirectory, string duplicateDirectory, List<(Properties.IScopeInfo, string)> tuples, string duplicateFile) | ||||
|     protected void WaitForFileConsumption<T>(DateTime dateTime, List<T> descriptions, bool isDummyRun, string successDirectory, string duplicateDirectory, List<(Properties.IScopeInfo, string)> collection, string duplicateFile) where T : Properties.IDescription | ||||
|     { | ||||
|         if (!isDummyRun && _IsEAFHosted) | ||||
|             WaitForFileConsumption(_FileConnectorConfiguration.SourceDirectoryCloaking, _Logistics, dateTime, successDirectory, duplicateDirectory, duplicateFile, tuples); | ||||
|             WaitForFileConsumption(_FileConnectorConfiguration.SourceDirectoryCloaking, _Logistics, dateTime, descriptions, successDirectory, duplicateDirectory, duplicateFile, collection); | ||||
|         else | ||||
|         { | ||||
|             long breakAfter = DateTime.Now.AddSeconds(_FileConnectorConfiguration.FileHandleWaitTime.Value).Ticks; | ||||
|  | ||||
| @ -9,55 +9,67 @@ namespace Adaptation.Shared; | ||||
| public class Logistics : ILogistics | ||||
| { | ||||
|  | ||||
|     public object NullData { get; private set; } | ||||
|     public string JobID { get; private set; } //CellName | ||||
|     public long Sequence { get; private set; } //Ticks | ||||
|     public DateTime DateTimeFromSequence { get; private set; } | ||||
|     public double TotalSecondsSinceLastWriteTimeFromSequence { get; private set; } | ||||
|     public string MesEntity { get; private set; } //SPC | ||||
|     public string ReportFullPath { get; private set; } //Extract file | ||||
|     public string ProcessJobID { get; set; } //Reactor (duplicate but I want it in the logistics) | ||||
|     public string MID { get; set; } //Lot & Pocket || Lot | ||||
|     public List<string> Tags { get; set; } | ||||
|     public List<string> Logistics1 { get; set; } | ||||
|     public List<Logistics2> Logistics2 { get; set; } | ||||
|     protected readonly DateTime _DateTimeFromSequence; | ||||
|     protected readonly FileInfo _FileInfo; | ||||
|     protected readonly string _JobID; | ||||
|     protected readonly List<string> _Logistics1; | ||||
|     protected readonly List<Logistics2> _Logistics2; | ||||
|     protected string _MID; | ||||
|     protected readonly string _MesEntity; | ||||
|     protected readonly object _NullData; | ||||
|     protected string _ProcessJobID; | ||||
|     protected readonly string _ReportFullPath; | ||||
|     protected readonly long _Sequence; | ||||
|     protected readonly double _TotalSecondsSinceLastWriteTimeFromSequence; | ||||
|  | ||||
|     public DateTime DateTimeFromSequence => _DateTimeFromSequence; | ||||
|     public FileInfo FileInfo => _FileInfo; | ||||
|     public string JobID => _JobID; | ||||
|     public List<string> Logistics1 => _Logistics1; | ||||
|     public List<Logistics2> Logistics2 => _Logistics2; | ||||
|     public string MID => _MID; | ||||
|     public string MesEntity => _MesEntity; | ||||
|     public object NullData => _NullData; | ||||
|     public string ProcessJobID => _ProcessJobID; | ||||
|     public string ReportFullPath => _ReportFullPath; | ||||
|     public long Sequence => _Sequence; | ||||
|     public double TotalSecondsSinceLastWriteTimeFromSequence => _TotalSecondsSinceLastWriteTimeFromSequence; | ||||
|  | ||||
|     public Logistics(IFileRead fileRead) | ||||
|     { | ||||
|         DateTime dateTime = DateTime.Now; | ||||
|         NullData = null; | ||||
|         Sequence = dateTime.Ticks; | ||||
|         DateTimeFromSequence = dateTime; | ||||
|         JobID = fileRead.CellInstanceName; | ||||
|         TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|         MesEntity = DefaultMesEntity(dateTime); | ||||
|         ReportFullPath = string.Empty; | ||||
|         ProcessJobID = nameof(ProcessJobID); | ||||
|         MID = nameof(MID); | ||||
|         Tags = new List<string>(); | ||||
|         Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|         Logistics2 = new List<Logistics2>(); | ||||
|         _NullData = null; | ||||
|         _Sequence = dateTime.Ticks; | ||||
|         _DateTimeFromSequence = dateTime; | ||||
|         _JobID = fileRead.CellInstanceName; | ||||
|         _TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|         _MesEntity = DefaultMesEntity(dateTime); | ||||
|         _ReportFullPath = string.Empty; | ||||
|         _ProcessJobID = nameof(ProcessJobID); | ||||
|         _MID = nameof(MID); | ||||
|         _Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|         _Logistics2 = new List<Logistics2>(); | ||||
|     } | ||||
|  | ||||
|     public Logistics(IFileRead fileRead, string reportFullPath, bool useSplitForMID, int? fileInfoLength = null) | ||||
|     public Logistics(IFileRead fileRead, long tickOffset, string reportFullPath, bool useSplitForMID, int? fileInfoLength = null) | ||||
|     { | ||||
|         if (string.IsNullOrEmpty(fileRead.CellInstanceName)) | ||||
|             throw new Exception(); | ||||
|         if (string.IsNullOrEmpty(fileRead.MesEntity)) | ||||
|             throw new Exception(); | ||||
|         NullData = fileRead.NullData; | ||||
|         FileInfo fileInfo = new(reportFullPath); | ||||
|         DateTime dateTime = fileInfo.LastWriteTime; | ||||
|         if (fileInfoLength.HasValue && fileInfo.Length < fileInfoLength.Value) | ||||
|         _NullData = fileRead.NullData; | ||||
|         _FileInfo = new(reportFullPath); | ||||
|         DateTime dateTime = new(_FileInfo.LastWriteTime.Ticks + tickOffset); | ||||
|         if (fileInfoLength.HasValue && _FileInfo.Length < fileInfoLength.Value) | ||||
|             dateTime = dateTime.AddTicks(-1); | ||||
|         JobID = fileRead.CellInstanceName; | ||||
|         Sequence = dateTime.Ticks; | ||||
|         DateTimeFromSequence = dateTime; | ||||
|         TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|         MesEntity = fileRead.MesEntity; | ||||
|         ReportFullPath = fileInfo.FullName; | ||||
|         ProcessJobID = nameof(ProcessJobID); | ||||
|         string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(fileInfo.FullName); | ||||
|         _JobID = fileRead.CellInstanceName; | ||||
|         _Sequence = dateTime.Ticks; | ||||
|         _DateTimeFromSequence = dateTime; | ||||
|         _TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|         _MesEntity = fileRead.MesEntity; | ||||
|         _ReportFullPath = _FileInfo.FullName; | ||||
|         _ProcessJobID = nameof(ProcessJobID); | ||||
|         string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(_FileInfo.FullName); | ||||
|         if (useSplitForMID) | ||||
|         { | ||||
|             if (fileNameWithoutExtension.IndexOf(".") > -1) | ||||
| @ -67,10 +79,9 @@ public class Logistics : ILogistics | ||||
|             if (fileNameWithoutExtension.IndexOf("-") > -1) | ||||
|                 fileNameWithoutExtension = fileNameWithoutExtension.Split('-')[0].Trim(); | ||||
|         } | ||||
|         MID = string.Concat(fileNameWithoutExtension.Substring(0, 1).ToUpper(), fileNameWithoutExtension.Substring(1).ToLower()); | ||||
|         Tags = new List<string>(); | ||||
|         Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|         Logistics2 = new List<Logistics2>(); | ||||
|         _MID = string.Concat(fileNameWithoutExtension.Substring(0, 1).ToUpper(), fileNameWithoutExtension.Substring(1).ToLower()); | ||||
|         _Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|         _Logistics2 = new List<Logistics2>(); | ||||
|     } | ||||
|  | ||||
|     public Logistics(string reportFullPath, string logistics) | ||||
| @ -78,57 +89,57 @@ public class Logistics : ILogistics | ||||
|         string key; | ||||
|         DateTime dateTime; | ||||
|         string[] segments; | ||||
|         Logistics1 = logistics.Split(new string[] { Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries).ToList(); | ||||
|         _FileInfo = new(reportFullPath); | ||||
|         _Logistics1 = logistics.Split(new string[] { Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries).ToList(); | ||||
|         if (!Logistics1.Any() || !Logistics1[0].StartsWith("LOGISTICS_1")) | ||||
|         { | ||||
|             NullData = null; | ||||
|             JobID = "null"; | ||||
|             dateTime = new FileInfo(reportFullPath).LastWriteTime; | ||||
|             Sequence = dateTime.Ticks; | ||||
|             DateTimeFromSequence = dateTime; | ||||
|             TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|             MesEntity = DefaultMesEntity(dateTime); | ||||
|             ReportFullPath = reportFullPath; | ||||
|             ProcessJobID = "R##"; | ||||
|             MID = "null"; | ||||
|             Tags = new List<string>(); | ||||
|             Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|             Logistics2 = new List<Logistics2>(); | ||||
|             _NullData = null; | ||||
|             _JobID = "null"; | ||||
|             dateTime = _FileInfo.LastWriteTime; | ||||
|             _Sequence = dateTime.Ticks; | ||||
|             _DateTimeFromSequence = dateTime; | ||||
|             _TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|             _MesEntity = DefaultMesEntity(dateTime); | ||||
|             _ReportFullPath = reportFullPath; | ||||
|             _ProcessJobID = "R##"; | ||||
|             _MID = "null"; | ||||
|             _Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|             _Logistics2 = new List<Logistics2>(); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             string logistics1Line1 = Logistics1[0]; | ||||
|             key = "NULL_DATA="; | ||||
|             if (!logistics1Line1.Contains(key)) | ||||
|                 NullData = null; | ||||
|                 _NullData = null; | ||||
|             else | ||||
|             { | ||||
|                 segments = logistics1Line1.Split(new string[] { key }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                 NullData = segments[1].Split(';')[0]; | ||||
|                 _NullData = segments[1].Split(';')[0]; | ||||
|             } | ||||
|             key = "JOBID="; | ||||
|             if (!logistics1Line1.Contains(key)) | ||||
|                 JobID = "null"; | ||||
|                 _JobID = "null"; | ||||
|             else | ||||
|             { | ||||
|                 segments = logistics1Line1.Split(new string[] { key }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                 JobID = segments[1].Split(';')[0]; | ||||
|                 _JobID = segments[1].Split(';')[0]; | ||||
|             } | ||||
|             key = "SEQUENCE="; | ||||
|             if (!logistics1Line1.Contains(key)) | ||||
|                 dateTime = new FileInfo(reportFullPath).LastWriteTime; | ||||
|                 dateTime = _FileInfo.LastWriteTime; | ||||
|             else | ||||
|             { | ||||
|                 segments = logistics1Line1.Split(new string[] { key }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                 if (!long.TryParse(segments[1].Split(';')[0].Split('.')[0], out long sequence) || sequence < new DateTime(1999, 1, 1).Ticks) | ||||
|                     dateTime = new FileInfo(reportFullPath).LastWriteTime; | ||||
|                     dateTime = _FileInfo.LastWriteTime; | ||||
|                 else | ||||
|                     dateTime = new DateTime(sequence); | ||||
|             } | ||||
|             Sequence = dateTime.Ticks; | ||||
|             DateTimeFromSequence = dateTime; | ||||
|             TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|             DateTime lastWriteTime = new FileInfo(reportFullPath).LastWriteTime; | ||||
|             _Sequence = dateTime.Ticks; | ||||
|             _DateTimeFromSequence = dateTime; | ||||
|             _TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTime).TotalSeconds; | ||||
|             DateTime lastWriteTime = _FileInfo.LastWriteTime; | ||||
|             if (TotalSecondsSinceLastWriteTimeFromSequence > 600) | ||||
|             { | ||||
|                 if (lastWriteTime != dateTime) | ||||
| @ -138,33 +149,32 @@ public class Logistics : ILogistics | ||||
|             } | ||||
|             key = "MES_ENTITY="; | ||||
|             if (!logistics1Line1.Contains(key)) | ||||
|                 MesEntity = DefaultMesEntity(dateTime); | ||||
|                 _MesEntity = DefaultMesEntity(dateTime); | ||||
|             else | ||||
|             { | ||||
|                 segments = logistics1Line1.Split(new string[] { key }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                 MesEntity = segments[1].Split(';')[0]; | ||||
|                 _MesEntity = segments[1].Split(';')[0]; | ||||
|             } | ||||
|             ReportFullPath = reportFullPath; | ||||
|             _ReportFullPath = reportFullPath; | ||||
|             key = "PROCESS_JOBID="; | ||||
|             if (!logistics1Line1.Contains(key)) | ||||
|                 ProcessJobID = "R##"; | ||||
|                 _ProcessJobID = "R##"; | ||||
|             else | ||||
|             { | ||||
|                 segments = logistics1Line1.Split(new string[] { key }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                 ProcessJobID = segments[1].Split(';')[0]; | ||||
|                 _ProcessJobID = segments[1].Split(';')[0]; | ||||
|             } | ||||
|             key = "MID="; | ||||
|             if (!logistics1Line1.Contains(key)) | ||||
|                 MID = "null"; | ||||
|                 _MID = "null"; | ||||
|             else | ||||
|             { | ||||
|                 segments = logistics1Line1.Split(new string[] { key }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                 MID = segments[1].Split(';')[0]; | ||||
|                 _MID = segments[1].Split(';')[0]; | ||||
|             } | ||||
|         } | ||||
|         Logistics2 logistics2; | ||||
|         Tags = new List<string>(); | ||||
|         Logistics2 = new List<Logistics2>(); | ||||
|         _Logistics2 = new List<Logistics2>(); | ||||
|         for (int i = 1; i < Logistics1.Count; i++) | ||||
|         { | ||||
|             if (Logistics1[i].StartsWith("LOGISTICS_2")) | ||||
| @ -180,29 +190,12 @@ public class Logistics : ILogistics | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public Logistics ShallowCopy() => (Logistics)MemberwiseClone(); | ||||
|  | ||||
|     private static string DefaultMesEntity(DateTime dateTime) => string.Concat(dateTime.Ticks, "_MES_ENTITY"); | ||||
|  | ||||
|     internal string GetLotViaMostCommonMethod() => MID.Substring(0, MID.Length - 2); | ||||
|  | ||||
|     internal string GetPocketNumberViaMostCommonMethod() => MID.Substring(MID.Length - 2); | ||||
|  | ||||
|     internal void Update(string dateTime, string processJobID, string mid) | ||||
|     internal void Update(string mid, string processJobID) | ||||
|     { | ||||
|         if (!DateTime.TryParse(dateTime, out DateTime dateTimeCasted)) | ||||
|             dateTimeCasted = DateTime.Now; | ||||
|         NullData = null; | ||||
|         //JobID = Description.GetCellName(); | ||||
|         Sequence = dateTimeCasted.Ticks; | ||||
|         DateTimeFromSequence = dateTimeCasted; | ||||
|         TotalSecondsSinceLastWriteTimeFromSequence = (DateTime.Now - dateTimeCasted).TotalSeconds; | ||||
|         //MesEntity = DefaultMesEntity(dateTime); | ||||
|         //ReportFullPath = string.Empty; | ||||
|         ProcessJobID = processJobID; | ||||
|         MID = mid; | ||||
|         Tags = new List<string>(); | ||||
|         Logistics1 = new string[] { string.Concat("LOGISTICS_1", '\t', "A_JOBID=", JobID, ";A_MES_ENTITY=", MesEntity, ";") }.ToList(); | ||||
|         Logistics2 = new List<Logistics2>(); | ||||
|         _MID = mid; | ||||
|         _ProcessJobID = processJobID; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @ -16,7 +16,7 @@ public class ScopeInfo : Properties.IScopeInfo | ||||
|     public string QueryFilter { get; private set; } | ||||
|     public string FileNameWithoutExtension { get; private set; } | ||||
|  | ||||
|     public ScopeInfo(Test test, string fileName, string queryFilter = "", string title = "", string html = "") | ||||
|     public ScopeInfo(Test test, string fileName, string queryFilter = "", string title = "", string html = "", string extraExtension = "") | ||||
|     { | ||||
|         Enum = test; | ||||
|         Test = test; | ||||
|  | ||||
| @ -30,7 +30,7 @@ public partial class WS | ||||
|                 }; | ||||
|                 HttpResponseMessage httpResponseMessage = httpClient.SendAsync(httpRequestMessage, HttpCompletionOption.ResponseContentRead).Result; | ||||
|                 resultsJson = httpResponseMessage.Content.ReadAsStringAsync().Result; | ||||
|                 results = JsonSerializer.Deserialize<Results>(resultsJson); | ||||
|                 results = JsonSerializer.Deserialize<Results>(resultsJson, new JsonSerializerOptions { PropertyNameCaseInsensitive = true }); | ||||
|             } | ||||
|             if (!results.Success) | ||||
|                 results.Errors.Add(results.ToString()); | ||||
| @ -44,8 +44,8 @@ public partial class WS | ||||
|                 _ = stringBuilder.AppendLine(exception.Message); | ||||
|                 exception = exception.InnerException; | ||||
|             } | ||||
|             if (results.Errors is null) | ||||
|                 results.Errors = new List<string>(); | ||||
|             results.Errors ??= new List<string>(); | ||||
|             results.Errors.Add(resultsJson); | ||||
|             results.Errors.Add(stringBuilder.ToString()); | ||||
|         } | ||||
|         return new(resultsJson, results); | ||||
|  | ||||
| @ -91,8 +91,7 @@ public class ProcessDataStandardFormat | ||||
|         string segment; | ||||
|         List<string> body = new(); | ||||
|         StringBuilder logistics = new(); | ||||
|         if (lines is null) | ||||
|             lines = File.ReadAllLines(reportFullPath); | ||||
|         lines ??= File.ReadAllLines(reportFullPath); | ||||
|         string[] segments; | ||||
|         if (lines.Length < 7) | ||||
|             segments = Array.Empty<string>(); | ||||
| @ -276,8 +275,7 @@ public class ProcessDataStandardFormat | ||||
|     public static string GetLines(Logistics logistics, Properties.IScopeInfo scopeInfo, List<string> names, Dictionary<string, List<string>> keyValuePairs, string dateFormat, string timeFormat, List<string> pairedParameterNames, bool useDateTimeFromSequence = true, string format = "", List<string> ignoreParameterNames = null) | ||||
|     { | ||||
|         StringBuilder result = new(); | ||||
|         if (ignoreParameterNames is null) | ||||
|             ignoreParameterNames = new List<string>(); | ||||
|         ignoreParameterNames ??= new List<string>(); | ||||
|         if (useDateTimeFromSequence && !string.IsNullOrEmpty(format)) | ||||
|             throw new Exception(); | ||||
|         else if (!useDateTimeFromSequence && string.IsNullOrEmpty(format)) | ||||
| @ -357,8 +355,7 @@ public class ProcessDataStandardFormat | ||||
|             if (string.IsNullOrEmpty(lines[i])) | ||||
|                 continue; | ||||
|             segments = lines[i].Split(inputSeparator); | ||||
|             if (currentGroup is null) | ||||
|                 currentGroup = segments.Length; | ||||
|             currentGroup ??= segments.Length; | ||||
|             if (segments.Length != currentGroup) | ||||
|             { | ||||
|                 currentGroup = segments.Length; | ||||
|  | ||||
| @ -7,4 +7,13 @@ public interface IDescription | ||||
|     int Count { get; } | ||||
|     int Index { get; } | ||||
|  | ||||
|     string MesEntity { get; } | ||||
|     string Date { get; } | ||||
|  | ||||
|     string Employee { get; } | ||||
|     string PSN { get; } | ||||
|     string RDS { get; } | ||||
|     string Reactor { get; } | ||||
|     string Recipe { get; } | ||||
|  | ||||
| } | ||||
| @ -7,6 +7,7 @@ public interface IFileRead | ||||
|     string MesEntity { get; } | ||||
|     bool IsEAFHosted { get; } | ||||
|     string EventName { get; } | ||||
|     bool IsDuplicator { get; } | ||||
|     string EquipmentType { get; } | ||||
|     string ReportFullPath { get; } | ||||
|     string CellInstanceName { get; } | ||||
|  | ||||
| @ -1,22 +1,23 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.IO; | ||||
|  | ||||
| namespace Adaptation.Shared.Properties; | ||||
|  | ||||
| public interface ILogistics | ||||
| { | ||||
|  | ||||
|     public object NullData { get; } | ||||
|     public string JobID { get; } //CellName | ||||
|     public long Sequence { get; } //Ticks | ||||
|     public DateTime DateTimeFromSequence { get; } | ||||
|     public FileInfo FileInfo { get; } | ||||
|     public string JobID { get; } | ||||
|     public List<string> Logistics1 { get; } | ||||
|     public List<Logistics2> Logistics2 { get; } | ||||
|     public string MID { get; } | ||||
|     public string MesEntity { get; } | ||||
|     public object NullData { get; } | ||||
|     public string ProcessJobID { get; } | ||||
|     public string ReportFullPath { get; } | ||||
|     public long Sequence { get; } | ||||
|     public double TotalSecondsSinceLastWriteTimeFromSequence { get; } | ||||
|     public string MesEntity { get; } //SPC | ||||
|     public string ReportFullPath { get; } //Extract file | ||||
|     public string ProcessJobID { get; set; } //Reactor (duplicate but I want it in the logistics) | ||||
|     public string MID { get; set; } //Lot & Pocket || Lot | ||||
|     public List<string> Tags { get; set; } | ||||
|     public List<string> Logistics1 { get; set; } | ||||
|     public List<Logistics2> Logistics2 { get; set; } | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user