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 Strategy56 implements Strategy {
28
29 private static final int[] multiplicators = new int[] { 4, 3, 2, 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 int cd = 0;
46 if (9 == accountCode.getDigitAtPos(0) && mod < 2) {
47 if (0 == mod) {
48 cd = 8;
49 } else if (1 == mod) {
50 cd = 7;
51 }
52 } else {
53 cd = 11 - mod;
54 }
55
56 return new CheckDigit(9, cd);
57 }
58
59 }