All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.prowidesoftware.swift.model.SwiftBlock Maven / Gradle / Ivy

There is a newer version: SRU2024-10.2.3
Show newest version
/*
 * Copyright 2006-2023 Prowide
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.prowidesoftware.swift.model;

import java.io.Serializable;
import java.util.Objects;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.builder.ToStringBuilder;

/**
 * Base class for a generic SWIFT block.
* This is an abstract class so specific block classes for each block (block 1, 2, 3, etc...) * should be instantiated.
*
* Instances of this class may have a list of unparsed texts (UnparsedTextList). * For easy access, methods have been created that first ensure the lists exists (the * real object is created and then call the base method).
* However, not all the base list methods have been implemented. If you need to use not * exposed functionality, retrieve the underlying list with (see getUnparsedTexts method)
* * @author sebastian */ // TODO: add parameter checks (Validate.*) and complete javadocs public abstract class SwiftBlock implements Serializable { private static final long serialVersionUID = -6993261477630953757L; /** * List of unparsed texts. For performance reasons, this will be null until really needed. */ protected UnparsedTextList unparsedTexts = null; /** * Only valid for block2, only when using hibernate for persistence */ protected Boolean input; /** * Only valid for block2, only when using hibernate for persistence */ protected Boolean output; /** * helper for hibernate mapping */ protected String blockType; /** * Default constructor, shouldn't be used normally. * DO NOT USE: present only for subclasses */ protected SwiftBlock() {} /** * Constructor for an unparsed text list * * @param unparsedText the list of unparsed texts */ public SwiftBlock(final UnparsedTextList unparsedText) { // set the unparsed text list this.unparsedTexts = unparsedText; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; SwiftBlock that = (SwiftBlock) o; return Objects.equals(unparsedTexts, that.unparsedTexts); } @Override public int hashCode() { return Objects.hash(unparsedTexts); } /** * @return a string identifying block type or null if not implemented */ public String getBlockType() { return blockType; } /** * should not be normally called * @param blockType block type * */ public void setBlockType(String blockType) { this.blockType = blockType; } /** * Sets the block number (this method is to be overwrite for derived classes). * * @param blockNumber the block number to set * @since 5.0 */ protected abstract void setBlockNumber(Integer blockNumber); /** * Sets the block name (this method is to be overwrite for derived classes). * * @param blockName the block name to set * @since 5.0 */ protected abstract void setBlockName(String blockName); /** * Returns the block number (this method is to be overwritten for derived classes). * * @return Integer containing the block's number */ public abstract Integer getNumber(); /** * Returns the block name (this method is to be overwritten for derived classes). * * @return block name * @since 5.0 */ public abstract String getName(); @Override public String toString() { return ToStringBuilder.reflectionToString(this); } /** * Tell if this block is a block that contains a list of tags (3-5) or is a block with fixed length value (1-2) * * @return true if this object contains a list of tags (which may be empty or null */ public boolean isTagBlock() { return this instanceof SwiftTagListBlock; } /** * verifies that the unparsed text list exists */ protected void unparsedTextVerify() { if (this.unparsedTexts == null) { this.unparsedTexts = new UnparsedTextList(); } } /** * Returns the unparsed text list attached to the Block. * * @return the unparsed texts attached to the block */ public UnparsedTextList getUnparsedTexts() { // create the list if needed unparsedTextVerify(); return this.unparsedTexts; } /** * sets the list of unparsed texts * * @param texts the new list of unparsed texts (may be null) */ public void setUnparsedTexts(final UnparsedTextList texts) { this.unparsedTexts = texts; } /** * returns the size of the unparsed text list * * @return the count of unparsed test attached to the block */ public Integer getUnparsedTextsSize() { // no list => size is zero... if (this.unparsedTexts == null) { return 0; } return this.unparsedTexts.size(); } /** * decides if a specific text (by index) is likely a SWIFT FIN message. Exceptions are inherited from * base implementation methods. * * @param index the unparsed text number * @return true if the unparsed text at position index is a full SWIFT Message * @throws IllegalArgumentException if parameter index is null * @throws IndexOutOfBoundsException if parameter index is out of bounds */ public Boolean unparsedTextIsMessage(final Integer index) { // create the list if needed unparsedTextVerify(); return this.unparsedTexts.isMessage(index); } /** * get an unparsed text * * @param index the unparsed text number * @return the requested text * @throws IllegalArgumentException if parameter index is null * @throws IndexOutOfBoundsException if parameter index is out of bounds */ public String unparsedTextGetText(final Integer index) { // create the list if needed unparsedTextVerify(); return this.unparsedTexts.getText(index); } /** * get an unparsed text as a parsed swift message * * @param index the unparsed text number * @return the blocks unparsed text at position index, parsed into a SwiftMessage object * @throws IllegalArgumentException if parameter index is null */ public SwiftMessage unparsedTextGetAsMessage(final Integer index) { // create the list if needed unparsedTextVerify(); return this.unparsedTexts.getTextAsMessage(index); } /** * adds a new unparsed text * * @param text the unparsed text to append * @throws IllegalArgumentException if parameter text is null */ public void unparsedTextAddText(final String text) { // create the list if needed unparsedTextVerify(); this.unparsedTexts.addText(text); } /** * adds a new unparsed text from a message * * @param message the message to be appended * @throws IllegalArgumentException if parameter message is null */ public void unparsedTextAddText(final SwiftMessage message) { // create the list if needed unparsedTextVerify(); this.unparsedTexts.addText(message); } /** * Only valid for block2, only when using hibernate for persistence * * @return true if the message block type is 2I * @deprecated Use {@link #getBlockType()} */ @Deprecated public Boolean getInput() { return StringUtils.equals(getBlockType(), "2I"); } /** * Only valid for block2, only when using hibernate for persistence * * @param input the is input parameter */ public void setInput(Boolean input) { this.input = input; } /** * Only valid for block2, only when using hibernate for persistence * * @return true if message block type is 2O * @deprecated Use {@link #getBlockType()} */ @Deprecated public Boolean getOutput() { return StringUtils.equals(getBlockType(), "2O"); } /** * Only valid for block2, only when using hibernate for persistence * * @param output the is output parameter */ public void setOutput(Boolean output) { this.output = output; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy