/// <summary> /// Send the PDQ audit /// </summary> public static void SendPDQAudit(NHapi.Model.V25.Message.QBP_Q21 request, NHapi.Model.V25.Message.RSP_K21 response) { OutcomeIndicator outcome = OutcomeIndicator.Success; if (!response.MSA.AcknowledgmentCode.Value.EndsWith("A")) { outcome = OutcomeIndicator.EpicFail; } var audit = CreateAudit(ActionType.Execute, outcome, EventIdentifierType.Query, new CodeValue <string>("ITI-21", "IHE Transactions") { DisplayName = "Patient Demographcis Query" }, request, ConfigurationManager.AppSettings["crEndpoint"]); audit.AuditableObjects = new List <AuditableObject>(); // Results found if (response.QAK.QueryResponseStatus.Value == "OK") { for (int i = 0; i < response.QUERY_RESPONSERepetitionsUsed; i++) { audit.AuditableObjects.Add( new AuditableObject() { Type = AuditableObjectType.Person, TypeSpecified = true, Role = AuditableObjectRole.Patient, RoleSpecified = true, LifecycleType = AuditableObjectLifecycle.Export, IDTypeCode = new CodeValue <AuditableObjectIdType>(AuditableObjectIdType.PatientNumber), ObjectId = string.Format("{0}^^^&{1}&ISO", response.GetQUERY_RESPONSE(i).PID.GetPatientIdentifierList(0).IDNumber.Value, response.GetQUERY_RESPONSE(i).PID.GetPatientIdentifierList(0).AssigningAuthority.UniversalID.Value) } ); } } // Query parameters audit.AuditableObjects.Add(new AuditableObject() { Type = AuditableObjectType.SystemObject, TypeSpecified = true, Role = AuditableObjectRole.Query, RoleSpecified = true, ObjectId = request.QPD.QueryTag.Value, IDTypeCode = new CodeValue <AuditableObjectIdType>(AuditableObjectIdType.ITI21), ObjectSpecChoice = ObjectDataChoiceType.ParticipantObjectQuery, ObjectSpec = Convert.ToBase64String(Encoding.UTF8.GetBytes(new PipeParser().Encode(request))), ObjectDetail = new List <ObjectDetailType>() { new ObjectDetailType() { Type = "MSH-10", Value = System.Text.Encoding.UTF8.GetBytes(request.MSH.MessageControlID.Value) } } }); SendAudit(audit); }
/// <summary> /// Create RSP_K21 message /// </summary> internal NHapi.Base.Model.IMessage CreateRSP_K21(RegistryQueryResult result, RegistryQueryRequest filter, List <Everest.Connectors.IResultDetail> dtls) { // Return value var retVal = new NHapi.Model.V25.Message.RSP_K21(); retVal.MSH.MessageType.MessageStructure.Value = "RSP_K21"; var qak = retVal.QAK; var msa = retVal.MSA; var dsc = retVal.DSC; var qpd = retVal.QPD; qak.QueryTag.Value = result.QueryTag; msa.AcknowledgmentCode.Value = "AA"; if (dtls.Exists(o => o.Type == Everest.Connectors.ResultDetailType.Error)) { qak.QueryResponseStatus.Value = "AE"; msa.AcknowledgmentCode.Value = "AE"; foreach (var dtl in dtls) { var err = retVal.GetStructure("ERR", retVal.currentReps("ERR")) as NHapi.Model.V25.Segment.ERR; MessageUtil.UpdateERR(err, dtl, Context); } } else if (result.Results == null || result.Results.Count == 0) { qak.QueryResponseStatus.Value = "NF"; } else { // Create the pid qak.QueryResponseStatus.Value = "OK"; qak.HitCount.Value = result.TotalResults.ToString(); qak.ThisPayload.Value = result.Results.Count.ToString(); //qak.HitsRemaining.Value = (result.TotalResults - result.StartRecordNumber).ToString(); foreach (RegistrationEvent res in result.Results) { var pid = retVal.GetQUERY_RESPONSE(retVal.QUERY_RESPONSERepetitionsUsed); UpdatePID(res, pid.PID, false); UpdateQRI(res, pid.QRI); pid.PID.SetIDPID.Value = retVal.QUERY_RESPONSERepetitionsUsed.ToString(); } // DSC segment? if (result.TotalResults > result.Results.Count) { retVal.DSC.ContinuationPointer.Value = result.ContinuationPtr; retVal.DSC.ContinuationStyle.Value = "I"; } } // Actual query paramaeters var regFilter = filter.QueryRequest.FindComponent(SVC.Core.ComponentModel.HealthServiceRecordSiteRoleType.SubjectOf) as RegistrationEvent; var personFilter = regFilter.FindComponent(SVC.Core.ComponentModel.HealthServiceRecordSiteRoleType.SubjectOf) as Person; qpd.QueryTag.Value = filter.QueryTag; qpd.MessageQueryName.Identifier.Value = "IHE PDQ Query"; var terser = new Terser(retVal); int qpdRep = 0; if (personFilter.GenderCode != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.8"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), personFilter.GenderCode); } if (personFilter.AlternateIdentifiers != null && personFilter.AlternateIdentifiers.Count > 0) { var altId = personFilter.AlternateIdentifiers[0]; if (altId.Domain != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.3.4.2"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), altId.Domain); terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.3.4.3"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), "ISO"); } if (altId.Identifier != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.3.1"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), altId.Identifier); } if (altId.AssigningAuthority != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.3.4.1"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), altId.AssigningAuthority); } } if (personFilter.Names != null && personFilter.Names.Count > 0) { var name = personFilter.Names[0]; foreach (var pt in name.Parts) { string pidNo = ComponentUtility.XPN_MAP.First(o => o.Value == pt.Type).Key; terser.Set(String.Format("/QPD-3({0})-1", qpdRep), String.Format("@PID.5.{0}", pidNo)); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), pt.Value); } if (name.Use != NameSet.NameSetUse.Search) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.5.7"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), ComponentUtility.XPN_USE_MAP.First(o => o.Value == name.Use).Key); } } if (personFilter.BirthTime != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.7"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), new TS(personFilter.BirthTime.Value).Value); } if (personFilter.Addresses != null && personFilter.Addresses.Count > 0) { var addr = personFilter.Addresses[0]; foreach (var pt in addr.Parts) { string pidNo = ComponentUtility.AD_MAP.First(o => o.Value == pt.PartType).Key; terser.Set(String.Format("/QPD-3({0})-1", qpdRep), String.Format("@PID.11.{0}", pidNo)); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), pt.AddressValue); } if (addr.Use != AddressSet.AddressSetUse.Search) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.11.7"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), ComponentUtility.AD_USE_MAP.First(o => o.Value == addr.Use).Key); } } var ma = personFilter.FindComponent(SVC.Core.ComponentModel.HealthServiceRecordSiteRoleType.RepresentitiveOf) as PersonalRelationship; if (ma != null) { if (ma.LegalName != null) { foreach (var pt in ma.LegalName.Parts) { string pidNo = ComponentUtility.XPN_MAP.First(o => o.Value == pt.Type).Key; terser.Set(String.Format("/QPD-3({0})-1", qpdRep), String.Format("@PID.6.{0}", pidNo)); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), pt.Value); } } if (ma.AlternateIdentifiers != null && ma.AlternateIdentifiers.Count > 0) { var altId = ma.AlternateIdentifiers[0]; if (altId.Domain != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.21.4.2"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), altId.Domain); terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.21.4.3"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), "ISO"); } if (altId.Identifier != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.21.1"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), altId.Identifier); } if (altId.AssigningAuthority != null) { terser.Set(String.Format("/QPD-3({0})-1", qpdRep), "@PID.21.4.1"); terser.Set(String.Format("/QPD-3({0})-2", qpdRep++), altId.AssigningAuthority); } } } return(retVal); }