/** * This Source Code Form is subject to the terms of the Mozilla Public License, * v. 2.0. If a copy of the MPL was not distributed with this file, You can * obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under * the terms of the Healthcare Disclaimer located at http://openmrs.org/license. * * Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS * graphic logo is a trademark of OpenMRS Inc. */ package org.openmrs.api.handler; import java.util.Date; import org.apache.commons.lang.StringUtils; import org.openmrs.Cohort; import org.openmrs.Encounter; import org.openmrs.Obs; import org.openmrs.Order; import org.openmrs.Patient; import org.openmrs.User; import org.openmrs.Voidable; import org.openmrs.annotation.Handler; import org.openmrs.aop.RequiredDataAdvice; /** * This class ensures that the voidReason is non-null for supported object types * * @see RequiredDataAdvice * @see UnvoidHandler * @since 1.5 */ @Handler(supports = { Patient.class, Encounter.class, Obs.class, Cohort.class, Order.class }, order = 1 /* low order so this is run first */) public class RequireVoidReasonVoidHandler implements VoidHandler<Voidable> { /** * Validates that the voidReason is non-null and non-empty for supported objects * * @should throw IllegalArgumentException if Patient voidReason is null * @should throw IllegalArgumentException if Encounter voidReason is empty * @should throw IllegalArgumentException if Obs voidReason is blank * @should not throw Exception if voidReason is not blank * @should not throw Exception if voidReason is null for unsupported types */ @Override public void handle(Voidable voidableObject, User voidingUser, Date voidedDate, String voidReason) { if (StringUtils.isBlank(voidReason)) { throw new IllegalArgumentException("The 'reason' argument is required"); } } }