001/* 002 * jPOS Project [http://jpos.org] 003 * Copyright (C) 2000-2026 jPOS Software SRL 004 * 005 * This program is free software: you can redistribute it and/or modify 006 * it under the terms of the GNU Affero General Public License as 007 * published by the Free Software Foundation, either version 3 of the 008 * License, or (at your option) any later version. 009 * 010 * This program is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 013 * GNU Affero General Public License for more details. 014 * 015 * You should have received a copy of the GNU Affero General Public License 016 * along with this program. If not, see <http://www.gnu.org/licenses/>. 017 */ 018 019package org.jpos.iso; 020 021import java.util.LinkedList; 022import java.util.ListIterator; 023 024/** 025 * Wrapper class resulting from process of validating an ISOMsg 026 * instance. Contains details of the original msg and validation-error 027 * details too. Normally in validation process when an error is detected 028 * by validator in msg, then the msg is replaced by an instance 029 * of this class, containning error details. 030 * <p>Title: jPOS</p> 031 * <p>Description: Java Framework for Financial Systems</p> 032 * <p>Copyright: Copyright (c) 2000 jPOS.org. All rights reserved.</p> 033 * <p>Company: www.jPOS.org</p> 034 * @author Jose Eduardo Leon 035 * @version 1.0 036 */ 037@SuppressWarnings("unchecked") 038public class ISOVMsg extends ISOMsg implements ISOVErrorList { 039 040 private static final long serialVersionUID = 443461124206801037L; 041 042 /** 043 * Copy properties from parent. 044 * @param Source original instance. 045 */ 046 private void copyFromParent( ISOMsg Source ){ 047 this.packager = Source.packager; 048 this.fields = Source.fields; 049 this.dirty = Source.dirty; 050 this.maxFieldDirty = Source.maxFieldDirty; 051 this.header = Source.header; 052 this.fieldNumber = Source.fieldNumber; 053 this.maxField = Source.maxField; 054 this.direction = Source.direction; 055 } 056 057 /** 058 * Create a message from original instance adding error data. 059 * @param Source Original msg instance. 060 */ 061 public ISOVMsg( ISOMsg Source ) { 062 /** @todo Try best strategy */ 063 copyFromParent( Source ); 064 } 065 066 /** 067 * Wraps the source message and attaches an initial validation error. 068 * 069 * @param Source original {@link ISOMsg} to wrap 070 * @param FirstError initial error attached to the message 071 */ 072 public ISOVMsg( ISOMsg Source, ISOVError FirstError ) { 073 /** @todo Try best strategy */ 074 copyFromParent( Source ); 075 addISOVError( FirstError ); 076 } 077 078 /** 079 * Add an error component to the list of errors. 080 * @param Error Error instance to add. 081 * @return True if the list of errors change after operation. 082 */ 083 public boolean addISOVError(ISOVError Error) { 084 return errors.add( Error ); 085 } 086 087 /** 088 * Get an error iterator instance. 089 * @return iterator. 090 */ 091 public ListIterator errorListIterator() { 092 return errors.listIterator(); 093 } 094 095 /** list of errors **/ 096 protected LinkedList errors = new LinkedList( ); 097}