public async Task <Result <string> > Handle(AfyaMobileFamilyScreeningEncounterCommand request, CancellationToken cancellationToken) { string afyaMobileId = string.Empty; string indexClientAfyaMobileId = string.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { try { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "INDEX_CLIENT_AFYAMOBILE_ID") { indexClientAfyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); var indexClientIdentifiers = await registerPersonService.getPersonIdentifiers(indexClientAfyaMobileId, 10); if (indexClientIdentifiers.Count > 0) { //Get Index client var indexClient = await registerPersonService.GetPatientByPersonId(indexClientIdentifiers[0].PersonId); var partnetPersonIdentifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (partnetPersonIdentifiers.Count > 0) { DateTime screeningDate = DateTime.Now; try { screeningDate = DateTime.ParseExact(request.SCREENING_ENCOUNTER.FAMILY_SCREENING.SCREENING_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse family screening SCREENING_DATE: {request.SCREENING_ENCOUNTER.FAMILY_SCREENING.SCREENING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse family screening SCREENING_DATE: {request.SCREENING_ENCOUNTER.FAMILY_SCREENING.SCREENING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } int hivStatus = request.SCREENING_ENCOUNTER.FAMILY_SCREENING.HIV_STATUS; int eligible = request.SCREENING_ENCOUNTER.FAMILY_SCREENING.ELIGIBLE_FOR_HTS; DateTime bookingDate = DateTime.Now; try { bookingDate = DateTime.ParseExact(request.SCREENING_ENCOUNTER.FAMILY_SCREENING.BOOKING_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse family screening BOOKING_DATE: {request.SCREENING_ENCOUNTER.FAMILY_SCREENING.BOOKING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse family screening BOOKING_DATE: {request.SCREENING_ENCOUNTER.FAMILY_SCREENING.BOOKING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd. Exception: {e.Message}"); } string remarks = request.SCREENING_ENCOUNTER.FAMILY_SCREENING.REMARKS; var familyScreenings = await _unitOfWork.Repository <LookupItemView>().Get(x => x.MasterName == "FamilyScreening") .ToListAsync(); List <Screening> familyScreeningList = new List <Screening>(); for (int j = 0; j < familyScreenings.Count; j++) { if (familyScreenings[j].ItemName == "EligibleTesting") { Screening screening = new Screening() { ScreeningCategoryId = familyScreenings[j].ItemId, ScreeningTypeId = familyScreenings[j].MasterId, ScreeningValueId = eligible }; familyScreeningList.Add(screening); } else if (familyScreenings[j].ItemName == "ScreeningHivStatus") { Screening screening = new Screening() { ScreeningCategoryId = familyScreenings[j].ItemId, ScreeningTypeId = familyScreenings[j].MasterId, ScreeningValueId = hivStatus }; familyScreeningList.Add(screening); } } var patientMasterVisitEntity = await _unitOfWork.Repository <PatientMasterVisit>() .Get(x => x.PatientId == indexClient.Id && x.ServiceId == 2).ToListAsync(); int patientMasterVisitId = patientMasterVisitEntity.OrderBy(x => x.Id).FirstOrDefault().Id; var familyScreeningReturnValue = await encounterTestingService.AddPartnerScreening(partnetPersonIdentifiers[0].PersonId, indexClient.Id, patientMasterVisitId, null, screeningDate, bookingDate, familyScreeningList, 1); var stringParnerObject = Newtonsoft.Json.JsonConvert.SerializeObject(new { familyId = partnetPersonIdentifiers[0].PersonId, familyTraced = true }); var partnerScreeningDone = await registerPersonService.AddAppStateStore(indexClient.PersonId, indexClient.Id, 10, null, null, stringParnerObject); var familyHivStatus = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "ScreeningHivStatus" && x.ItemId == hivStatus).ToListAsync(); if (familyHivStatus.Count > 0 && familyHivStatus[0].ItemName == "Positive") { var stringFamilyScreenedPositiveObject = Newtonsoft.Json.JsonConvert.SerializeObject(new { familyId = partnetPersonIdentifiers[0].PersonId, familyTraced = true }); var hasFamiyBeenScreenedPositive = await registerPersonService.AddAppStateStore(indexClient.PersonId, indexClient.Id, 14, null, null, stringFamilyScreenedPositiveObject); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Family member with afyamobileid: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Family member with afyamobileid: {afyaMobileId} could not be found")); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Index client with afyamobileid: {indexClientAfyaMobileId} could not be found for family member: {afyaMobileId}", false); return(Result <string> .Invalid($"Index client with afyamobileid: {indexClientAfyaMobileId} could not be found for family member: {afyaMobileId}")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized family screening for clientid: {indexClientAfyaMobileId} and partnerid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized family screening for afyamobileId: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize family screening for clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize family screening for clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobileFamilyTracingEncounterCommand request, CancellationToken cancellationToken) { string afyaMobileId = string.Empty; string indexClientAfyaMobileId = string.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { try { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "INDEX_CLIENT_AFYAMOBILE_ID") { indexClientAfyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); var indexClientIdentifiers = await registerPersonService.getPersonIdentifiers(indexClientAfyaMobileId, 10); if (indexClientIdentifiers.Count > 0) { //Get Index client var indexClient = await registerPersonService.GetPatientByPersonId(indexClientIdentifiers[0].PersonId); var partnetPersonIdentifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (partnetPersonIdentifiers.Count > 0) { for (int j = 0; j < request.TRACING_ENCOUNTER.TRACING.Count; j++) { var lookupitem = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "TracingType" && x.ItemName == "Family").ToListAsync(); int tracingType = lookupitem[0].ItemId; DateTime tracingDate = DateTime.Now; try { tracingDate = DateTime.ParseExact(request.TRACING_ENCOUNTER.TRACING[j].TRACING_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse family tracing TRACING_DATE: {request.TRACING_ENCOUNTER.TRACING[j].TRACING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse family tracing TRACING_DATE: {request.TRACING_ENCOUNTER.TRACING[j].TRACING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } int mode = request.TRACING_ENCOUNTER.TRACING[j].TRACING_MODE; int outcome = request.TRACING_ENCOUNTER.TRACING[j].TRACING_OUTCOME; DateTime?reminderDate = null; if (!string.IsNullOrWhiteSpace(request.TRACING_ENCOUNTER.TRACING[j].REMINDER_DATE)) { reminderDate = DateTime.ParseExact(request.TRACING_ENCOUNTER.TRACING[j].REMINDER_DATE, "yyyyMMdd", null); } DateTime?tracingBookingDate = null; if (!string.IsNullOrWhiteSpace(request.TRACING_ENCOUNTER.TRACING[j].BOOKING_DATE)) { tracingBookingDate = DateTime.ParseExact(request.TRACING_ENCOUNTER.TRACING[j].BOOKING_DATE, "yyyyMMdd", null); } int consent = request.TRACING_ENCOUNTER.TRACING[j].CONSENT; int? reasonnotcontacted = request.TRACING_ENCOUNTER.TRACING[j].REASONNOTCONTACTED; string reasonnotcontactedother = request.TRACING_ENCOUNTER.TRACING[j].REASONNOTCONTACTEDOTHER; var trace = await encounterTestingService.addTracing(partnetPersonIdentifiers[0].PersonId, tracingType, tracingDate, mode, outcome, 1, null, consent, tracingBookingDate, reminderDate, reasonnotcontacted, reasonnotcontactedother); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Family member with afyamobileid: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Family member with afyamobileid: {afyaMobileId} could not be found")); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Index client with afyamobileid: {indexClientAfyaMobileId} could not be found for family member: {afyaMobileId}", false); return(Result <string> .Invalid($"Index client with afyamobileid: {indexClientAfyaMobileId} could not be found for family member: {afyaMobileId}")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized family tracing for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized family tracing for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize family tracing for clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize family tracing for clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobileSynchronizeHtsTestsCommand request, CancellationToken cancellationToken) { string afyaMobileId = String.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); try { //Person Identifier for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); //check if person already exists var identifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (identifiers.Count > 0) { var person = await registerPersonService.GetPerson(identifiers[0].PersonId); var patient = await registerPersonService.GetPatientByPersonId(identifiers[0].PersonId); int pnsAccepted = request.HIV_TESTS.SUMMARY.PNS_ACCEPTED; int pnsDeclineReason = request.HIV_TESTS.SUMMARY.PNS_DECLINE_REASON; List <NewTests> screeningTests = request.HIV_TESTS.SCREENING; List <NewTests> confirmatoryTests = request.HIV_TESTS.CONFIRMATORY; int coupleDiscordant = request.HIV_TESTS.SUMMARY.COUPLE_DISCORDANT; int finalResultGiven = request.HIV_TESTS.SUMMARY.FINAL_RESULT_GIVEN; int roundOneTestResult = request.HIV_TESTS.SUMMARY.SCREENING_RESULT; int? roundTwoTestResult = request.HIV_TESTS.SUMMARY.CONFIRMATORY_RESULT; int? finalResult = request.HIV_TESTS.SUMMARY.FINAL_RESULT; var encounterNumber = request.PLACER_DETAIL.ENCOUNTER_NUMBER; int providerId = request.PLACER_DETAIL.PROVIDER_ID; //Get Consent to screen partners itemId var consentPartnerType = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "ConsentType" && x.ItemName == "ConsentToListPartners") .FirstOrDefaultAsync(); int consentListPartnersTypeId = consentPartnerType != null ? consentPartnerType.ItemId : 0; var resultPlacerGet = await registerPersonService.GetInteropPlacerValue(7, 4, encounterNumber); if (resultPlacerGet.Count > 0) { var getHtsEncounter = await encounterTestingService.GetHtsEncounter(resultPlacerGet[0].EntityId); var getPatientEncounter = await encounterTestingService.GetPatientEncounterById(getHtsEncounter.PatientEncounterID); var getPatientConsents = await encounterTestingService.GetPatientConsent(patient.Id, getPatientEncounter.PatientMasterVisitId, 2, consentListPartnersTypeId); if (getPatientConsents.Count > 0) { getPatientConsents[0].ConsentValue = pnsAccepted; getPatientConsents[0].ConsentDate = getPatientEncounter.EncounterStartTime; getPatientConsents[0].DeclineReason = pnsDeclineReason; await encounterTestingService.UpdatePatientConsent(getPatientConsents[0]); var hasConsentedToListPartners = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.ItemId == pnsAccepted && x.MasterName == "YesNoNA").ToListAsync(); if (hasConsentedToListPartners.Count > 0) { if (hasConsentedToListPartners[0].ItemName == "Yes") { var listPartners = await registerPersonService.AddAppStateStore(person.Id, patient.Id, 3, getPatientEncounter.PatientMasterVisitId, getPatientEncounter.Id, null); } } } else { //add consent to list partners var partnersConsent = await encounterTestingService.addPatientConsent(patient.Id, getPatientEncounter.PatientMasterVisitId, 2, pnsAccepted, consentListPartnersTypeId, getPatientEncounter.EncounterStartTime, providerId, pnsDeclineReason); var hasConsentedToListPartners = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.ItemId == pnsAccepted && x.MasterName == "YesNoNA").ToListAsync(); if (hasConsentedToListPartners.Count > 0) { if (hasConsentedToListPartners[0].ItemName == "Yes") { var listPartners = await registerPersonService.AddAppStateStore(person.Id, patient.Id, 3, getPatientEncounter.PatientMasterVisitId, getPatientEncounter.Id, null); } } } //Screening Tests var updatedScreeningTests = await encounterTestingService.UpdateTesting(getHtsEncounter.Id, screeningTests, providerId, 1); //Confirmatory Tests var updatedConfirmatoryTests = await encounterTestingService.UpdateTesting(getHtsEncounter.Id, confirmatoryTests, providerId, 2); getHtsEncounter.CoupleDiscordant = coupleDiscordant; getHtsEncounter.FinalResultGiven = finalResultGiven; await encounterTestingService.updateHtsEncounter(getHtsEncounter.Id, getHtsEncounter); var getHtsEncounterResults = await encounterTestingService.GetHtsEncounterResultByEncounterId(getHtsEncounter.Id); if (getHtsEncounterResults.Count > 0) { getHtsEncounterResults[0].RoundOneTestResult = roundOneTestResult; getHtsEncounterResults[0].RoundTwoTestResult = roundTwoTestResult; getHtsEncounterResults[0].FinalResult = finalResult; var updatedHtsEncounterResult = await encounterTestingService.UpdateHtsEncounterResult(getHtsEncounterResults[0]); // add state for positive person var clientFinalResultsList = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.ItemId == finalResult && x.MasterName == "HIVFinalResults").ToListAsync(); if (clientFinalResultsList.Count > 0 && clientFinalResultsList[0].ItemName == "Positive") { var isClientPositiveState = await registerPersonService.AddAppStateStore(person.Id, patient.Id, 4, getPatientEncounter.PatientMasterVisitId, getPatientEncounter.Id, null); } } else { var htsEncounterResult = await encounterTestingService.addHtsEncounterResult(getHtsEncounter.Id, roundOneTestResult, roundTwoTestResult, finalResult); // add state for positive person var clientFinalResultsList = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.ItemId == finalResult && x.MasterName == "HIVFinalResults").ToListAsync(); if (clientFinalResultsList.Count > 0 && clientFinalResultsList[0].ItemName == "Positive") { var isClientPositiveState = await registerPersonService.AddAppStateStore(person.Id, patient.Id, 4, getPatientEncounter.PatientMasterVisitId, getPatientEncounter.Id, null); } } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"HTS PRE-TEST with encounter number: {encounterNumber} could not be found", false); Result <string> .Invalid($"HTS PRE-TEST with encounter number: {encounterNumber} could not be found"); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Person with afyaMobileId: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Person with afyaMobileId: {afyaMobileId} could not be found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized HTS tests for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized HTS tests for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize Hts tests for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize Hts tests for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(SynchronizePartnersCommand request, CancellationToken cancellationToken) { using (_htsUnitOfWork) using (_unitOfWork) { string afyaMobileId = string.Empty; string indexClientAfyaMobileId = string.Empty; RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); var facilityId = request.MESSAGE_HEADER.SENDING_FACILITY; for (int i = 0; i < request.PARTNERS.Count; i++) { for (int j = 0; j < request.PARTNERS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID.Count; j++) { if (request.PARTNERS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID") { afyaMobileId = request.PARTNERS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } if (request.PARTNERS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "INDEX_CLIENT_AFYAMOBILE_ID") { indexClientAfyaMobileId = request.PARTNERS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, indexClientAfyaMobileId, JsonConvert.SerializeObject(request), false); try { string firstName = request.PARTNERS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.FIRST_NAME; string middleName = request.PARTNERS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.MIDDLE_NAME; string lastName = request.PARTNERS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.LAST_NAME; int sex = request.PARTNERS[i].PATIENT_IDENTIFICATION.SEX; DateTime dateOfBirth = DateTime.ParseExact(request.PARTNERS[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH, "yyyyMMdd", null); int providerId = request.PARTNERS[i].PATIENT_IDENTIFICATION.USER_ID; int maritalStatusId = request.PARTNERS[i].PATIENT_IDENTIFICATION.MARITAL_STATUS; string mobileNumber = request.PARTNERS[i].PATIENT_IDENTIFICATION.PHONE_NUMBER; string landmark = request.PARTNERS[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS .LANDMARK; int relationshipType = request.PARTNERS[i].PATIENT_IDENTIFICATION.RELATIONSHIP_TYPE; Facility clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.PosID == facilityId).FirstOrDefaultAsync(); if (clientFacility == null) { clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.DeleteFlag == 0).FirstOrDefaultAsync(); } var indexClientIdentifiers = await registerPersonService.getPersonIdentifiers(indexClientAfyaMobileId, 10); if (indexClientIdentifiers.Count > 0) { //Get Index client var indexClient = await registerPersonService.GetPatientByPersonId(indexClientIdentifiers[0].PersonId); var partnetPersonIdentifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (partnetPersonIdentifiers.Count > 0) { await registerPersonService.UpdatePerson(partnetPersonIdentifiers[0].PersonId, firstName, middleName, lastName, sex, dateOfBirth, clientFacility.FacilityID); //update maritalstatus id await registerPersonService.UpdateMaritalStatus(partnetPersonIdentifiers[0].PersonId, maritalStatusId); if (!string.IsNullOrWhiteSpace(mobileNumber)) { await registerPersonService.UpdatePersonContact(partnetPersonIdentifiers[0].PersonId, null, mobileNumber); } if (!string.IsNullOrWhiteSpace(landmark)) { await registerPersonService.UpdatePersonLocation(partnetPersonIdentifiers[0].PersonId, landmark); } var getPersonRelationship = await registerPersonService.GetPersonRelationshipByPatientIdPersonId(indexClient.Id, partnetPersonIdentifiers[0].PersonId); if (getPersonRelationship != null) { getPersonRelationship.RelationshipTypeId = relationshipType; var updatedRelationship = await registerPersonService.UpdatePersonRelationship(getPersonRelationship); } else { //Add PersonRelationship var personRelationship = await registerPersonService.addPersonRelationship(partnetPersonIdentifiers[0].PersonId, indexClient.Id, relationshipType, providerId); } /*** * Encounter */ if (request.PARTNERS[i].ENCOUNTER != null) { if (request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING != null) { int pnsAccepted = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PNS_ACCEPTED; DateTime screeningDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.SCREENING_DATE, "yyyyMMdd", null); int ipvScreeningDone = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.IPV_SCREENING_DONE; int hurtByPartner = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.HURT_BY_PARTNER; int threatByPartner = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.THREAT_BY_PARTNER; int sexualAbuseByPartner = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.SEXUAL_ABUSE_BY_PARTNER; int ipvOutcome = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.IPV_OUTCOME; string partnerOccupation = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PARTNER_OCCUPATION; int partnerRelationship = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PARTNER_RELATIONSHIP; int livingWithClient = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.LIVING_WITH_CLIENT; int hivStatus = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.HIV_STATUS; int pnsApproach = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PNS_APPROACH; int eligibleForHts = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.ELIGIBLE_FOR_HTS; DateTime bookingDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.BOOKING_DATE, "yyyyMMdd", null); var pnsScreeningOptions = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "PnsScreening").ToListAsync(); List <Screening> newScreenings = new List <Screening>(); for (int j = 0; j < pnsScreeningOptions.Count; j++) { if (pnsScreeningOptions[j].ItemName == "EligibleTesting") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = eligibleForHts }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PNSApproach") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = pnsApproach }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "HIVStatus") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = hivStatus }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "LivingWithClient") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = livingWithClient }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsRelationship") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = partnerRelationship }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "IPVOutcome") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = ipvOutcome }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsForcedSexual") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = sexualAbuseByPartner }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsThreatenedHurt") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = threatByPartner }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsPhysicallyHurt") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = hurtByPartner }; newScreenings.Add(screening); } } var patientMasterVisitEntity = await _unitOfWork.Repository <PatientMasterVisit>() .Get(x => x.PatientId == indexClient.Id && x.ServiceId == 2).ToListAsync(); int patientMasterVisitId = patientMasterVisitEntity.OrderBy(x => x.Id).FirstOrDefault().Id; var partnHtsScreenings = await encounterTestingService.AddPartnerScreening(partnetPersonIdentifiers[0].PersonId, indexClient.Id, patientMasterVisitId, partnerOccupation, screeningDate, bookingDate, newScreenings, providerId); } var tracingLookup = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "TracingType" && x.ItemName == "Family").ToListAsync(); int tracingType = tracingLookup.FirstOrDefault().ItemId; for (int j = 0; j < request.PARTNERS[i].ENCOUNTER.TRACING.Count; j++) { DateTime tracingDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.TRACING[j].TRACING_DATE, "yyyyMMdd", null); int mode = request.PARTNERS[i].ENCOUNTER.TRACING[j].TRACING_MODE; int outcome = request.PARTNERS[i].ENCOUNTER.TRACING[j].TRACING_OUTCOME; int consent = request.PARTNERS[i].ENCOUNTER.TRACING[j].CONSENT; DateTime?tracingBookingDate = null; if (!string.IsNullOrWhiteSpace(request.PARTNERS[i].ENCOUNTER.TRACING[j].BOOKING_DATE)) { tracingBookingDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.TRACING[j].BOOKING_DATE, "yyyyMMdd", null); } int? reasonnotcontacted = request.PARTNERS[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTED; string reasonnotcontactedother = request.PARTNERS[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTEDOTHER; var tracingOutcome = await encounterTestingService.addTracing(partnetPersonIdentifiers[0].PersonId, tracingType, tracingDate, mode, outcome, providerId, null, consent, tracingBookingDate, null, reasonnotcontacted, reasonnotcontactedother); } } // update message as processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, indexClientAfyaMobileId, true, DateTime.Now, "success"); } else { //Register Partner var person = await registerPersonService.RegisterPerson(firstName, middleName, lastName, sex, providerId, clientFacility.FacilityID, dateOfBirth); //Add afyamobile Id as an Id of the partner var personIdentifier = await registerPersonService.addPersonIdentifiers(person.Id, 10, afyaMobileId, providerId); //Add partner marital status var partnerMaritalStatus = await registerPersonService.AddMaritalStatus(person.Id, maritalStatusId, providerId); //add partner contacts if (!string.IsNullOrWhiteSpace(mobileNumber)) { var partnerContacts = await registerPersonService.addPersonContact(person.Id, null, mobileNumber, null, null, providerId); } //add partner location if (!string.IsNullOrWhiteSpace(landmark)) { var partnerLocation = await registerPersonService.addPersonLocation(person.Id, 0, 0, 0, " ", landmark, providerId); } //Add PersonRelationship var personRelationship = await registerPersonService.addPersonRelationship(person.Id, indexClient.Id, relationshipType, providerId); /*** * Encounter */ if (request.PARTNERS[i].ENCOUNTER != null) { if (request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING != null) { int pnsAccepted = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PNS_ACCEPTED; DateTime screeningDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.SCREENING_DATE, "yyyyMMdd", null); int ipvScreeningDone = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.IPV_SCREENING_DONE; int hurtByPartner = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.HURT_BY_PARTNER; int threatByPartner = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.THREAT_BY_PARTNER; int sexualAbuseByPartner = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.SEXUAL_ABUSE_BY_PARTNER; int ipvOutcome = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.IPV_OUTCOME; string partnerOccupation = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PARTNER_OCCUPATION; int partnerRelationship = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PARTNER_RELATIONSHIP; int livingWithClient = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.LIVING_WITH_CLIENT; int hivStatus = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.HIV_STATUS; int pnsApproach = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.PNS_APPROACH; int eligibleForHts = request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.ELIGIBLE_FOR_HTS; DateTime bookingDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.PARTNER_SCREENING.BOOKING_DATE, "yyyyMMdd", null); var pnsScreeningOptions = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "PnsScreening").ToListAsync(); List <Screening> newScreenings = new List <Screening>(); for (int j = 0; j < pnsScreeningOptions.Count; j++) { if (pnsScreeningOptions[j].ItemName == "EligibleTesting") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = eligibleForHts }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PNSApproach") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = pnsApproach }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "HIVStatus") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = hivStatus }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "LivingWithClient") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = livingWithClient }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsRelationship") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = partnerRelationship }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "IPVOutcome") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = ipvOutcome }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsForcedSexual") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = sexualAbuseByPartner }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsThreatenedHurt") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = threatByPartner }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsPhysicallyHurt") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = hurtByPartner }; newScreenings.Add(screening); } } var patientMasterVisitEntity = await _unitOfWork.Repository <PatientMasterVisit>() .Get(x => x.PatientId == indexClient.Id && x.ServiceId == 2).ToListAsync(); int patientMasterVisitId = patientMasterVisitEntity.OrderBy(x => x.Id).FirstOrDefault().Id; var partnHtsScreenings = await encounterTestingService.AddPartnerScreening(person.Id, indexClient.Id, patientMasterVisitId, partnerOccupation, screeningDate, bookingDate, newScreenings, providerId); } var tracingLookup = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "TracingType" && x.ItemName == "Family").ToListAsync(); int tracingType = tracingLookup.FirstOrDefault().ItemId; for (int j = 0; j < request.PARTNERS[i].ENCOUNTER.TRACING.Count; j++) { DateTime tracingDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.TRACING[j].TRACING_DATE, "yyyyMMdd", null); int mode = request.PARTNERS[i].ENCOUNTER.TRACING[j].TRACING_MODE; int outcome = request.PARTNERS[i].ENCOUNTER.TRACING[j].TRACING_OUTCOME; int consent = request.PARTNERS[i].ENCOUNTER.TRACING[j].CONSENT; DateTime?tracingBookingDate = null; if (!string.IsNullOrWhiteSpace(request.PARTNERS[i].ENCOUNTER.TRACING[j].BOOKING_DATE)) { tracingBookingDate = DateTime.ParseExact(request.PARTNERS[i].ENCOUNTER.TRACING[j].BOOKING_DATE, "yyyyMMdd", null); } int? reasonnotContacted = request.PARTNERS[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTED; string reasonnotContactedOther = request.PARTNERS[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTEDOTHER; var tracingOutcome = await encounterTestingService.addTracing(person.Id, tracingType, tracingDate, mode, outcome, providerId, null, consent, tracingBookingDate, null, reasonnotContacted, reasonnotContactedOther); } } } } // update message as processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, indexClientAfyaMobileId, true, DateTime.Now, "success"); return(Result <string> .Valid(afyaMobileId)); } catch (Exception e) { Log.Error(e.Message); Log.Error(e.InnerException.ToString()); // update message as processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, indexClientAfyaMobileId, false, DateTime.Now, e.Message + " " + e.InnerException.ToString()); return(Result <string> .Invalid(e.Message)); } } return(Result <string> .Valid(afyaMobileId)); } }
public async Task <Result <string> > Handle(AfyaMobileFamilyDemographicsCommand request, CancellationToken cancellationToken) { string afyaMobileId = string.Empty; string indexClientAfyaMobileId = string.Empty; using (var trans = _unitOfWork.Context.Database.BeginTransaction()) { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); var facilityId = request.MESSAGE_HEADER.SENDING_FACILITY; try { for (int i = 0; i < request.FAMILY.Count; i++) { for (int j = 0; j < request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID.Count; j++) { if (request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID") { afyaMobileId = request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } if (request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "INDEX_CLIENT_AFYAMOBILE_ID") { indexClientAfyaMobileId = request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); string firstName = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.FIRST_NAME; string middleName = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.MIDDLE_NAME; string lastName = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.LAST_NAME; int sex = request.FAMILY[i].PATIENT_IDENTIFICATION.SEX; DateTime dateOfBirth = DateTime.Now; try { dateOfBirth = DateTime.ParseExact(request.FAMILY[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse family demographics DATE_OF_BIRTH: {request.FAMILY[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse family demographics DATE_OF_BIRTH: {request.FAMILY[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } int providerId = request.FAMILY[i].PATIENT_IDENTIFICATION.USER_ID; int maritalStatusId = request.FAMILY[i].PATIENT_IDENTIFICATION.MARITAL_STATUS; string mobileNumber = request.FAMILY[i].PATIENT_IDENTIFICATION.PHONE_NUMBER; string landmark = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.LANDMARK; int countyId = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.COUNTY; int subCountyId = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.SUB_COUNTY; int wardId = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.WARD; int relationshipType = request.FAMILY[i].PATIENT_IDENTIFICATION.RELATIONSHIP_TYPE; Facility clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.PosID == facilityId).FirstOrDefaultAsync(); if (clientFacility == null) { clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.DeleteFlag == 0).FirstOrDefaultAsync(); } var indexClientIdentifiers = await registerPersonService.getPersonIdentifiers(indexClientAfyaMobileId, 10); if (indexClientIdentifiers.Count > 0) { //Get Index client var indexClient = await registerPersonService.GetPatientByPersonId(indexClientIdentifiers[0].PersonId); var partnetPersonIdentifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (partnetPersonIdentifiers.Count > 0) { await registerPersonService.UpdatePerson(partnetPersonIdentifiers[0].PersonId, firstName, middleName, lastName, sex, dateOfBirth, clientFacility.FacilityID); //update maritalstatus id await registerPersonService.UpdateMaritalStatus(partnetPersonIdentifiers[0].PersonId, maritalStatusId); if (!string.IsNullOrWhiteSpace(mobileNumber)) { await registerPersonService.UpdatePersonContact(partnetPersonIdentifiers[0].PersonId, null, mobileNumber); } if (!string.IsNullOrWhiteSpace(landmark)) { await registerPersonService.UpdatePersonLocation(partnetPersonIdentifiers[0].PersonId, landmark); } var getPersonRelationship = await registerPersonService.GetPersonRelationshipByPatientIdPersonId(indexClient.Id, partnetPersonIdentifiers[0].PersonId); if (getPersonRelationship != null) { getPersonRelationship.RelationshipTypeId = relationshipType; var updatedRelationship = await registerPersonService.UpdatePersonRelationship(getPersonRelationship); } else { //Add PersonRelationship var personRelationship = await registerPersonService.addPersonRelationship(partnetPersonIdentifiers[0].PersonId, indexClient.Id, relationshipType, providerId); } } else { //Register Partner var person = await registerPersonService.RegisterPerson(firstName, middleName, lastName, sex, providerId, clientFacility.FacilityID, dateOfBirth); //Add afyamobile Id as an Id of the partner var personIdentifier = await registerPersonService.addPersonIdentifiers(person.Id, 10, afyaMobileId, providerId); //Add partner marital status var partnerMaritalStatus = await registerPersonService.AddMaritalStatus(person.Id, maritalStatusId, providerId); //add partner contacts if (!string.IsNullOrWhiteSpace(mobileNumber)) { var partnerContacts = await registerPersonService.addPersonContact(person.Id, null, mobileNumber, null, null, providerId); } //add partner location if (!string.IsNullOrWhiteSpace(landmark) || (countyId > 0) || (subCountyId > 0) || (wardId > 0)) { landmark = string.IsNullOrWhiteSpace(landmark) ? "" : landmark; var partnerLocation = await registerPersonService.addPersonLocation(person.Id, countyId, subCountyId, wardId, " ", landmark, providerId); } //Add PersonRelationship var personRelationship = await registerPersonService.addPersonRelationship(person.Id, indexClient.Id, relationshipType, providerId); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Index clientid: {indexClientAfyaMobileId} for familyid: {afyaMobileId} not found", false); return(Result <string> .Invalid($"Index clientid: {indexClientAfyaMobileId} for familyid: {afyaMobileId} not found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, "success", true); } trans.Commit(); return(Result <string> .Valid($"Successfully synchronized family: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize family: {afyaMobileId} for clientid: {indexClientAfyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize family: {afyaMobileId} for clientid: {indexClientAfyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobileSynchronizeClientsCommand request, CancellationToken cancellationToken) { string afyaMobileId = String.Empty; using (var trans = _unitOfWork.Context.Database.BeginTransaction()) { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); LookupLogic lookupLogic = new LookupLogic(_unitOfWork); PersonOccupationService pocc = new PersonOccupationService(_unitOfWork); EducationLevelService educationLevelService = new EducationLevelService(_unitOfWork); for (int i = 0; i < request.CLIENTS.Count; i++) { for (int j = 0; j < request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID.Count; j++) { if (request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); try { var facilityId = request.MESSAGE_HEADER.SENDING_FACILITY; for (int i = 0; i < request.CLIENTS.Count; i++) { string firstName = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.FIRST_NAME; string middleName = string.IsNullOrWhiteSpace(request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.MIDDLE_NAME) ? "" : request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.MIDDLE_NAME; string lastName = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.LAST_NAME; string nickName = (request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.NICK_NAME == null) ? "" : request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_NAME.NICK_NAME.ToString(); int sex = request.CLIENTS[i].PATIENT_IDENTIFICATION.SEX; //Try to parse dateOfBirth DateTime dateOfBirth = DateTime.Now; try { dateOfBirth = DateTime.ParseExact(request.CLIENTS[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse DateOfBirth: {request.CLIENTS[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH} as a valid date. Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse DateOfBirth: {request.CLIENTS[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH} as a valid date. Incorrect format, date should be in the following format yyyyMMdd"); } string dobPrecision = request.CLIENTS[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH_PRECISION; //Try to parse DateOfEnrollment DateTime dateEnrollment = DateTime.Now; try { dateEnrollment = DateTime.ParseExact(request.CLIENTS[i].PATIENT_IDENTIFICATION.REGISTRATION_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse DateOfEnrollment: {request.CLIENTS[i].PATIENT_IDENTIFICATION.REGISTRATION_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse DateOfEnrollment: {request.CLIENTS[i].PATIENT_IDENTIFICATION.REGISTRATION_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } int maritalStatusId = request.CLIENTS[i].PATIENT_IDENTIFICATION.MARITAL_STATUS; string landmark = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS .LANDMARK; int ward = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.WARD; int county = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.COUNTY; int subcounty = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.SUB_COUNTY; string educationlevel = (request.CLIENTS[i].PATIENT_IDENTIFICATION.EDUCATIONLEVEL == null) ? "" : request.CLIENTS[i].PATIENT_IDENTIFICATION.EDUCATIONLEVEL.ToString(); string educationoutcome = (request.CLIENTS[i].PATIENT_IDENTIFICATION.EDUCATIONOUTCOME == null) ? "" : request.CLIENTS[i].PATIENT_IDENTIFICATION.EDUCATIONOUTCOME.ToString(); string occupation = (request.CLIENTS[i].PATIENT_IDENTIFICATION.OCCUPATION == null) ? "" : request.CLIENTS[i].PATIENT_IDENTIFICATION.OCCUPATION.ToString(); string physicalAddress = request.CLIENTS[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.POSTAL_ADDRESS; string mobileNumber = request.CLIENTS[i].PATIENT_IDENTIFICATION.PHONE_NUMBER; string enrollmentNo = string.Empty; int userId = request.CLIENTS[i].PATIENT_IDENTIFICATION.USER_ID; string maritalStatusName = String.Empty; string gender = String.Empty; var maritalStatusList = await lookupLogic.GetLookupNameByGroupNameItemId(maritalStatusId, "HTSMaritalStatus"); var genderList = await lookupLogic.GetLookupNameByGroupNameItemId(sex, "Gender"); if (maritalStatusList.Count > 0) { maritalStatusName = maritalStatusList[0].ItemName; } if (genderList.Count > 0) { gender = genderList[0].ItemName; } for (int j = 0; j < request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID.Count; j++) { if (request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "HTS" && request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "HTS_SERIAL") { enrollmentNo = request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } if (request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.CLIENTS[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } } Facility clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.PosID == facilityId).FirstOrDefaultAsync(); if (clientFacility == null) { clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.DeleteFlag == 0).FirstOrDefaultAsync(); } //check if person already exists var identifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (identifiers.Count > 0) { var registeredPerson = await registerPersonService.GetPerson(identifiers[0].PersonId); if (registeredPerson != null) { var updatedPerson = await registerPersonService.UpdatePerson(identifiers[0].PersonId, firstName, middleName, lastName, sex, dateOfBirth, clientFacility.FacilityID, registrationDate : dateEnrollment, NickName : nickName); } else { var person = await registerPersonService.RegisterPerson(firstName, middleName, lastName, sex, userId, clientFacility.FacilityID, dateOfBirth, nickName : nickName); } var patient = await registerPersonService.GetPatientByPersonId(identifiers[0].PersonId); if (patient != null) { var updatedPatient = await registerPersonService.UpdatePatient(patient.Id, dateOfBirth, facilityId); } else { //Add Person to mst_patient var mstResult = await registerPersonService.InsertIntoBlueCard(firstName, lastName, middleName, dateEnrollment, " ", 283, maritalStatusName, physicalAddress, mobileNumber, gender, dobPrecision, dateOfBirth, userId, facilityId); if (mstResult.Count > 0) { patient = await registerPersonService.AddPatient(identifiers[0].PersonId, userId, facilityId); // Person is enrolled state var enrollmentAppState = await registerPersonService.AddAppStateStore(identifiers[0].PersonId, patient.Id, 7, null, null); // Enroll patient var patientIdentifier = await registerPersonService.EnrollPatient(enrollmentNo, patient.Id, 2, userId, dateEnrollment); //Add PersonIdentifiers var personIdentifier = await registerPersonService.addPersonIdentifiers(identifiers[0].PersonId, 10, afyaMobileId, userId); } } var updatedPersonPopulations = await registerPersonService.UpdatePersonPopulation(identifiers[0].PersonId, request.CLIENTS[i].PATIENT_IDENTIFICATION.KEY_POP, userId); //Location if (!string.IsNullOrWhiteSpace(landmark) || (county > 0) || (subcounty > 0) || (ward > 0)) { var updatedLocation = await registerPersonService.UpdatePersonLocation(identifiers[0].PersonId, landmark, ward, county, subcounty, userId); } if (!string.IsNullOrWhiteSpace(educationlevel)) { var personeducation = await educationLevelService.UpdatePersonEducation(identifiers[0].PersonId, educationlevel, educationoutcome, userId); } if (!string.IsNullOrWhiteSpace(occupation)) { var personoccupation = await pocc.Update(identifiers[0].PersonId, occupation, userId); } if (!string.IsNullOrWhiteSpace(mobileNumber) || !string.IsNullOrWhiteSpace(physicalAddress)) { //add Person Contact var personContact = await registerPersonService.UpdatePersonContact(identifiers[0].PersonId, physicalAddress, mobileNumber); } // update message as processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, "success", true); } else { // Add Person var person = await registerPersonService.RegisterPerson(firstName, middleName, lastName, sex, userId, clientFacility.FacilityID, dateOfBirth, nickName : nickName); //Add Person to mst_patient var mstResult = await registerPersonService.InsertIntoBlueCard(firstName, lastName, middleName, dateEnrollment, " ", 283, maritalStatusName, physicalAddress, mobileNumber, gender, dobPrecision, dateOfBirth, userId, facilityId); if (mstResult.Count > 0) { //Add PersonIdentifiers var personIdentifier = await registerPersonService.addPersonIdentifiers(person.Id, 10, afyaMobileId, userId); // Add Patient var patient = await registerPersonService.AddPatient(person.Id, userId, mstResult[0].Ptn_Pk, facilityId); // Person is enrolled state var enrollmentAppState = await registerPersonService.AddAppStateStore(person.Id, patient.Id, 7, null, null); // Enroll patient var patientIdentifier = await registerPersonService.EnrollPatient(enrollmentNo, patient.Id, 2, userId, dateEnrollment); // Add Marital Status var maritalStatus = await registerPersonService.AddMaritalStatus(person.Id, maritalStatusId, userId); // Add Person Key pop var population = await registerPersonService.addPersonPopulation(person.Id, request.CLIENTS[i].PATIENT_IDENTIFICATION.KEY_POP, userId); // Add Person Location if (!string.IsNullOrWhiteSpace(landmark) || (county > 0) || (subcounty > 0) || (ward > 0)) { var personLocation = await registerPersonService.UpdatePersonLocation(person.Id, landmark, ward, county, subcounty, userId); } if (!string.IsNullOrWhiteSpace(educationlevel)) { var personeducation = await educationLevelService.UpdatePersonEducation(person.Id, educationlevel, educationoutcome, userId); } if (!string.IsNullOrWhiteSpace(occupation)) { var personoccupation = await pocc.Update(person.Id, occupation, userId); } if (!string.IsNullOrWhiteSpace(mobileNumber) || !string.IsNullOrWhiteSpace(physicalAddress)) { //add Person Contact var personContact = await registerPersonService.addPersonContact(person.Id, physicalAddress, mobileNumber, string.Empty, string.Empty, userId); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized demographics for afyamobileid: {afyaMobileId}", true); } } } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized demographics for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized demographics for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Error syncronizing afyamobileid: {afyaMobileId}. Exception Message: {ex.Message}, Inner Exception {ex.InnerException}"); return(Result <string> .Invalid($"Failed to synchronize clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(SynchronizeFamilyCommand request, CancellationToken cancellationToken) { using (_htsUnitOfWork) using (_unitOfWork) { string afyaMobileId = string.Empty; string indexClientAfyaMobileId = string.Empty; RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); PersonOccupationService pocc = new PersonOccupationService(_unitOfWork); EducationLevelService educationLevelService = new EducationLevelService(_unitOfWork); var facilityId = request.MESSAGE_HEADER.SENDING_FACILITY; for (int i = 0; i < request.FAMILY.Count; i++) { for (int j = 0; j < request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID.Count; j++) { if (request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID") { afyaMobileId = request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } if (request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "INDEX_CLIENT_AFYAMOBILE_ID") { indexClientAfyaMobileId = request.FAMILY[i].PATIENT_IDENTIFICATION.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, indexClientAfyaMobileId, JsonConvert.SerializeObject(request), false); try { string firstName = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.FIRST_NAME; string middleName = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.MIDDLE_NAME; string lastName = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.LAST_NAME; int sex = request.FAMILY[i].PATIENT_IDENTIFICATION.SEX; string nickName = (request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.NICK_NAME == null) ? "" : request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_NAME.NICK_NAME.ToString(); int ward = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.WARD; int county = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.COUNTY; int subcounty = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS.SUB_COUNTY; string educationlevel = (request.FAMILY[i].PATIENT_IDENTIFICATION.EDUCATIONLEVEL == null) ? "" : request.FAMILY[i].PATIENT_IDENTIFICATION.EDUCATIONLEVEL.ToString(); string educationoutcome = (request.FAMILY[i].PATIENT_IDENTIFICATION.EDUCATIONOUTCOME == null) ? "" : request.FAMILY[i].PATIENT_IDENTIFICATION.EDUCATIONOUTCOME.ToString(); string occupation = (request.FAMILY[i].PATIENT_IDENTIFICATION.OCCUPATION == null) ? "" : request.FAMILY[i].PATIENT_IDENTIFICATION.OCCUPATION.ToString(); DateTime dateOfBirth = DateTime.ParseExact(request.FAMILY[i].PATIENT_IDENTIFICATION.DATE_OF_BIRTH, "yyyyMMdd", null); int providerId = request.FAMILY[i].PATIENT_IDENTIFICATION.USER_ID; int maritalStatusId = request.FAMILY[i].PATIENT_IDENTIFICATION.MARITAL_STATUS; string mobileNumber = request.FAMILY[i].PATIENT_IDENTIFICATION.PHONE_NUMBER; string landmark = request.FAMILY[i].PATIENT_IDENTIFICATION.PATIENT_ADDRESS.PHYSICAL_ADDRESS .LANDMARK; int relationshipType = request.FAMILY[i].PATIENT_IDENTIFICATION.RELATIONSHIP_TYPE; int Userid = request.FAMILY[i].PATIENT_IDENTIFICATION.USER_ID; Facility clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.PosID == facilityId).FirstOrDefaultAsync(); if (clientFacility == null) { clientFacility = await _unitOfWork.Repository <Facility>().Get(x => x.DeleteFlag == 0).FirstOrDefaultAsync(); } var indexClientIdentifiers = await registerPersonService.getPersonIdentifiers(indexClientAfyaMobileId, 10); if (indexClientIdentifiers.Count > 0) { //Get Index client var indexClient = await registerPersonService.GetPatientByPersonId(indexClientIdentifiers[0].PersonId); var partnetPersonIdentifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (partnetPersonIdentifiers.Count > 0) { await registerPersonService.UpdatePerson(partnetPersonIdentifiers[0].PersonId, firstName, middleName, lastName, sex, dateOfBirth, clientFacility.FacilityID, NickName : nickName); //update maritalstatus id await registerPersonService.UpdateMaritalStatus(partnetPersonIdentifiers[0].PersonId, maritalStatusId); if (!string.IsNullOrWhiteSpace(mobileNumber)) { await registerPersonService.UpdatePersonContact(partnetPersonIdentifiers[0].PersonId, null, mobileNumber); } if (!string.IsNullOrWhiteSpace(landmark) || (county > 0) || (subcounty > 0) || (ward > 0)) { var personlocation = await registerPersonService.UpdatePersonLocation(partnetPersonIdentifiers[0].PersonId, landmark, ward, county, subcounty, Userid); } if (!string.IsNullOrWhiteSpace(educationlevel)) { var personeducation = await educationLevelService.UpdatePersonEducation(partnetPersonIdentifiers[0].PersonId, educationlevel, educationoutcome, Userid); } if (!string.IsNullOrWhiteSpace(occupation)) { var personoccupation = await pocc.Update(partnetPersonIdentifiers[0].PersonId, occupation, Userid); } var getPersonRelationship = await registerPersonService.GetPersonRelationshipByPatientIdPersonId(indexClient.Id, partnetPersonIdentifiers[0].PersonId); if (getPersonRelationship != null) { getPersonRelationship.RelationshipTypeId = relationshipType; var updatedRelationship = await registerPersonService.UpdatePersonRelationship(getPersonRelationship); } else { //Add PersonRelationship var personRelationship = await registerPersonService.addPersonRelationship(partnetPersonIdentifiers[0].PersonId, indexClient.Id, relationshipType, providerId); } /*** * Encounter */ if (request.FAMILY[i].ENCOUNTER != null) { if (request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING != null) { DateTime screeningDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.SCREENING_DATE, "yyyyMMdd", null); int hivStatus = request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.HIV_STATUS; int eligible = request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.ELIGIBLE_FOR_HTS; DateTime bookingDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.BOOKING_DATE, "yyyyMMdd", null); string remarks = request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.REMARKS; var familyScreenings = await _unitOfWork.Repository <LookupItemView>().Get(x => x.MasterName == "FamilyScreening") .ToListAsync(); List <Screening> familyScreeningList = new List <Screening>(); for (int j = 0; j < familyScreenings.Count; j++) { if (familyScreenings[j].ItemName == "EligibleTesting") { Screening screening = new Screening() { ScreeningCategoryId = familyScreenings[j].ItemId, ScreeningTypeId = familyScreenings[j].MasterId, ScreeningValueId = eligible }; familyScreeningList.Add(screening); } else if (familyScreenings[j].ItemName == "ScreeningHivStatus") { Screening screening = new Screening() { ScreeningCategoryId = familyScreenings[j].ItemId, ScreeningTypeId = familyScreenings[j].MasterId, ScreeningValueId = hivStatus }; familyScreeningList.Add(screening); } } var patientMasterVisitEntity = await _unitOfWork.Repository <PatientMasterVisit>() .Get(x => x.PatientId == indexClient.Id && x.ServiceId == 2).ToListAsync(); int patientMasterVisitId = patientMasterVisitEntity.OrderBy(x => x.Id).FirstOrDefault().Id; var familyScreeningReturnValue = await encounterTestingService.AddPartnerScreening(partnetPersonIdentifiers[0].PersonId, indexClient.Id, patientMasterVisitId, null, screeningDate, bookingDate, familyScreeningList, providerId); } for (int j = 0; j < request.FAMILY[i].ENCOUNTER.TRACING.Count; j++) { var lookupitem = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "TracingType" && x.ItemName == "Family").ToListAsync(); int tracingType = lookupitem[0].ItemId; DateTime tracingDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.TRACING[j].TRACING_DATE, "yyyyMMdd", null); int mode = request.FAMILY[i].ENCOUNTER.TRACING[j].TRACING_MODE; int outcome = request.FAMILY[i].ENCOUNTER.TRACING[j].TRACING_OUTCOME; DateTime?reminderDate = null; if (!string.IsNullOrWhiteSpace(request.FAMILY[i].ENCOUNTER.TRACING[j].REMINDER_DATE)) { reminderDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.TRACING[j].REMINDER_DATE, "yyyyMMdd", null); } DateTime?tracingBookingDate = null; if (!string.IsNullOrWhiteSpace(request.FAMILY[i].ENCOUNTER.TRACING[j].BOOKING_DATE)) { tracingBookingDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.TRACING[j].BOOKING_DATE, "yyyyMMdd", null); } int consent = request.FAMILY[i].ENCOUNTER.TRACING[j].CONSENT; int? ReasonNotContacted = request.FAMILY[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTED; string reasonnotcontactedOther = request.FAMILY[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTEDOTHER; var trace = await encounterTestingService.addTracing(partnetPersonIdentifiers[0].PersonId, tracingType, tracingDate, mode, outcome, providerId, null, consent, tracingBookingDate, reminderDate, ReasonNotContacted, reasonnotcontactedOther); } } } else { //Register family var person = await registerPersonService.RegisterPerson(firstName, middleName, lastName, sex, providerId, clientFacility.FacilityID, dateOfBirth, nickName : nickName); //Add afyamobile Id as an Id of the family var personIdentifier = await registerPersonService.addPersonIdentifiers(person.Id, 10, afyaMobileId, providerId); //Add family marital status var partnerMaritalStatus = await registerPersonService.AddMaritalStatus(person.Id, maritalStatusId, providerId); //add family contacts if (string.IsNullOrWhiteSpace(mobileNumber)) { var partnerContacts = await registerPersonService.addPersonContact(person.Id, null, mobileNumber, null, null, providerId); } //add family location /* if (!string.IsNullOrWhiteSpace(landmark)) * { * var partnerLocation = await registerPersonService.addPersonLocation(person.Id, 0, 0, 0, "", landmark, providerId); * }*/ if (!string.IsNullOrWhiteSpace(landmark) || (county > 0) || (subcounty > 0) || (ward > 0)) { var partnerLocation = await registerPersonService.UpdatePersonLocation(person.Id, landmark, ward, county, subcounty, Userid); } if (!string.IsNullOrWhiteSpace(educationlevel)) { var partnereducation = await educationLevelService.UpdatePersonEducation(person.Id, educationlevel, educationoutcome, Userid); } if (!string.IsNullOrWhiteSpace(occupation)) { var partneroccupation = await pocc.Update(person.Id, occupation, Userid); } //Add PersonRelationship var personRelationship = await registerPersonService.addPersonRelationship(person.Id, indexClient.Id, relationshipType, providerId); /*** * Encounter */ if (request.FAMILY[i].ENCOUNTER != null) { if (request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING != null) { DateTime screeningDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.SCREENING_DATE, "yyyyMMdd", null); int hivStatus = request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.HIV_STATUS; int eligible = request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.ELIGIBLE_FOR_HTS; DateTime bookingDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.BOOKING_DATE, "yyyyMMdd", null); string remarks = request.FAMILY[i].ENCOUNTER.FAMILY_SCREENING.REMARKS; var familyScreenings = await _unitOfWork.Repository <LookupItemView>().Get(x => x.MasterName == "FamilyScreening") .ToListAsync(); List <Screening> familyScreeningList = new List <Screening>(); for (int j = 0; j < familyScreenings.Count; j++) { if (familyScreenings[j].ItemName == "EligibleTesting") { Screening screening = new Screening() { ScreeningCategoryId = familyScreenings[j].ItemId, ScreeningTypeId = familyScreenings[j].MasterId, ScreeningValueId = eligible }; familyScreeningList.Add(screening); } else if (familyScreenings[j].ItemName == "ScreeningHivStatus") { Screening screening = new Screening() { ScreeningCategoryId = familyScreenings[j].ItemId, ScreeningTypeId = familyScreenings[j].MasterId, ScreeningValueId = hivStatus }; familyScreeningList.Add(screening); } } var patientMasterVisitEntity = await _unitOfWork.Repository <PatientMasterVisit>() .Get(x => x.PatientId == indexClient.Id && x.ServiceId == 2).ToListAsync(); int patientMasterVisitId = patientMasterVisitEntity.OrderBy(x => x.Id).FirstOrDefault().Id; var familyScreeningReturnValue = await encounterTestingService.AddPartnerScreening(person.Id, indexClient.Id, patientMasterVisitId, null, screeningDate, bookingDate, familyScreeningList, providerId); } for (int j = 0; j < request.FAMILY[i].ENCOUNTER.TRACING.Count; j++) { var lookupitem = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "TracingType" && x.ItemName == "Family").ToListAsync(); int tracingType = lookupitem[0].ItemId; DateTime tracingDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.TRACING[j].TRACING_DATE, "yyyyMMdd", null); int mode = request.FAMILY[i].ENCOUNTER.TRACING[j].TRACING_MODE; int outcome = request.FAMILY[i].ENCOUNTER.TRACING[j].TRACING_OUTCOME; DateTime?reminderDate = null; if (!string.IsNullOrWhiteSpace(request.FAMILY[i].ENCOUNTER.TRACING[j].REMINDER_DATE)) { reminderDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.TRACING[j].REMINDER_DATE, "yyyyMMdd", null); } DateTime?tracingBookingDate = null; if (!string.IsNullOrWhiteSpace(request.FAMILY[i].ENCOUNTER.TRACING[j].BOOKING_DATE)) { tracingBookingDate = DateTime.ParseExact(request.FAMILY[i].ENCOUNTER.TRACING[j].BOOKING_DATE, "yyyyMMdd", null); } int consent = request.FAMILY[i].ENCOUNTER.TRACING[j].CONSENT; int? reasonnotcontacted = request.FAMILY[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTED; string reasonnotcontactedother = request.FAMILY[i].ENCOUNTER.TRACING[j].REASONNOTCONTACTEDOTHER; var trace = await encounterTestingService.addTracing(person.Id, tracingType, tracingDate, mode, outcome, providerId, null, consent, tracingBookingDate, reminderDate, reasonnotcontacted, reasonnotcontactedother); } } } } // update message as processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, indexClientAfyaMobileId, true, DateTime.Now, "success"); return(Result <string> .Valid(afyaMobileId)); } catch (Exception e) { Log.Error(e.Message); Log.Error(e.InnerException.ToString()); // update message as processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, indexClientAfyaMobileId, false, DateTime.Now, e.Message + " " + e.InnerException.ToString()); return(Result <string> .Invalid(e.Message)); } } return(Result <string> .Valid(afyaMobileId)); } }
public async Task <Result <string> > Handle(AfyaMobileSynchronizeLinkageCommand request, CancellationToken cancellationToken) { string afyaMobileId = String.Empty; RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { try { //Person Identifier for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); int providerId = request.PLACER_DETAIL.PROVIDER_ID; //check if person already exists var identifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (identifiers.Count > 0) { DateTime dateLinkageEnrolled = DateTime.Now; try { dateLinkageEnrolled = DateTime.ParseExact(request.LINKAGE.DATE_ENROLLED, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse linkage DATE_ENROLLED: {request.LINKAGE.DATE_ENROLLED} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse linkage DATE_ENROLLED: {request.LINKAGE.DATE_ENROLLED} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } string linkageCCCNumber = request.LINKAGE.CCC_NUMBER; string linkageFacility = request.LINKAGE.FACILITY; string healthWorker = request.LINKAGE.HEALTH_WORKER; string carde = request.LINKAGE.CARDE; string ARTStartDate = request.LINKAGE.ARTStartDate; string remarks = request.LINKAGE.REMARKS; DateTime?artstartDate = null; if (!string.IsNullOrWhiteSpace(ARTStartDate)) { try { artstartDate = DateTime.ParseExact(ARTStartDate, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse linkage ARTStartDate: {request.LINKAGE.ARTStartDate} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse linkage ARTStartDate: {request.LINKAGE.ARTStartDate} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } } var previousLinkage = await encounterTestingService.GetPersonLinkage(identifiers[0].PersonId); if (previousLinkage.Count > 0) { previousLinkage[0].ArtStartDate = artstartDate; previousLinkage[0].LinkageDate = dateLinkageEnrolled; previousLinkage[0].CCCNumber = linkageCCCNumber; previousLinkage[0].Facility = linkageFacility; previousLinkage[0].HealthWorker = healthWorker; previousLinkage[0].Cadre = carde; previousLinkage[0].Comments = remarks; await encounterTestingService.UpdatePersonLinkage(previousLinkage[0]); } else { //add Client Linkage var clientLinkage = await encounterTestingService.AddLinkage(identifiers[0].PersonId, dateLinkageEnrolled, linkageCCCNumber, linkageFacility, providerId, healthWorker, carde, remarks, artstartDate); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Person with afyaMobileId: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Person with afyaMobileId: {afyaMobileId} could not be found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized HTS Linkage for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized HTS Linkage for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize Hts Referral for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize Hts Referral for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobileSynchronizeTracingCommand request, CancellationToken cancellationToken) { string afyaMobileId = String.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); try { //Person Identifier for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); //Tracing var enrollmentTracing = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "TracingType" && x.ItemName == "Enrolment").FirstOrDefaultAsync(); int tracingType = enrollmentTracing.ItemId; int providerId = request.PLACER_DETAIL.PROVIDER_ID; string tracingRemarks = String.Empty; //check if person already exists var identifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (identifiers.Count > 0) { var person = await registerPersonService.GetPerson(identifiers[0].PersonId); var patient = await registerPersonService.GetPatientByPersonId(identifiers[0].PersonId); //check for client tracing for (int j = 0; (request.TRACING != null && j < request.TRACING.Count); j++) { DateTime tracingDate = DateTime.Now; try { tracingDate = DateTime.ParseExact(request.TRACING[j].TRACING_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse tracing TRACING_DATE: {request.TRACING[j].TRACING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse tracing TRACING_DATE: {request.TRACING[j].TRACING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } int mode = request.TRACING[j].TRACING_MODE; int outcome = request.TRACING[j].TRACING_OUTCOME; int? reasonnotcontacted = request.TRACING[j].REASONNOTCONTACTED; string reasonnotcontactedother = request.TRACING[j].REASONNOTCONTACTEDOTHER; //add Client Tracing var clientTracing = await encounterTestingService.addTracing(person.Id, tracingType, tracingDate, mode, outcome, providerId, tracingRemarks, null, null, null, reasonnotcontacted, reasonnotcontactedother); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Person with afyaMobileId: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Person with afyaMobileId: {afyaMobileId} could not be found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized HTS Tracing for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized HTS Tracing for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize Hts Tracing for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize Hts Tracing for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobileSynchronizeReferralCommand request, CancellationToken cancellationToken) { string afyaMobileId = String.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); try { //Person Identifier for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); //check if person already exists var identifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (identifiers.Count > 0) { // var person = await registerPersonService.GetPerson(identifiers[0].PersonId); var patient = await registerPersonService.GetPatientByPersonId(identifiers[0].PersonId); //add referral int providerId = request.PLACER_DETAIL.PROVIDER_ID; DateTime?dateToBeEnrolled = null; try { dateToBeEnrolled = DateTime.ParseExact(request.REFERRAL.DATE_TO_BE_ENROLLED, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse Referral DATE_TO_BE_ENROLLED: {request.REFERRAL.DATE_TO_BE_ENROLLED} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse Referral DATE_TO_BE_ENROLLED: {request.REFERRAL.DATE_TO_BE_ENROLLED} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } string facilityReferred = request.REFERRAL.REFERRED_TO; var referralReason = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "ReferralReason" && x.ItemName == "CCCEnrollment").ToListAsync(); var searchFacility = await encounterTestingService.SearchFacility(facilityReferred); var previousReferrals = await encounterTestingService.GetReferralByPersonId(identifiers[0].PersonId); var facility = await encounterTestingService.GetCurrentFacility(); int MFLCode = 0; if (searchFacility.Count > 0) { MFLCode = Convert.ToInt32(searchFacility[0].MFLCode); if (previousReferrals.Count > 0) { previousReferrals[0].ToFacility = Convert.ToInt32(searchFacility[0].MFLCode); previousReferrals[0].OtherFacility = ""; previousReferrals[0].ExpectedDate = dateToBeEnrolled.Value; await encounterTestingService.UpdateReferral(previousReferrals[0]); } else { if (facility.Count > 0) { await encounterTestingService.AddReferral(identifiers[0].PersonId, facility[0].FacilityID, 2, MFLCode, referralReason[0].ItemId, providerId, dateToBeEnrolled.Value, ""); } } } else { searchFacility = await encounterTestingService.SearchFacility("Other"); MFLCode = Convert.ToInt32(searchFacility[0].MFLCode); await encounterTestingService.AddReferral(identifiers[0].PersonId, facility[0].FacilityID, 2, MFLCode, referralReason[0].ItemId, providerId, dateToBeEnrolled.Value, facilityReferred); } var clientHasBeenReferredState = await registerPersonService.AddAppStateStore(identifiers[0].PersonId, patient.Id, 5, null, null); } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Person with afyaMobileId: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Person with afyaMobileId: {afyaMobileId} could not be found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized HTS Referral for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized HTS Referral for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize Hts Referral for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize Hts Referral for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobileSynchronizeEncounterCommand request, CancellationToken cancellationToken) { string afyaMobileId = String.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); //Person Identifier for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID" && request.INTERNAL_PATIENT_ID[j].ASSIGNING_AUTHORITY == "AFYAMOBILE") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); try { //check if person already exists var identifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); //Encounter DateTime encounterDate = DateTime.Now; try { encounterDate = DateTime.ParseExact(request.PRE_TEST.ENCOUNTER_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse HTS_EncounterDate: {request.PRE_TEST.ENCOUNTER_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse HTS_EncounterDate: {request.PRE_TEST.ENCOUNTER_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } string htsEncounterRemarks = request.PRE_TEST.REMARKS; int clientEverTested = request.PRE_TEST.EVER_TESTED; int clientEverSelfTested = request.PRE_TEST.SELF_TEST_12_MONTHS; int testEntryPoint = request.PRE_TEST.SERVICE_POINT; int htsencounterType = request.PRE_TEST.ENCOUNTER_TYPE; int testingStrategy = request.PRE_TEST.STRATEGY; int clientTestedAs = request.PRE_TEST.TESTED_AS; int monthsSinceLastTest = request.PRE_TEST.MONTHS_SINCE_LAST_TEST; List <int> clientDisabilities = request.PRE_TEST.DISABILITIES; int providerId = request.PLACER_DETAIL.PROVIDER_ID; var encounterNumber = request.PLACER_DETAIL.ENCOUNTER_NUMBER; //HTS Encounter types var emrEncounterTypes = await _unitOfWork.Repository <LookupItemView>() .Get(x => x.MasterName == "EncounterType" && x.ItemName == "Hts-encounter") .FirstOrDefaultAsync(); int encounterTypeId = emrEncounterTypes.ItemId; //Get consent to testing int consentValue = request.PRE_TEST.CONSENT; var consentType = await _unitOfWork.Repository <LookupItemView>().Get(x => x.MasterName == "ConsentType" && x.ItemName == "ConsentToBeTested").FirstOrDefaultAsync(); int consentTypeId = consentType != null ? consentType.ItemId : 0; //Get TBStatus masterId var screeningType = await _unitOfWork.Repository <LookupItemView>().Get(x => x.MasterName == "TbScreening").FirstOrDefaultAsync(); int screeningTypeId = screeningType != null ? screeningType.MasterId : 0; int tbStatus = request.PRE_TEST.TB_SCREENING; if (identifiers.Count > 0) { var person = await registerPersonService.GetPerson(identifiers[0].PersonId); var patient = await registerPersonService.GetPatientByPersonId(identifiers[0].PersonId); var resultPlacerGet = await registerPersonService.GetInteropPlacerValue(7, 4, encounterNumber); if (resultPlacerGet.Count > 0) { var getHtsEncounter = await encounterTestingService.GetHtsEncounter(resultPlacerGet[0].EntityId); var getPatientEncounter = await encounterTestingService.GetPatientEncounterById(getHtsEncounter.PatientEncounterID); getHtsEncounter.EverTested = clientEverTested; getHtsEncounter.MonthsSinceLastTest = monthsSinceLastTest; getHtsEncounter.MonthSinceSelfTest = null; getHtsEncounter.TestedAs = clientTestedAs; getHtsEncounter.TestingStrategy = testingStrategy; getHtsEncounter.EncounterRemarks = htsEncounterRemarks; //getHtsEncounter.FinalResultGiven = ; //getHtsEncounter.CoupleDiscordant = 1; getHtsEncounter.TestEntryPoint = testEntryPoint; getHtsEncounter.EverSelfTested = clientEverSelfTested; getHtsEncounter.EncounterType = htsencounterType; await encounterTestingService.UpdateHtsEncounter(getHtsEncounter); var getPatientScreenings = await encounterTestingService.GetPatientScreening(patient.Id, getPatientEncounter.PatientMasterVisitId, screeningTypeId, null); if (getPatientScreenings.Count > 0) { getPatientScreenings[0].ScreeningValueId = tbStatus; await encounterTestingService.UpdatePatientScreening(getPatientScreenings[0]); } else { //add patient screening var patientScreening = await encounterTestingService.addPatientScreening(patient.Id, getPatientEncounter.PatientMasterVisitId, screeningTypeId, encounterDate, tbStatus, providerId); } await encounterTestingService.UpdateClientDisabilities(identifiers[0].PersonId, clientDisabilities, getPatientEncounter.Id, providerId); } else { //add patient master visit var patientMasterVisit = await encounterTestingService.AddPatientMasterVisit(patient.Id, 2, encounterDate, providerId); //add patient encounter var patientEncounter = await encounterTestingService.AddPatientEncounter(patient.Id, encounterTypeId, patientMasterVisit.Id, encounterDate, 2, providerId); //add patient HTS encounter var htsEncounter = await encounterTestingService.addHtsEncounter(htsEncounterRemarks, clientEverSelfTested, clientEverTested, patientEncounter.Id, person.Id, providerId, testEntryPoint, htsencounterType, testingStrategy, clientTestedAs, monthsSinceLastTest, null); //add afya mobile placer value var addplacerHtsPlacer = await registerPersonService.AddInteropPlacerValue(htsEncounter.Id, 4, 7, encounterNumber); //add patient consent var consent = await encounterTestingService.addPatientConsent(patient.Id, patientMasterVisit.Id, 2, consentValue, consentTypeId, encounterDate, providerId, null); //add patient screening var patientScreening = await encounterTestingService.addPatientScreening(patient.Id, patientMasterVisit.Id, screeningTypeId, encounterDate, tbStatus, providerId); //add disabilities var disabilities = await encounterTestingService.addDisabilities(clientDisabilities, patientEncounter.Id, identifiers[0].PersonId, providerId); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Person with afyaMobileId: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Person with afyaMobileId: {afyaMobileId} could not be found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized HTS encounter for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized HTS encounter for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize encounter for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize encounter for clientid: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }
public async Task <Result <string> > Handle(AfyaMobilePartnerScreeningEncounterCommand request, CancellationToken cancellationToken) { string afyaMobileId = string.Empty; string indexClientAfyaMobileId = string.Empty; using (var trans = _htsUnitOfWork.Context.Database.BeginTransaction()) { try { RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork); EncounterTestingService encounterTestingService = new EncounterTestingService(_unitOfWork, _htsUnitOfWork); for (int j = 0; j < request.INTERNAL_PATIENT_ID.Count; j++) { if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "AFYA_MOBILE_ID") { afyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } if (request.INTERNAL_PATIENT_ID[j].IDENTIFIER_TYPE == "INDEX_CLIENT_AFYAMOBILE_ID") { indexClientAfyaMobileId = request.INTERNAL_PATIENT_ID[j].ID; } } var afyaMobileMessage = await registerPersonService.AddAfyaMobileInbox(DateTime.Now, request.MESSAGE_HEADER.MESSAGE_TYPE, afyaMobileId, JsonConvert.SerializeObject(request), false); int pnsAccepted = request.SCREENING.PARTNER_SCREENING.PNS_ACCEPTED; DateTime screeningDate = DateTime.Now; try { screeningDate = DateTime.ParseExact(request.SCREENING.PARTNER_SCREENING.SCREENING_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse partner screening SCREENING_DATE: {request.SCREENING.PARTNER_SCREENING.SCREENING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse partner screening SCREENING_DATE: {request.SCREENING.PARTNER_SCREENING.SCREENING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } int ipvScreeningDone = request.SCREENING.PARTNER_SCREENING.IPV_SCREENING_DONE; int hurtByPartner = request.SCREENING.PARTNER_SCREENING.HURT_BY_PARTNER; int threatByPartner = request.SCREENING.PARTNER_SCREENING.THREAT_BY_PARTNER; int sexualAbuseByPartner = request.SCREENING.PARTNER_SCREENING.SEXUAL_ABUSE_BY_PARTNER; int ipvOutcome = request.SCREENING.PARTNER_SCREENING.IPV_OUTCOME; string partnerOccupation = request.SCREENING.PARTNER_SCREENING.PARTNER_OCCUPATION; int partnerRelationship = request.SCREENING.PARTNER_SCREENING.PARTNER_RELATIONSHIP; int livingWithClient = request.SCREENING.PARTNER_SCREENING.LIVING_WITH_CLIENT; int hivStatus = request.SCREENING.PARTNER_SCREENING.HIV_STATUS; int pnsApproach = request.SCREENING.PARTNER_SCREENING.PNS_APPROACH; int eligibleForHts = request.SCREENING.PARTNER_SCREENING.ELIGIBLE_FOR_HTS; DateTime bookingDate = DateTime.Now; try { bookingDate = DateTime.ParseExact(request.SCREENING.PARTNER_SCREENING.BOOKING_DATE, "yyyyMMdd", null); } catch (Exception e) { Log.Error($"Could not parse partner screening BOOKING_DATE: {request.SCREENING.PARTNER_SCREENING.BOOKING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); throw new Exception($"Could not parse partner screening BOOKING_DATE: {request.SCREENING.PARTNER_SCREENING.BOOKING_DATE} as a valid date: Incorrect format, date should be in the following format yyyyMMdd"); } var pnsScreeningOptions = await _unitOfWork.Repository <LookupItemView>().Get(x => x.MasterName == "PnsScreening").ToListAsync(); int providerId = 1; List <Screening> newScreenings = new List <Screening>(); for (int j = 0; j < pnsScreeningOptions.Count; j++) { if (pnsScreeningOptions[j].ItemName == "EligibleTesting") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = eligibleForHts }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PNSApproach") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = pnsApproach }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "HIVStatus") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = hivStatus }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "LivingWithClient") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = livingWithClient }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsRelationship") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = partnerRelationship }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "IPVOutcome") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = ipvOutcome }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsForcedSexual") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = sexualAbuseByPartner }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsThreatenedHurt") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = threatByPartner }; newScreenings.Add(screening); } else if (pnsScreeningOptions[j].ItemName == "PnsPhysicallyHurt") { Screening screening = new Screening() { ScreeningCategoryId = pnsScreeningOptions[j].ItemId, ScreeningTypeId = pnsScreeningOptions[j].MasterId, ScreeningValueId = hurtByPartner }; newScreenings.Add(screening); } } var indexClientIdentifiers = await registerPersonService.getPersonIdentifiers(indexClientAfyaMobileId, 10); if (indexClientIdentifiers.Count > 0) { //Get Index client var indexClient = await registerPersonService.GetPatientByPersonId(indexClientIdentifiers[0].PersonId); var partnetPersonIdentifiers = await registerPersonService.getPersonIdentifiers(afyaMobileId, 10); if (partnetPersonIdentifiers.Count > 0) { var patientMasterVisitEntity = await _unitOfWork.Repository <PatientMasterVisit>() .Get(x => x.PatientId == indexClient.Id && x.ServiceId == 2).ToListAsync(); int patientMasterVisitId = patientMasterVisitEntity.OrderBy(x => x.Id).FirstOrDefault().Id; var partnHtsScreenings = await encounterTestingService.AddPartnerScreening( partnetPersonIdentifiers[0].PersonId, indexClient.Id, patientMasterVisitId, partnerOccupation, screeningDate, bookingDate, newScreenings, providerId); var stringParnerObject = Newtonsoft.Json.JsonConvert.SerializeObject(new { partnerId = partnetPersonIdentifiers[0].PersonId, pnsScreened = true }); var partnerScreeningDone = await registerPersonService.AddAppStateStore(indexClient.PersonId, indexClient.Id, 8, null, null, stringParnerObject); } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Partner with afyamobileid: {afyaMobileId} could not be found", false); return(Result <string> .Invalid($"Partner with afyamobileid: {afyaMobileId} could not be found")); } } else { //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Index clientid: {indexClientAfyaMobileId} for partnerid: {afyaMobileId} not found", false); return(Result <string> .Invalid($"Index clientid: {indexClientAfyaMobileId} for partnerid: {afyaMobileId} not found")); } //update message has been processed await registerPersonService.UpdateAfyaMobileInbox(afyaMobileMessage.Id, afyaMobileId, true, DateTime.Now, $"Successfully synchronized partner screening for afyamobileid: {afyaMobileId}", true); trans.Commit(); return(Result <string> .Valid($"Successfully synchronized partner screening for afyamobileid: {afyaMobileId}")); } catch (Exception ex) { trans.Rollback(); Log.Error($"Failed to synchronize partner screening for clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException); return(Result <string> .Invalid($"Failed to synchronize partner screening for clientId: {afyaMobileId} " + ex.Message + " " + ex.InnerException)); } } }