com.prowidesoftware.swift.model.MtId 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 com.prowidesoftware.swift.model.field.Field32A;
import com.prowidesoftware.swift.model.mt.MTVariant;
import java.util.Objects;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang3.StringUtils;
/**
* Structured identification of MT message types, composed by the business process, actual type and variant.
*
* The business process is currently set to a fixed value "fin", however it is kept as
* class attribute because eventually could be used also for "apc".
*
* @author sebastian
* @since 7.8.4
*/
public class MtId {
private static final Pattern TYPE_PATTERN = Pattern.compile("\\d{3}");
private String businessProcess = "fin";
private String messageType;
private String variant;
/**
* @since @since 8.0.3
*/
public MtId() {}
/**
* Parses a string identifier into a structured MT identifier
* @param identifier an identifier such as 103, fin.103, fin.103.STP, 202.COV
* @since 7.8.6
*/
public MtId(String identifier) {
this();
if (identifier != null) {
// match exactly three digits from the identifier string
Matcher matcher = TYPE_PATTERN.matcher(identifier);
if (matcher.find()) {
this.messageType = matcher.group(0);
}
if (StringUtils.isNotBlank(this.messageType)) {
// if message type was extracted, we try to extract the variant as well
MTVariant.extract(identifier).ifPresent(variant -> this.variant = variant.name());
} else {
// otherwise we just use the parameter as type
this.messageType = identifier;
}
}
}
/**
* @param messageType the message type number (optionally prefixed with "fin.")
* @param variant An MT variant (STP, REMIT, COV), a MUG identifier or null if none applies
*/
public MtId(String messageType, String variant) {
if (StringUtils.startsWith(messageType, "fin.")) {
this.messageType = StringUtils.substringAfter(messageType, "fin.");
} else {
this.messageType = messageType;
}
this.variant = variant;
}
/**
* @param messageType the message type number
* @param variant a message variant (STP, REMIT, COV) or null if none applies
*/
public MtId(String messageType, MTVariant variant) {
this(messageType, variant != null ? variant.name() : null);
}
/**
* Parses a string identifier into a structured MT identifier
* @param identifier an identifier such as 103, fin.103, fin.103.STP, 202.COV
* @since 9.1.8
*/
public static MtId parse(final String identifier) {
return new MtId(identifier);
}
public String getBusinessProcess() {
return businessProcess;
}
/**
* @since 8.0.3 returns this
*/
public MtId setBusinessProcess(String businessProcess) {
this.businessProcess = businessProcess;
return this;
}
public String getMessageType() {
return messageType;
}
/**
* @since 8.0.3 returns this
*/
public MtId setMessageType(String messageType) {
this.messageType = messageType;
return this;
}
public String getVariant() {
return variant;
}
/**
* @since 8.0.3 returns this
*/
public MtId setVariant(String variant) {
this.variant = variant;
return this;
}
/**
* @since 9.2.6
*/
public MtId setVariant(MTVariant variant) {
this.variant = variant.name();
return this;
}
@Override
public String toString() {
return id();
}
/**
* Get a string in the form of businessprocess.messagetype.variant
*
* @return a string with the MT message type identification
* @since 7.8.4
*/
public String id() {
final StringBuilder sb = new StringBuilder();
if (businessProcess != null) {
sb.append(businessProcess);
} else {
return null;
}
if (messageType != null) {
sb.append(".").append(messageType);
} else {
return null;
}
if (variant != null) {
sb.append(".").append(variant);
}
return sb.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
MtId mtId = (MtId) o;
return Objects.equals(businessProcess, mtId.businessProcess)
&& Objects.equals(messageType, mtId.messageType)
&& Objects.equals(variant, mtId.variant);
}
@Override
public int hashCode() {
return Objects.hash(businessProcess, messageType, variant);
}
/**
* Returns the first number in the message type, representing the message category.
* For example for 103 returns 1
*
* @return the message category number or empty if the message type is invalid or not present
* @since 7.10.4
*/
public String category() {
if (messageType != null && messageType.length() > 0) {
char cat = messageType.charAt(0);
if (Character.isDigit(cat)) {
return String.valueOf(cat);
}
}
return "";
}
/**
* Creates the corresponding ISO 15022 namespace URI for this MT, for example: urn:swift:xsd:fin.103.2021
*
* @return a string representing the namespace URI for the MT
* @since 9.2.14
*/
public String namespaceURI() {
return new StringBuilder("urn:swift:xsd:")
.append(id())
.append(".")
.append(Field32A.SRU)
.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy