Class Modulus97CheckDigit

All Implemented Interfaces:
Serializable, CheckDigit, IsoIecConstants
Direct Known Subclasses:
IBANCheckDigit

public class Modulus97CheckDigit extends IsoIec7064PureSystem implements IsoIecConstants
MOD 97-10 module similar to ISO/IEC 7064, MOD 97-10. In difference to the standard this module applies to alphanumeric Strings. Check digits can be from 02 to 98 (00 and 01 are not possible)

See Wikipedia - ISO/IEC_7064 (de) for more details on ISO/IEC 7064, MOD 97-10

This MOD 97-10 module can be used to validate the LEI (Legal Entity Identifier), ICD id 0199

Since:
1.10.0
See Also:
  • Method Details

    • getInstance

      public static CheckDigit getInstance()
      Gets the singleton instance of this validator.
      Returns:
      A singleton instance of the class.
    • getRadix

      protected int getRadix()
      Description copied from class: IsoIec7064PureSystem
      Radix is the second number following “MOD” in the ISO/IEC designation, f.i. 2 for "MOD 11-2"
      Specified by:
      getRadix in class IsoIec7064PureSystem
      Returns:
      the radix of the Check Digit routine
    • getCharacterSet

      protected String getCharacterSet()
      Description copied from class: IsoIec7064PureSystem
      MOD 11-2 check characters are “0” to “9” plus “X” for example.
      Specified by:
      getCharacterSet in class IsoIec7064PureSystem
      Returns:
      a String containing characters the check digit is build from. This can be IsoIecConstants.NUMERIC, IsoIecConstants.ALPHABETIC, IsoIecConstants.ALPHANUMERIC , IsoIecConstants.NUMERIC_PLUS_X, IsoIecConstants.ALPHANUMERIC_PLUS_STAR
    • calculate

      public String calculate(String code) throws CheckDigitException
      Description copied from class: ModulusCheckDigit
      Calculate a modulus Check Digit for a code which does not yet have one.
      Specified by:
      calculate in interface CheckDigit
      Overrides:
      calculate in class IsoIec7064PureSystem
      Parameters:
      code - The code for which to calculate the Check Digit; the check digit should not be included
      Returns:
      The calculated Check Digit
      Throws:
      CheckDigitException - if an error occurs calculating the check digit
    • calculateModulus

      protected int calculateModulus(String code, boolean includesCheckDigit) throws CheckDigitException
      Description copied from class: ModulusCheckDigit
      Calculate the modulus for a code.
      Overrides:
      calculateModulus in class IsoIec7064PureSystem
      Parameters:
      code - The code to calculate the modulus for.
      includesCheckDigit - Whether the code includes the Check Digit or not.
      Returns:
      The modulus value
      Throws:
      CheckDigitException - if an error occurs calculating the modulus for the specified code
    • isValid

      public boolean isValid(String code)
      Description copied from class: ModulusCheckDigit
      Validate a modulus check digit for a code.
      Specified by:
      isValid in interface CheckDigit
      Overrides:
      isValid in class IsoIec7064PureSystem
      Parameters:
      code - The code to validate
      Returns:
      true if the check digit is valid, otherwise false
    • toInt

      protected int toInt(char character, int leftPos, int rightPos) throws CheckDigitException
      Description copied from class: IsoIec7064PureSystem
      Convert a character at a specified position to an integer value.

      Note: this implementation only handlers numeric values For non-numeric characters, override this method to provide character-->integer conversion.

      Overrides to handle numeric, alphabetic or alphanumeric values respectively.

      Overrides:
      toInt in class IsoIec7064PureSystem
      Parameters:
      character - The character to convert
      leftPos - The position of the character in the code, counting from left to right (for identifiying the position in the string)
      rightPos - The position of the character in the code, counting from right to left (not used here)
      Returns:
      The integer value of the character
      Throws:
      CheckDigitException - if character is non-numeric