001 /* 002 * Copyright 2011 The Kuali Foundation. 003 * 004 * Licensed under the Educational Community License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.opensource.org/licenses/ecl2.php 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 package org.kuali.kfs.fp.document.validation.impl; 017 018 import static org.kuali.kfs.sys.KFSConstants.ACCOUNTING_LINE_ERRORS; 019 import static org.kuali.kfs.sys.KFSKeyConstants.ERROR_DOCUMENT_BALANCE_CONSIDERING_CREDIT_AND_DEBIT_AMOUNTS; 020 021 import org.kuali.kfs.fp.document.AuxiliaryVoucherDocument; 022 import org.kuali.kfs.sys.document.validation.GenericValidation; 023 import org.kuali.kfs.sys.document.validation.event.AttributedDocumentEvent; 024 import org.kuali.rice.kns.util.GlobalVariables; 025 import org.kuali.rice.kns.util.KualiDecimal; 026 027 /** 028 * Validation for Auxiliary Voucher, which checks tha tthe accounting lines on the document, with all of 029 * their various credits and debits, balance. 030 */ 031 public class AuxiliaryVoucherAccountingLinesBalanceValidation extends GenericValidation { 032 private AuxiliaryVoucherDocument auxiliaryVoucherDocumentForValidation; 033 034 /** 035 * Returns true if credit/debit entries are in balance 036 * @see org.kuali.kfs.sys.document.validation.Validation#validate(org.kuali.kfs.sys.document.validation.event.AttributedDocumentEvent) 037 */ 038 public boolean validate(AttributedDocumentEvent event) { 039 KualiDecimal creditAmount = getAuxiliaryVoucherDocumentForValidation().getCreditTotal(); 040 KualiDecimal debitAmount = getAuxiliaryVoucherDocumentForValidation().getDebitTotal(); 041 042 boolean balanced = debitAmount.equals(creditAmount); 043 if (!balanced) { 044 String errorParams[] = { creditAmount.toString(), debitAmount.toString() }; 045 GlobalVariables.getMessageMap().putError(ACCOUNTING_LINE_ERRORS, ERROR_DOCUMENT_BALANCE_CONSIDERING_CREDIT_AND_DEBIT_AMOUNTS, errorParams); 046 } 047 return balanced; 048 } 049 050 /** 051 * Gets the auxiliaryVoucherDocumentForValidation attribute. 052 * @return Returns the auxiliaryVoucherDocumentForValidation. 053 */ 054 public AuxiliaryVoucherDocument getAuxiliaryVoucherDocumentForValidation() { 055 return auxiliaryVoucherDocumentForValidation; 056 } 057 058 /** 059 * Sets the auxiliaryVoucherDocumentForValidation attribute value. 060 * @param auxiliaryVoucherDocumentForValidation The auxiliaryVoucherDocumentForValidation to set. 061 */ 062 public void setAuxiliaryVoucherDocumentForValidation(AuxiliaryVoucherDocument accountingDocumentForValidation) { 063 this.auxiliaryVoucherDocumentForValidation = accountingDocumentForValidation; 064 } 065 }