From ed8f2f2024b54681cb05c5835ea78bf4fbfd8c28 Mon Sep 17 00:00:00 2001 From: Michael Seaton Date: Thu, 3 Oct 2024 12:30:20 -0400 Subject: [PATCH] RA-2050 - FIX NPE on registration find patient page. --- .../controller/FindPatientPageController.java | 24 +++++++++++++------ 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/omod/src/main/java/org/openmrs/module/registrationapp/page/controller/FindPatientPageController.java b/omod/src/main/java/org/openmrs/module/registrationapp/page/controller/FindPatientPageController.java index 56c0f3fc..7de999b9 100644 --- a/omod/src/main/java/org/openmrs/module/registrationapp/page/controller/FindPatientPageController.java +++ b/omod/src/main/java/org/openmrs/module/registrationapp/page/controller/FindPatientPageController.java @@ -55,15 +55,25 @@ public void controller(UiSessionContext uiSessionContext, ) throws EvaluationException { Location sessionLocation = uiSessionContext.getSessionLocation(); + List mostRecentRegistrationEncounters = null; + // only show the most recent registration encounters if a registration encounter has been defined for this app - if (app.getConfig() != null && app.getConfig().get("registrationEncounter") != null) { - model.addAttribute("mostRecentRegistrationEncounters", addMostRecentRegistrationEncounters(model, app, libraries, dsdService, encounterService, sessionLocation)); - model.addAttribute("appId", app.getId()); - } - else { - model.addAttribute("mostRecentRegistrationEncounters", null); - model.addAttribute("appId", null); + if (app.getConfig() != null) { + JsonNode registrationEncounterConfig = app.getConfig().get("registrationEncounter"); + if (registrationEncounterConfig != null) { + JsonNode encounterTypeConfig = registrationEncounterConfig.get("encounterType"); + if (encounterTypeConfig != null) { + String encounterTypeUuid = encounterTypeConfig.getTextValue(); + EncounterType et = encounterService.getEncounterTypeByUuid(encounterTypeUuid); + if (et == null) { + throw new IllegalStateException("Invalid configuration for registrationEncounter. No encounterType found for uuid " + encounterTypeUuid); + } + mostRecentRegistrationEncounters = addMostRecentRegistrationEncounters(model, app, libraries, dsdService, encounterService, sessionLocation); + } + } } + model.addAttribute("mostRecentRegistrationEncounters", mostRecentRegistrationEncounters); + model.addAttribute("appId", app.getId()); JsonNode columnConfig = null; if (app.getConfig() != null) {