public void QueryTest() { try { //var newHeader = new CobasE6000RequestInformationRecord(@"Q|1|^^ ^1^5032^1^^S1^SC||ALL||||||||O"); var newHeader = new CobasE6000RequestInformationRecord(@"Q|1|^^121108010001 ^1^5032^1^^S1^SC^R1||ALL||||||||O"); //var tempP = new CobasE6000PatientInformationRecord(@"P|1|||||||M||||||35^Y||||||||||||||||||||"); //Debug.WriteLine(tempP.Create()); Debug.WriteLine(newHeader.GetOrderBarcode()); Debug.WriteLine(newHeader.Create()); } catch (Exception ex) { Debug.WriteLine(ex.ToString()); } }
public Cobase6000BiManager() { try { //if (DateTime.Now > new DateTime(2013, 06, 06)) throw new Exception("XXX"); _clsHRecord = new CobasE6000HeaderRecord(); _clsPRecord = new CobasE6000PatientInformationRecord(); _clsORecord = new CobasE6000TestOrderRecord(); _clsQRecord = new CobasE6000RequestInformationRecord(); _clsRRecord = new CobasE6000ResultRecord(); _clsTRecord = new CobasE6000TerminationRecord(); } catch (Exception ex) { Log.Error("Fatal Error: {0}", ex); } }
public Cobase6000Bi() { try { _clsHRecord = new CobasE6000HeaderRecord(); _clsPRecord = new CobasE6000PatientInformationRecord(); _clsORecord = new CobasE6000TestOrderRecord(); _clsQRecord = new CobasE6000RequestInformationRecord(); _clsRRecord = new CobasE6000ResultRecord(); _clsTRecord = new CobasE6000TerminationRecord(); _prvRequestArray = new Queue <List <string> >(); _objService = new ExternalDataExchangeService(); _failSending = 0; _instanceId = Guid.NewGuid(); _objWorkFlowRuntime.AddService(_objService); _objAstm = new ClsAstm(); _objService.AddService(_objAstm); _objAstm.SendACKEvent += objASTM_SendACKEvent; _objAstm.SendNAKEvent += objASTM_SendNAKEvent; _objAstm.SendENQEvent += objASTM_SendENQEvent; _objAstm.SendEOTEvent += objASTM_SendEOTEvent; //_objAstm.ACKTimeoutEvent += new EventHandler(_objAstm_ACKTimeoutEvent); _objWorkFlowInstance = _objWorkFlowRuntime.CreateWorkflow(typeof(ASTMWorkflow), null, _instanceId); _objWorkFlowInstance.Start(); Console.WriteLine(@"Work flow started"); _objDataEventArgs = new ExternalDataEventArgs(_instanceId) { WaitForIdle = true }; DumpStateMachine(_objWorkFlowRuntime, _instanceId); } catch (Exception ex) { Log.Error("Fatal Error: {0}", ex); } }
private void ProcessData() { try { var arrRecords = new string[] {}; if (_bufferData != string.Empty) { arrRecords = _bufferData.Split(new[] { _clsRRecord.Rules.EndOfRecordCharacter }, StringSplitOptions.RemoveEmptyEntries); } var i = 0; while (i < arrRecords.Length) { var arrFields = arrRecords[i].Split(_clsPRecord.Rules.FieldDelimiter); if (arrFields[0].Equals(_clsRRecord.RecordType.Data)) { _clsRRecord = new CobasE6000ResultRecord(arrRecords[i]); AddResult(_clsRRecord.GetResult()); _newResult = true; } if (arrFields[0].StartsWith(_clsPRecord.RecordType.Data)) { _clsPRecord = new CobasE6000PatientInformationRecord(arrRecords[i]); } else if (arrFields[0].StartsWith(_clsORecord.RecordType.Data)) { _clsORecord = new CobasE6000TestOrderRecord(arrRecords[i]); TestResult.Barcode = _clsORecord.SpecimenId.Data.Trim(); var tempDate = _clsORecord.DateTimeResultReportedOrLastModified.Data; TestResult.TestDate = string.Format("{0}/{1}/{2}", tempDate.Substring(6, 2), tempDate.Substring(4, 2), tempDate.Substring(0, 4)); } else if (arrFields[0].Equals(_clsQRecord.RecordType.Data)) { _clsQRecord = new CobasE6000RequestInformationRecord(arrRecords[i]); _sQBarcode = _clsQRecord.GetOrderBarcode(); _newQuery = true; var regList = GetRegList(_sQBarcode); if (regList != null) { if (regList.Count > 0) { Log.Debug(string.Format("So order: {0}", regList.Count.ToString())); foreach (string s in regList) { Log.Debug(string.Format("{0}\r\n", s)); } } else { Log.Debug("No order!"); } } else { Log.Debug("No order!"); } _prvRequestArray.Enqueue(CreateOrderFrame(regList)); } else if (arrFields[0].Equals(_clsHRecord.RecordType.Data)) { _clsHRecord = new CobasE6000HeaderRecord(arrRecords[i]); } i++; } if (_newQuery) { //Send((int)EventID.OpenNewOutputSession, _sQBarcode); _objAstm.CallGetQuery(_objDataEventArgs); if ((_prvRequestArray != null) && (_prvRequestArray.Count != 0)) { _currentOrder.Clear(); _currentOrder = _prvRequestArray.Dequeue(); _currentOrderIdx = 0; } //SendByte((byte)DeviceHelper.ENQ); _newQuery = false; } if (_newResult) { Log.Debug("Begin Import Result"); Log.Debug(ImportResults() ? "Import Result Success" : "Error While Import Result"); _newResult = false; } } catch (Exception ex) { Log.Error("Fatal Error:{0}", ex.ToString()); } }
public override bool ProcessData(string inputBuffer, ref List <string> orderList) { try { var arrRecords = new string[] {}; if (inputBuffer != string.Empty) { arrRecords = inputBuffer.Split(new[] { _clsRRecord.Rules.EndOfRecordCharacter }, StringSplitOptions.RemoveEmptyEntries); } int i = 0; bool _newResult = false; while (i < arrRecords.Length) { string[] arrFields = arrRecords[i].Split(_clsPRecord.Rules.FieldDelimiter); if (arrFields[0].Equals(_clsRRecord.RecordType.Data)) { _clsRRecord = new CobasE6000ResultRecord(arrRecords[i]); AddResult(_clsRRecord.GetResult()); _newResult = true; } if (arrFields[0].StartsWith(_clsPRecord.RecordType.Data)) { _clsPRecord = new CobasE6000PatientInformationRecord(arrRecords[i]); } else if (arrFields[0].StartsWith(_clsORecord.RecordType.Data)) { _clsORecord = new CobasE6000TestOrderRecord(arrRecords[i]); TestResult.Barcode = _clsORecord.SpecimenId.Data.Trim(); string tempDate = _clsORecord.DateTimeResultReportedOrLastModified.Data; TestResult.TestDate = string.Format("{0}/{1}/{2}", tempDate.Substring(6, 2), tempDate.Substring(4, 2), tempDate.Substring(0, 4)); } else if (arrFields[0].Equals(_clsQRecord.RecordType.Data)) { _clsQRecord = new CobasE6000RequestInformationRecord(arrRecords[i]); _sQBarcode = _clsQRecord.GetOrderBarcode(); List <string> regList = GetRegList(_sQBarcode); if (regList != null) { if (regList.Count > 0) { Log.Debug(string.Format("So order: {0}", regList.Count)); foreach (string s in regList) { Log.Debug(string.Format("{0}\r\n", s)); } } else { Log.Debug("No order!"); } } else { Log.Debug("No order!"); } orderList = CreateOrderFrame(regList); return(true); } else if (arrFields[0].Equals(_clsHRecord.RecordType.Data)) { _clsHRecord = new CobasE6000HeaderRecord(arrRecords[i]); } i++; } if (_newResult) { Log.Debug("Begin Import Result"); Log.Debug(ImportResults() ? "Import Result Success" : "Error While Import Result"); return(false); } } catch (Exception ex) { Log.Error("Fatal Error:{0}", ex.ToString()); } return(false); }