/* * The Kuali Financial System, a comprehensive financial management system for higher education. * * Copyright 2005-2014 The Kuali Foundation * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.kuali.kfs.module.purap.document.validation.impl; import java.util.Date; import org.kuali.kfs.module.purap.PurapConstants; import org.kuali.kfs.module.purap.PurapKeyConstants; import org.kuali.kfs.module.purap.PurapPropertyConstants; import org.kuali.kfs.module.purap.document.PurchasingDocument; import org.kuali.kfs.sys.document.validation.GenericValidation; import org.kuali.kfs.sys.document.validation.event.AttributedDocumentEvent; import org.kuali.kfs.sys.service.UniversityDateService; import org.kuali.rice.core.api.datetime.DateTimeService; import org.kuali.rice.krad.util.GlobalVariables; import org.kuali.rice.krad.util.ObjectUtils; public class PurchasingPaymentInfoValidation extends GenericValidation { DateTimeService dateTimeService; UniversityDateService universityDateService; public boolean validate(AttributedDocumentEvent event) { boolean valid = true; PurchasingDocument purDocument = (PurchasingDocument)event.getDocument(); GlobalVariables.getMessageMap().addToErrorPath(PurapConstants.PAYMENT_INFO_ERRORS); valid &= checkBeginDateBeforeEndDate(purDocument); if (valid && (ObjectUtils.isNotNull(purDocument.getPurchaseOrderBeginDate()) || ObjectUtils.isNotNull(purDocument.getPurchaseOrderEndDate()))) { if (ObjectUtils.isNotNull(purDocument.getPurchaseOrderBeginDate()) && ObjectUtils.isNull(purDocument.getPurchaseOrderEndDate())) { GlobalVariables.getMessageMap().putError(PurapPropertyConstants.PURCHASE_ORDER_END_DATE, PurapKeyConstants.ERROR_PURCHASE_ORDER_BEGIN_DATE_NO_END_DATE); valid &= false; } else { if (ObjectUtils.isNull(purDocument.getPurchaseOrderBeginDate()) && ObjectUtils.isNotNull(purDocument.getPurchaseOrderEndDate())) { GlobalVariables.getMessageMap().putError(PurapPropertyConstants.PURCHASE_ORDER_BEGIN_DATE, PurapKeyConstants.ERROR_PURCHASE_ORDER_END_DATE_NO_BEGIN_DATE); valid &= false; } } } if (valid && ObjectUtils.isNotNull(purDocument.getPurchaseOrderBeginDate()) && ObjectUtils.isNotNull(purDocument.getPurchaseOrderEndDate())) { if (ObjectUtils.isNull(purDocument.getRecurringPaymentTypeCode())) { GlobalVariables.getMessageMap().putError(PurapPropertyConstants.RECURRING_PAYMENT_TYPE_CODE, PurapKeyConstants.ERROR_RECURRING_DATE_NO_TYPE); valid &= false; } } else if (valid && ObjectUtils.isNotNull(purDocument.getRecurringPaymentTypeCode())) { GlobalVariables.getMessageMap().putError(PurapPropertyConstants.PURCHASE_ORDER_BEGIN_DATE, PurapKeyConstants.ERROR_RECURRING_TYPE_NO_DATE); valid &= false; } //checks for when FY is set to next FY if (purDocument.isPostingYearNext()) { Integer currentFY = universityDateService.getCurrentFiscalYear(); Date closingDate = universityDateService.getLastDateOfFiscalYear(currentFY); //if recurring payment begin dates entered, begin date must be > closing date if (ObjectUtils.isNotNull(purDocument.getPurchaseOrderBeginDate()) && (purDocument.getPurchaseOrderBeginDate().before(closingDate) || purDocument.getPurchaseOrderBeginDate().equals(closingDate))) { GlobalVariables.getMessageMap().putError(PurapPropertyConstants.PURCHASE_ORDER_BEGIN_DATE, PurapKeyConstants.ERROR_NEXT_FY_BEGIN_DATE_INVALID); valid &= false; } } GlobalVariables.getMessageMap().removeFromErrorPath(PurapConstants.PAYMENT_INFO_ERRORS); return valid; } /** * Implementation of the rule that if a document has a recurring payment begin date and end date, the begin date should come * before the end date. We needed to play around with this order if the fiscal year is the next fiscal year, since we * were dealing just with month and day, but we don't need to do that here; we're dealing with the whole Date object. * * @param purDocument the purchasing document to be validated * @return boolean false if the begin date is not before the end date. */ protected boolean checkBeginDateBeforeEndDate(PurchasingDocument purDocument) { boolean valid = true; Date beginDate = purDocument.getPurchaseOrderBeginDate(); Date endDate = purDocument.getPurchaseOrderEndDate(); if (ObjectUtils.isNotNull(beginDate) && ObjectUtils.isNotNull(endDate)) { if (dateTimeService.dateDiff(beginDate, endDate, false) <= 0) { valid &= false; GlobalVariables.getMessageMap().putError(PurapPropertyConstants.PURCHASE_ORDER_END_DATE, PurapKeyConstants.ERROR_PURCHASE_ORDER_BEGIN_DATE_AFTER_END); } } return valid; } public DateTimeService getDateTimeService() { return dateTimeService; } public void setDateTimeService(DateTimeService dateTimeService) { this.dateTimeService = dateTimeService; } public UniversityDateService getUniversityDateService() { return universityDateService; } public void setUniversityDateService(UniversityDateService universityDateService) { this.universityDateService = universityDateService; } }