From 99c1b2fe4c5041a0e8c7d7fa7adaa6d6a7e873e3 Mon Sep 17 00:00:00 2001 From: Zubair Asghar Date: Mon, 20 Jan 2025 20:30:00 +0500 Subject: [PATCH] fix: notification when SendMessage action is used with HideOption (#19722) --- ...DefaultProgramRuleEntityMapperService.java | 152 ++++++++---------- .../ProgramRuleEntityMapperServiceTest.java | 18 ++- 2 files changed, 87 insertions(+), 83 deletions(-) diff --git a/dhis-2/dhis-services/dhis-service-program-rule/src/main/java/org/hisp/dhis/programrule/engine/DefaultProgramRuleEntityMapperService.java b/dhis-2/dhis-services/dhis-service-program-rule/src/main/java/org/hisp/dhis/programrule/engine/DefaultProgramRuleEntityMapperService.java index 89f6f10f080f..89a7a05d3ac1 100644 --- a/dhis-2/dhis-services/dhis-service-program-rule/src/main/java/org/hisp/dhis/programrule/engine/DefaultProgramRuleEntityMapperService.java +++ b/dhis-2/dhis-services/dhis-service-program-rule/src/main/java/org/hisp/dhis/programrule/engine/DefaultProgramRuleEntityMapperService.java @@ -66,82 +66,6 @@ public class DefaultProgramRuleEntityMapperService implements ProgramRuleEntityM private static final String LOCATION_INDICATOR = "indicators"; - private final ImmutableMap> - ACTION_MAPPER = - new ImmutableMap.Builder>() - .put( - ProgramRuleActionType.ASSIGN, - pra -> - RuleActionAssign.create( - pra.getContent(), - pra.getData(), - getAssignedParameter(pra), - getAttributeType(pra))) - .put( - ProgramRuleActionType.CREATEEVENT, - pra -> - RuleActionCreateEvent.create( - pra.getContent(), pra.getData(), pra.getLocation())) - .put( - ProgramRuleActionType.DISPLAYKEYVALUEPAIR, - this::getLocationBasedDisplayRuleAction) - .put(ProgramRuleActionType.DISPLAYTEXT, this::getLocationBasedDisplayRuleAction) - .put( - ProgramRuleActionType.HIDEFIELD, - pra -> - RuleActionHideField.create( - pra.getContent(), getAssignedParameter(pra), getAttributeType(pra))) - .put( - ProgramRuleActionType.HIDEPROGRAMSTAGE, - pra -> RuleActionHideProgramStage.create(pra.getProgramStage().getUid())) - .put( - ProgramRuleActionType.HIDESECTION, - pra -> RuleActionHideSection.create(pra.getProgramStageSection().getUid())) - .put( - ProgramRuleActionType.SHOWERROR, - pra -> - RuleActionShowError.create( - pra.getContent(), - pra.getData(), - getAssignedParameter(pra), - getAttributeType(pra))) - .put( - ProgramRuleActionType.SHOWWARNING, - pra -> - RuleActionShowWarning.create( - pra.getContent(), - pra.getData(), - getAssignedParameter(pra), - getAttributeType(pra))) - .put( - ProgramRuleActionType.SETMANDATORYFIELD, - pra -> - RuleActionSetMandatoryField.create( - getAssignedParameter(pra), getAttributeType(pra))) - .put( - ProgramRuleActionType.WARNINGONCOMPLETE, - pra -> - RuleActionWarningOnCompletion.create( - pra.getContent(), - pra.getData(), - getAssignedParameter(pra), - getAttributeType(pra))) - .put( - ProgramRuleActionType.ERRORONCOMPLETE, - pra -> - RuleActionErrorOnCompletion.create( - pra.getContent(), - pra.getData(), - getAssignedParameter(pra), - getAttributeType(pra))) - .put( - ProgramRuleActionType.SENDMESSAGE, - pra -> RuleActionSendMessage.create(pra.getTemplateUid(), pra.getData())) - .put( - ProgramRuleActionType.SCHEDULEMESSAGE, - pra -> RuleActionScheduleMessage.create(pra.getTemplateUid(), pra.getData())) - .build(); - private final ImmutableMap< ProgramRuleVariableSourceType, Function> VARIABLE_MAPPER = @@ -513,12 +437,76 @@ private Rule toRule(ProgramRule programRule) { } private RuleAction toRuleAction(ProgramRuleAction programRuleAction) { - return ACTION_MAPPER - .getOrDefault( - programRuleAction.getProgramRuleActionType(), - pra -> - RuleActionAssign.create(pra.getContent(), pra.getData(), getAssignedParameter(pra))) - .apply(programRuleAction); + if (programRuleAction == null) { + throw new IllegalArgumentException("ProgramRuleAction cannot be null."); + } + + ProgramRuleActionType actionType = programRuleAction.getProgramRuleActionType(); + if (actionType == null) { + throw new IllegalArgumentException("ProgramRuleActionType cannot be null."); + } + + switch (actionType) { + case ASSIGN: + return RuleActionAssign.create( + programRuleAction.getContent(), + programRuleAction.getData(), + getAssignedParameter(programRuleAction), + getAttributeType(programRuleAction)); + case CREATEEVENT: + return RuleActionCreateEvent.create( + programRuleAction.getContent(), + programRuleAction.getData(), + programRuleAction.getLocation()); + case DISPLAYKEYVALUEPAIR: + case DISPLAYTEXT: + return getLocationBasedDisplayRuleAction(programRuleAction); + case HIDEFIELD: + return RuleActionHideField.create( + programRuleAction.getContent(), + getAssignedParameter(programRuleAction), + getAttributeType(programRuleAction)); + case HIDEPROGRAMSTAGE: + return RuleActionHideProgramStage.create(programRuleAction.getProgramStage().getUid()); + case HIDESECTION: + return RuleActionHideSection.create(programRuleAction.getProgramStageSection().getUid()); + case SHOWERROR: + return RuleActionShowError.create( + programRuleAction.getContent(), + programRuleAction.getData(), + getAssignedParameter(programRuleAction), + getAttributeType(programRuleAction)); + case SHOWWARNING: + return RuleActionShowWarning.create( + programRuleAction.getContent(), + programRuleAction.getData(), + getAssignedParameter(programRuleAction), + getAttributeType(programRuleAction)); + case SETMANDATORYFIELD: + return RuleActionSetMandatoryField.create( + getAssignedParameter(programRuleAction), getAttributeType(programRuleAction)); + case WARNINGONCOMPLETE: + return RuleActionWarningOnCompletion.create( + programRuleAction.getContent(), + programRuleAction.getData(), + getAssignedParameter(programRuleAction), + getAttributeType(programRuleAction)); + case ERRORONCOMPLETE: + return RuleActionErrorOnCompletion.create( + programRuleAction.getContent(), + programRuleAction.getData(), + getAssignedParameter(programRuleAction), + getAttributeType(programRuleAction)); + case SENDMESSAGE: + return RuleActionSendMessage.create( + programRuleAction.getTemplateUid(), programRuleAction.getData()); + case SCHEDULEMESSAGE: + return RuleActionScheduleMessage.create( + programRuleAction.getTemplateUid(), programRuleAction.getData()); + default: + // Return null for unsupported types + return null; + } } private RuleVariable toRuleVariable(ProgramRuleVariable programRuleVariable) { diff --git a/dhis-2/dhis-services/dhis-service-program-rule/src/test/java/org/hisp/dhis/programrule/engine/ProgramRuleEntityMapperServiceTest.java b/dhis-2/dhis-services/dhis-service-program-rule/src/test/java/org/hisp/dhis/programrule/engine/ProgramRuleEntityMapperServiceTest.java index 5b6a07c71ec3..e1302bb7424f 100644 --- a/dhis-2/dhis-services/dhis-service-program-rule/src/test/java/org/hisp/dhis/programrule/engine/ProgramRuleEntityMapperServiceTest.java +++ b/dhis-2/dhis-services/dhis-service-program-rule/src/test/java/org/hisp/dhis/programrule/engine/ProgramRuleEntityMapperServiceTest.java @@ -109,6 +109,7 @@ class ProgramRuleEntityMapperServiceTest extends DhisConvenienceTest { private ProgramRule programRuleD = null; + private ProgramRuleAction hideOption = null; private ProgramRuleAction assignAction = null; private ProgramRuleAction sendMessageAction = null; @@ -427,6 +428,7 @@ private void setUpProgramRules() { assignAction = createProgramRuleAction('I'); sendMessageAction = createProgramRuleAction('J'); + hideOption = createProgramRuleAction('K'); displayText = createProgramRuleAction('D'); assignAction = @@ -437,8 +439,13 @@ private void setUpProgramRules() { sendMessageAction = setProgramRuleAction(sendMessageAction, ProgramRuleActionType.SENDMESSAGE, null, null); + hideOption = + setProgramRuleAction(hideOption, ProgramRuleActionType.HIDEOPTION, "content", null); + programRuleA = setProgramRule(programRuleA, "", Sets.newHashSet(assignAction, displayText), 1); - programRuleB = setProgramRule(programRuleB, "", Sets.newHashSet(sendMessageAction), 4); + programRuleB = + setProgramRule( + programRuleB, "", Sets.newHashSet(sendMessageAction, displayText, hideOption), 4); programRuleD = setProgramRule(programRuleD, "", Sets.newHashSet(sendMessageAction), null); programRules.add(programRuleA); @@ -531,6 +538,15 @@ private ProgramRuleAction setProgramRuleAction( programRuleActionA.setTemplateUid(notificationTemplate.getUid()); } + if (type == ProgramRuleActionType.HIDEOPTION) { + Option option = createOption('O'); + TrackedEntityAttribute tea = createTrackedEntityAttribute('A'); + + programRuleActionA.setOption(option); + programRuleActionA.setAttribute(tea); + programRuleActionA.setContent(content); + } + return programRuleActionA; }