1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package net.sf.plausj.bank.german.strategy;
18
19 import net.sf.plausj.bank.german.AccountCode;
20 import net.sf.plausj.bank.german.BankCode;
21 import net.sf.plausj.bank.german.CheckDigit;
22
23 /**
24 * @author ninan
25 *
26 */
27 public class Strategy25 implements Strategy {
28
29 private static final int[] multiplicators = new int[] { 0, 9, 8, 7, 6, 5,
30 4, 3, 2 };
31
32 /**
33 * @see net.sf.plausj.bank.german.strategy.Strategy#calculateCheckDigit(net.sf.plausj.bank.german.BankCode,
34 * net.sf.plausj.bank.german.AccountCode)
35 */
36 public CheckDigit calculateCheckDigit(final BankCode bankCode,
37 final AccountCode accountCode) {
38
39 int sum = 0;
40 for (int i = AccountCode.ACCOUNT_CODE_MAX_LENGTH - 2; i >= 0; --i) {
41 sum += accountCode.getDigitAtPos(i) * multiplicators[i];
42 }
43
44 int mod = sum % 11;
45
46 if (mod == 1 && accountCode.getDigitAtPos(1) >= 0
47 && accountCode.getDigitAtPos(1) <= 7) {
48 return new CheckDigit(CheckDigit.ALWAYS_INVALID, 0);
49 } else if (mod == 1) {
50 return new CheckDigit(9, 0);
51 }
52
53 int cd = 11 - mod;
54
55 return new CheckDigit(9, cd);
56 }
57
58 }