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

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

/*
 * 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.util.Objects;
import org.apache.commons.lang3.StringUtils;

/**
 * Identifies a logical channel connection to SWIFT, and the network uses it for addressing.
 * It is basically a BIC code with an additional character identifier the terminal sending the message. The LT
 * identifier is located in position 9 of a full 12 characters address.
 * For example letter 'A' in CCCCUS33AXXX
*

* A sender LT address cannot have 'X' as LT identifier, conversely a * receiver LT address must have an 'X' as LT identifier. * * @author sebastian * @since 7.6 */ public class LogicalTerminalAddress extends BIC { private Character lTIdentifier = null; /** * Creates an LT address from its string value. *

If the string contains a BIC8 or BIC11 the LT identifier will be set with a default value. If the BIC has * 12 characters, then the LT and branch is extracted from the parameter code. Finally if the BIC has a special * size of 9 characters, that is parsed as the BIC8 plus the LT identifier, letting the branch with default. * * @param code a full LT address code (12 characters) or a BIC8, BIC11 or BIC8 plus LT identifier */ public LogicalTerminalAddress(final String code) { if (code != null) { setInstitution(StringUtils.trimToNull(StringUtils.substring(code, 0, 4))); setCountry(StringUtils.trimToNull(StringUtils.substring(code, 4, 6))); setLocation(StringUtils.trimToNull(StringUtils.substring(code, 6, 8))); if (code.length() > 8) { // after the BIC 8 we expect the LT, the LT + branch o just the branch if (code.length() == 9) { // if it has just 9 characters we assume it is a BIC8 plus the LT without branch this.lTIdentifier = code.charAt(8); } else if (code.length() >= 12) { // for 12 or more characters we extract both the LT and the branch this.lTIdentifier = code.charAt(8); super.branch = StringUtils.trimToNull(StringUtils.substring(code, 9)); } else { // otherwise we take the part after the BIC8 as the branch super.branch = StringUtils.trimToNull(StringUtils.substring(code, 8)); } } } } public Character getLTIdentifier() { return lTIdentifier; } public void setLTIdentifier(final Character _lTIdentifier) { lTIdentifier = _lTIdentifier; } /** * Returns a proper LT address for the sender of a message, assuring * the returned code has 12 characters and with no "X" in the 9th position. * *

If the terminal identifier is not set or if it is set to "X", then * the default identifier "A" will be used. * *

The branch code is padded with "XXX" if not present. * * @return the 12 characters address or null if the BIC has less than 8 characters */ public String getSenderLogicalTerminalAddress() { char LT = this.lTIdentifier == null || this.lTIdentifier.equals('X') ? 'A' : this.lTIdentifier; if (getBic8() != null) { return getBic8() + LT + getBranchOrDefault(); } return null; } /** * Returns a proper LT address for the receiver of a message, assuring * the returned code has 12 characters and with a fixed "X" in the 9th position. * *

The branch code is padded with "XXX" if not present. * * @return the 12 characters address or null if the BIC has less than 8 characters */ public String getReceiverLogicalTerminalAddress() { if (getBic8() != null) { return getBic8() + "X" + getBranchOrDefault(); } return null; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; if (!super.equals(o)) return false; LogicalTerminalAddress that = (LogicalTerminalAddress) o; return Objects.equals(lTIdentifier, that.lTIdentifier); } @Override public int hashCode() { return Objects.hash(super.hashCode(), lTIdentifier); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy