1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 package org.waarp.common.crypto;
21
22 import org.waarp.common.exception.CryptoException;
23 import org.waarp.common.logging.SysErrLogger;
24
25 import javax.crypto.Cipher;
26 import javax.crypto.Mac;
27 import java.io.File;
28 import java.io.IOException;
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49 public class HmacSha256 extends KeyObject {
50 private static final String ERROR = "Error: ";
51 private static final String CANNOT_BE_USED_FOR_HMAC_SHA256 =
52 "Cannot be used for HmacSha256";
53 private static final int KEY_SIZE = 128;
54 private static final String ALGO = "HmacSHA256";
55 private static final String INSTANCE = ALGO;
56 public static final String EXTENSION = "hs2";
57
58 @Override
59 public final String getAlgorithm() {
60 return ALGO;
61 }
62
63 @Override
64 public final String getInstance() {
65 return INSTANCE;
66 }
67
68 @Override
69 public final int getKeySize() {
70 return KEY_SIZE;
71 }
72
73 @Override
74 public final String getFileExtension() {
75 return EXTENSION;
76 }
77
78 @Override
79 public final Cipher toCrypt() {
80 throw new IllegalArgumentException(CANNOT_BE_USED_FOR_HMAC_SHA256);
81 }
82
83 @Override
84 public final byte[] crypt(final byte[] plaintext) throws Exception {
85 final Mac mac = Mac.getInstance(ALGO);
86 mac.init(secretKey);
87 return mac.doFinal(plaintext);
88 }
89
90 @Override
91 public final Cipher toDecrypt() {
92 throw new IllegalArgumentException(CANNOT_BE_USED_FOR_HMAC_SHA256);
93 }
94
95 @Override
96 public final byte[] decrypt(final byte[] ciphertext) throws Exception {
97 throw new IllegalArgumentException(CANNOT_BE_USED_FOR_HMAC_SHA256);
98 }
99
100
101
102
103
104
105 public static void main(final String[] args) {
106 if (args.length == 0) {
107 SysErrLogger.FAKE_LOGGER.syserr("Filename is needed as argument");
108 }
109 final HmacSha256 key = new HmacSha256();
110 try {
111 key.generateKey();
112 } catch (final Exception e) {
113 SysErrLogger.FAKE_LOGGER.syserr(ERROR + e.getMessage());
114 return;
115 }
116 try {
117 key.saveSecretKey(new File(args[0]));
118 } catch (final CryptoException e) {
119 SysErrLogger.FAKE_LOGGER.syserr(ERROR + e.getMessage());
120 return;
121 } catch (final IOException e) {
122 SysErrLogger.FAKE_LOGGER.syserr(ERROR + e.getMessage());
123 return;
124 }
125 SysErrLogger.FAKE_LOGGER.sysout(
126 "New HmacSha256 key file is generated: " + args[0]);
127 }
128 }