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

org.jdtaus.banking.Textschluessel Maven / Gradle / Ivy

There is a newer version: 1.16
Show newest version
/*
 *  jDTAUS Banking API
 *  Copyright (C) 2005 Christian Schulte
 *  
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or any later version.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 *
 */
package org.jdtaus.banking;

import java.io.ObjectStreamException;
import java.io.Serializable;
import java.text.MessageFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Locale;
import java.util.Map;
import java.util.Set;
import org.jdtaus.core.container.ContainerFactory;
import org.jdtaus.core.container.PropertyException;

/**
 * Type of a transaction in germany.
 * 

A Textschlüssel is made up of a two-digit positive integer (the key) and a three-digit positive integer * (the extension). The key, together with a constant extension, uniquely identifies a transaction's type. The extension * may also be used to hold non-identifying data. In such cases only the key is used to identify a transaction's type * and the extension holds variable data.

* * @author Christian Schulte * @version $JDTAUS: Textschluessel.java 8811 2012-12-04 00:48:00Z schulte $ * * @see TextschluesselVerzeichnis */ public class Textschluessel implements Cloneable, Comparable, Serializable { /** Constant for the name of property {@code key}. */ public static final String PROP_KEY = "org.jdtaus.banking.Textschluessel.PROP_KEY"; /** Constant for the name of property {@code extension}. */ public static final String PROP_EXTENSION = "org.jdtaus.banking.Textschluessel.PROP_EXTENSION"; /** Constant for the name of property {@code validTo}. */ public static final String PROP_VALID_TO = "org.jdtaus.banking.Textschluessel.PROP_VALID_TO"; /** Constant for the name of property {@code validFrom}. */ public static final String PROP_VALID_FROM = "org.jdtaus.banking.Textschluessel.PROP_VALID_FROM"; /** Constant for the name of property {@code debit}. */ public static final String PROP_DEBIT = "org.jdtaus.banking.Textschluessel.PROP_DEBIT"; /** Constant for the name of property {@code remittance}. */ public static final String PROP_REMITTANCE = "org.jdtaus.banking.Textschluessel.PROP_REMITTANCE"; /** Constant for the name of property {@code variable}. */ public static final String PROP_VARIABLE = "org.jdtaus.banking.Textschluessel.PROP_VARIABLE"; /** Constant for the name of property {@code shortDescription}. */ public static final String PROP_SHORTDESCRIPTION = "org.jdtaus.banking.Textschluessel.PROP_SHORTDESCRIPTION"; /** Serial version UID for backwards compatibility with 1.0.x classes. */ private static final long serialVersionUID = -8556424800883022756L; /** * Key of the Textschlüssel. * @serial */ private int key; /** * Extension of the Textschlüsse. * @serial */ private int extension; /** * Start date of validity. * @serial */ private Date validFrom; private transient long validFromMillis; /** * End date of validity. * @serial */ private Date validTo; private transient long validToMillis; /** * Flag indicating if a transaction of the type is a debit. * @serial */ private boolean debit; /** * Flag indicating if a transaction of the type is a remittance. * @serial */ private boolean remittance; /** * Flag indicating if the extension holds non-identifying, variable data. * @serial */ private boolean variable; /** * Maps language codes to short descriptions. * @serial */ private Map shortDescriptions = new HashMap( 10 ); /** Cached hash code. */ private transient int hashCode = NO_HASHCODE; private static final int NO_HASHCODE = Integer.MIN_VALUE; /** Creates a new {@code Textschluessel} instance. */ public Textschluessel() { super(); this.assertValidProperties(); } /** * Getter for property {@code key}. * * @return Key of the Textschlüssel. */ public int getKey() { return this.key; } /** * Setter for property {@code key}. * * @param value New key of the Textschlüssel. */ public void setKey( final int value ) { this.key = value; this.hashCode = NO_HASHCODE; } /** * Getter for property {@code extension}. * * @return Extension of the Textschlüssel. */ public int getExtension() { return this.extension; } /** * Setter for property {@code extension}. * * @param value New extension of the Textschlüssel. */ public void setExtension( final int value ) { this.extension = value; this.hashCode = NO_HASHCODE; } /** * Gets the date of validity of the Textschlüssel. * * @return The date the Textschlüssel is valid from (inclusive) or {@code null} if nothing is known about the start * of validity of the Textschlüssel. */ public Date getValidFrom() { return this.validFrom != null ? (Date) this.validFrom.clone() : null; } /** * Sets the date of validity of the Textschlüssel. * * @param value The new date the Textschlüssel is valid from or {@code null} if nothing is known about the start of * validity of the Textschlüssel. */ public void setValidFrom( final Date value ) { if ( value == null ) { this.validFrom = null; this.validFromMillis = 0L; } else { this.validFrom = (Date) value.clone(); this.validFromMillis = value.getTime(); } } /** * Gets the date of expiration of the Textschlüssel. * * @return The date the Textschlüssel is valid to (inclusive) or {@code null} if nothing is known about the date of * expiration of the Textschlüssel. */ public Date getValidTo() { return this.validTo != null ? (Date) this.validTo.clone() : null; } /** * Sets the date of expiration of the Textschlüssel. * * @param value The new date the Textschlüssel is valid to or {@code null} if nothing is known about the date of * expiration of the Textschlüssel. */ public void setValidTo( final Date value ) { if ( value == null ) { this.validTo = null; this.validToMillis = 0L; } else { this.validTo = (Date) value.clone(); this.validToMillis = 0L; } } /** * Gets a flag indicating that the Textschlüssel is valid at a given date. * * @param date The date with which to check. * * @return {@code true}, if the Textschlüssel is valid at {@code date}; {@code false} if not. * * @throws NullPointerException if {@code date} is {@code null}. */ public boolean isValidAt( final Date date ) { if ( date == null ) { throw new NullPointerException( "date" ); } return !( ( this.validFrom != null && this.validFromMillis > date.getTime() ) || ( this.validTo != null && this.validToMillis < date.getTime() ) ); } /** * Flag indicating if a transaction of this type is a debit. * * @return {@code true} if a transaction of this type is a debit; {@code false} if not. */ public boolean isDebit() { return this.debit; } /** * Setter for property {@code debit}. * * @param value {@code true} if a transaction of this type is a debit; {@code false} if not. */ public void setDebit( final boolean value ) { this.debit = value; } /** * Flag indicating if a transaction of this type is a remittance. * * @return {@code true} if a transaction of this type is a remittance; {@code false} if not. */ public boolean isRemittance() { return this.remittance; } /** * Setter for property {@code remittance}. * * @param value {@code true} if a transaction of this type is a remittance; {@code false} if not. */ public void setRemittance( final boolean value ) { this.remittance = value; } /** * Flag indicating if the extension holds non-identifying, variable data. * * @return {@code true} if the extension holds non-identifying, variable data; {@code false} if the extension is * part of the identifying key. */ public boolean isVariable() { return this.variable; } /** * Setter for property {@code variable}. * * @param value {@code true} if the extension holds non-identifying, variable data; {@code false} if the extension * is part of the identifying key. */ public void setVariable( final boolean value ) { this.variable = value; this.hashCode = NO_HASHCODE; } /** * Gets the short description of the Textschlüssel for a given locale. * * @param locale The locale of the short description to return or {@code null} for {@code Locale.getDefault()}. * * @return The short description of the instance for {@code locale}. */ public String getShortDescription( final Locale locale ) { final Locale l = locale == null ? Locale.getDefault() : locale; this.assertValidProperties(); // Try the requested language. String description = (String) this.shortDescriptions.get( l.getLanguage().toLowerCase() ); if ( description == null ) { // Try the configured default language. description = (String) this.shortDescriptions.get( this.getDefaultLanguage().toLowerCase() ); } if ( description == null ) { // Try the system's default language. description = (String) this.shortDescriptions.get( Locale.getDefault().getLanguage().toLowerCase() ); } if ( description == null ) { // Fall back to a default message just stating key and extension. description = this.getTextschluesselDescriptionMessage( this.getLocale(), new Integer( this.getKey() ), new Integer( this.getExtension() ) ); } return new MessageFormat( description, l ).format( new Object[] { new Integer( this.getKey() ), new Integer( this.getExtension() ) } ); } /** * Setter for property {@code shortDescription}. * * @param locale The locale to set the short description for or {@code null} for {@code Locale.getDefault()}. * @param shortDescription The new value for property {@code shortDescription} for {@code locale}. * * @return The value previously held by the instance for {@code locale} or {@code null} if the instance previously * held no value for {@code locale}. * * @throws NullPointerException if {@code shortDescription} is {@code null}. */ public String setShortDescription( final Locale locale, final String shortDescription ) { if ( shortDescription == null ) { throw new NullPointerException( "shortDescription" ); } final Locale l = locale == null ? Locale.getDefault() : locale; return (String) this.shortDescriptions.put( l.getLanguage().toLowerCase(), shortDescription ); } /** * Gets all locales for which the instance holds short descriptions. * * @return All locales for which the instance holds short descriptions. */ public Locale[] getLocales() { final Set locales = new HashSet( this.shortDescriptions.size() ); for ( final Iterator it = this.shortDescriptions.keySet().iterator(); it.hasNext(); ) { locales.add( new Locale( (String) it.next() ) ); } return (Locale[]) locales.toArray( new Locale[ locales.size() ] ); } /** * Checks configured properties. * * @throws PropertyException for invalid property values. * * @deprecated Removed without replacement. */ protected void assertValidProperties() { if ( this.getDefaultLanguage() == null || this.getDefaultLanguage().length() <= 0 ) { throw new PropertyException( "defaultLanguage", this.getDefaultLanguage() ); } } /** * Compares this object with the specified object for order. *

Compares the values of properties {@code key} and {@code extension} and returns a negative integer, zero, or a * positive integer as this object is less than, equal to, or greater than the specified object.

* * @param o The Object to be compared. * @return A negative integer, zero, or a positive integer as this object is less than, equal to, or greater than * the specified object. * * @throws NullPointerException if {@code o} is {@code null}. * @throws ClassCastException if the specified object's type prevents it from being compared to this Object. */ public int compareTo( final Object o ) { if ( o == null ) { throw new NullPointerException( "o" ); } if ( !( o instanceof Textschluessel ) ) { throw new ClassCastException( o.getClass().getName() ); } int result = 0; final Textschluessel that = (Textschluessel) o; if ( !this.equals( that ) ) { result = this.key == that.key ? 0 : this.key > that.key ? 1 : -1; if ( result == 0 && this.extension != that.extension ) { result = this.extension > that.extension ? 1 : -1; } } return result; } /** * Takes care of initializing the {@code validFromMillis} and {@code validToMillis} fields when constructed from an * <1.11 object stream. * * @throws ObjectStreamException if resolution fails. */ private Object readResolve() throws ObjectStreamException { if ( this.validFrom != null ) { this.validFromMillis = this.validFrom.getTime(); } if ( this.validTo != null ) { this.validToMillis = this.validTo.getTime(); } return this; } /** * Creates and returns a copy of this object. * * @return A clone of this instance. */ public Object clone() { try { return super.clone(); } catch ( final CloneNotSupportedException e ) { throw new AssertionError( e ); } } /** * Indicates whether some other object is equal to this one by comparing the values of all properties. *

The extension will only be compared if it is part of the identifying key based on the value of property * {@code variable}.

* * @param o The reference object with which to compare. * * @return {@code true} if this object is the same as {@code o}; {@code false} otherwise. */ public boolean equals( final Object o ) { boolean ret = o == this; if ( !ret && o instanceof Textschluessel ) { final Textschluessel that = (Textschluessel) o; if ( this.isVariable() ) { ret = that.isVariable() && this.key == that.getKey(); } else { ret = !that.isVariable() && this.key == that.getKey() && this.extension == that.getExtension(); } } return ret; } /** * Returns a hash code value for this object. * * @return A hash code value for this object. */ public int hashCode() { if ( this.hashCode == NO_HASHCODE ) { int hc = 23; hc = 37 * hc + ( this.variable ? 0 : 1 ); hc = 37 * hc + this.key; hc = 37 * hc + this.extension; this.hashCode = hc; } return this.hashCode; } /** * Returns a string representation of the object. * * @return A string representation of the object. */ public String toString() { return super.toString() + this.internalString(); } /** * Creates a string representing the properties of the instance. * * @return A string representing the properties of the instance. */ private String internalString() { return new StringBuffer( 200 ).append( '{' ). append( "key=" ).append( this.key ). append( ", extension=" ).append( this.extension ). append( ", validFrom=" ).append( this.validFrom ). append( ", validTo=" ).append( this.validTo ). append( ", debit=" ).append( this.debit ). append( ", remittance=" ).append( this.remittance ). append( ", variable=" ).append( this.variable ). append( ", shortDescription=" ). append( this.getShortDescription( null ) ). append( '}' ).toString(); } //--Dependencies------------------------------------------------------------ // //GEN-BEGIN:jdtausDependencies // This section is managed by jdtaus-container-mojo. /** * Gets the configured Locale implementation. * * @return The configured Locale implementation. */ private Locale getLocale() { return (Locale) ContainerFactory.getContainer(). getDependency( this, "Locale" ); } // //GEN-END:jdtausDependencies //------------------------------------------------------------Dependencies-- //--Messages---------------------------------------------------------------- // //GEN-BEGIN:jdtausMessages // This section is managed by jdtaus-container-mojo. /** * Gets the text of message textschluesselDescription. *
{0,number,00}{1,number,000}
*
{0,number,00}{1,number,000}
* * @param locale The locale of the message instance to return. * @param k format parameter. * @param e format parameter. * * @return the text of message textschluesselDescription. */ private String getTextschluesselDescriptionMessage( final Locale locale, final java.lang.Number k, final java.lang.Number e ) { return ContainerFactory.getContainer(). getMessage( this, "textschluesselDescription", locale, new Object[] { k, e }); } //
//GEN-END:jdtausMessages //----------------------------------------------------------------Messages-- //--Properties-------------------------------------------------------------- // //GEN-BEGIN:jdtausProperties // This section is managed by jdtaus-container-mojo. /** * Gets the value of property defaultLanguage. * * @return Default language of descriptions when there is no description available for a requested language. */ private java.lang.String getDefaultLanguage() { return (java.lang.String) ContainerFactory.getContainer(). getProperty( this, "defaultLanguage" ); } // //GEN-END:jdtausProperties //--------------------------------------------------------------Properties-- }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy