1 | // SECTION-START[License Header] |
2 | // <editor-fold defaultstate="collapsed" desc=" Generated License "> |
3 | /* |
4 | * jDTAUS ⁑ ISO-13616 |
5 | * Copyright (C) Christian Schulte, 2013-222 |
6 | * |
7 | * Permission to use, copy, modify, and/or distribute this software for any |
8 | * purpose with or without fee is hereby granted, provided that the above |
9 | * copyright notice and this permission notice appear in all copies. |
10 | * |
11 | * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
12 | * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
13 | * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
14 | * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
15 | * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
16 | * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
17 | * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
18 | * |
19 | * $JDTAUS: IbanCheckDigitsException.java 8843 2013-11-28 10:47:34Z schulte $ |
20 | * |
21 | */ |
22 | // </editor-fold> |
23 | // SECTION-END |
24 | package org.jdtaus.iso13616; |
25 | |
26 | import java.util.Locale; |
27 | |
28 | // SECTION-START[Documentation] |
29 | // <editor-fold defaultstate="collapsed" desc=" Generated Documentation "> |
30 | /** |
31 | * Gets thrown whenever validation of the check digits of an international bank account number fails. |
32 | * |
33 | * <dl> |
34 | * <dt><b>Identifier:</b></dt><dd>jDTAUS ⁑ ISO-13616 ⁑ IBAN Check Digits Exception</dd> |
35 | * <dt><b>Name:</b></dt><dd>jDTAUS ⁑ ISO-13616 ⁑ IBAN Check Digits Exception</dd> |
36 | * <dt><b>Abstract:</b></dt><dd>No</dd> |
37 | * <dt><b>Final:</b></dt><dd>Yes</dd> |
38 | * <dt><b>Stateless:</b></dt><dd>No</dd> |
39 | * </dl> |
40 | * |
41 | * @author <a href="mailto:cs@schulte.it">Christian Schulte</a> |
42 | * @version 1.1 |
43 | */ |
44 | // </editor-fold> |
45 | // SECTION-END |
46 | // SECTION-START[Annotations] |
47 | // <editor-fold defaultstate="collapsed" desc=" Generated Annotations "> |
48 | @javax.annotation.Generated( value = "org.jomc.tools.SourceFileProcessor 1.5", comments = "See http://www.jomc.org/jomc/1.5/jomc-tools-1.5" ) |
49 | // </editor-fold> |
50 | // SECTION-END |
51 | public class IbanCheckDigitsException extends Exception |
52 | { |
53 | // SECTION-START[IbanCheckDigitsException] |
54 | |
55 | /** Serial version UID for backwards compatibility with 2007.45.x classes. */ |
56 | private static final long serialVersionUID = 2758511596781778791L; |
57 | |
58 | /** |
59 | * The IBAN failing check digits validation. |
60 | * @serial |
61 | */ |
62 | private String iban; |
63 | |
64 | /** |
65 | * The invalid check digits. |
66 | * @serial |
67 | */ |
68 | private Number checkDigits; |
69 | |
70 | /** |
71 | * Creates a new {@code IbanCheckDigitsException} instance taking the IBAN failing check digits validation and the |
72 | * invalid check digits. |
73 | * |
74 | * @param iban The IBAN failing check digits validation. |
75 | * @param checkDigits The invalid check digits. |
76 | */ |
77 | public IbanCheckDigitsException( final String iban, final Number checkDigits ) |
78 | { |
79 | super(); |
80 | this.iban = iban; |
81 | this.checkDigits = checkDigits; |
82 | } |
83 | |
84 | /** |
85 | * Gets a message describing the exception. |
86 | * |
87 | * @return A message describing the exception. |
88 | */ |
89 | @Override |
90 | public String getMessage() |
91 | { |
92 | return getIbanCheckDigitsExceptionMessage( Locale.getDefault(), this.getIban(), this.getCheckDigits() ); |
93 | } |
94 | |
95 | /** |
96 | * Gets a localized message describing the exception for a given locale. |
97 | * |
98 | * @param locale The locale of the localized message to get. |
99 | * |
100 | * @return A localized message describing the exception. |
101 | * |
102 | * @throws NullPointerException if {@code locale} is {@code null}. |
103 | */ |
104 | public String getLocalizedMessage( final Locale locale ) |
105 | { |
106 | if ( locale == null ) |
107 | { |
108 | throw new NullPointerException( "locale" ); |
109 | } |
110 | |
111 | return getIbanCheckDigitsExceptionMessage( locale, this.getIban(), this.getCheckDigits() ); |
112 | } |
113 | |
114 | /** |
115 | * Gets the IBAN failing check digits validation. |
116 | * |
117 | * @return The IBAN failing check digits validation. |
118 | */ |
119 | public String getIban() |
120 | { |
121 | return this.iban; |
122 | } |
123 | |
124 | /** |
125 | * Gets the invalid check digits. |
126 | * |
127 | * @return The invalid check digits. |
128 | */ |
129 | public Number getCheckDigits() |
130 | { |
131 | return this.checkDigits; |
132 | } |
133 | |
134 | // SECTION-END |
135 | // SECTION-START[Dependencies] |
136 | // SECTION-END |
137 | // SECTION-START[Properties] |
138 | // SECTION-END |
139 | // SECTION-START[Messages] |
140 | // <editor-fold defaultstate="collapsed" desc=" Generated Messages "> |
141 | /** |
142 | * Gets the text of the {@code <IBAN Check Digits Exception Message>} message. |
143 | * <p><dl> |
144 | * <dt><b>Languages:</b></dt> |
145 | * <dd>English (default)</dd> |
146 | * <dd>Deutsch</dd> |
147 | * <dt><b>Final:</b></dt><dd>No</dd> |
148 | * </dl></p> |
149 | * @param locale The locale of the message to return. |
150 | * @param iban Format argument. |
151 | * @param illegalCheckDigits Format argument. |
152 | * @return The text of the {@code <IBAN Check Digits Exception Message>} message for {@code locale}. |
153 | */ |
154 | @SuppressWarnings("unused") |
155 | @javax.annotation.Generated( value = "org.jomc.tools.SourceFileProcessor 1.5", comments = "See http://www.jomc.org/jomc/1.5/jomc-tools-1.5" ) |
156 | private static String getIbanCheckDigitsExceptionMessage( final java.util.Locale locale, final java.lang.String iban, final java.lang.Number illegalCheckDigits ) |
157 | { |
158 | java.io.BufferedReader reader = null; |
159 | |
160 | try |
161 | { |
162 | final String message = java.text.MessageFormat.format( java.util.ResourceBundle.getBundle( "org.jdtaus.iso13616.IbanCheckDigitsException", locale ).getString( "IBAN Check Digits Exception Message" ), iban, illegalCheckDigits, (Object) null ); |
163 | final java.lang.StringBuilder builder = new java.lang.StringBuilder( message.length() ); |
164 | reader = new java.io.BufferedReader( new java.io.StringReader( message ) ); |
165 | final String lineSeparator = System.getProperty( "line.separator", "\n" ); |
166 | |
167 | String line; |
168 | while ( ( line = reader.readLine() ) != null ) |
169 | { |
170 | builder.append( lineSeparator ).append( line ); |
171 | } |
172 | |
173 | reader.close(); |
174 | reader = null; |
175 | return builder.length() > 0 ? builder.substring( lineSeparator.length() ) : ""; |
176 | } |
177 | catch( final java.io.IOException e ) |
178 | { |
179 | throw new java.lang.AssertionError( e ); |
180 | } |
181 | finally |
182 | { |
183 | try |
184 | { |
185 | if( reader != null ) |
186 | { |
187 | reader.close(); |
188 | } |
189 | } |
190 | catch( final java.io.IOException e ) |
191 | { |
192 | throw new java.lang.AssertionError( e ); |
193 | } |
194 | } |
195 | } |
196 | // </editor-fold> |
197 | // SECTION-END |
198 | } |