1 /*
2 * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 */
23
24 /*
25 * @test
26 * @bug 8014618
27 * @summary Need to strip leading zeros in TlsPremasterSecret of DHKeyAgreement
28 * @library ..
29 * @author Pasi Eronen
30 * @modules jdk.crypto.token
31 * @run main/othervm TestLeadingZeroesP11
32 * @run main/othervm TestLeadingZeroesP11 sm
33 */
34
35
36 import java.security.KeyFactory;
37 import java.security.PrivateKey;
38 import java.security.Provider;
39 import java.security.PublicKey;
40 import java.security.spec.PKCS8EncodedKeySpec;
41 import java.security.spec.X509EncodedKeySpec;
42 import javax.crypto.KeyAgreement;
43
44 /**
45 * Test that leading zeroes are stripped in TlsPremasterSecret case,
46 * but are left as-is in other cases.
47 *
48 * We use pre-generated keypairs, since with randomly generated keypairs,
49 * a leading zero happens only (roughly) 1 out of 256 cases.
50 */
51
52 public class TestLeadingZeroesP11 extends PKCS11Test {
53
54 public static void main(String[] args) throws Exception {
55 main(new TestLeadingZeroesP11(), args);
56 }
57
58 @Override
59 public void main(Provider p) throws Exception {
60
61 // decode pre-generated keypairs
62 KeyFactory kfac = KeyFactory.getInstance("DH", p);
63 PublicKey alicePubKey =
64 kfac.generatePublic(new X509EncodedKeySpec(alicePubKeyEnc));
65 PublicKey bobPubKey =
66 kfac.generatePublic(new X509EncodedKeySpec(bobPubKeyEnc));
67 PrivateKey alicePrivKey =
68 kfac.generatePrivate(new PKCS8EncodedKeySpec(alicePrivKeyEnc));
69 PrivateKey bobPrivKey =
70 kfac.generatePrivate(new PKCS8EncodedKeySpec(bobPrivKeyEnc));
71
72 // generate normal shared secret
73 KeyAgreement aliceKeyAgree = KeyAgreement.getInstance("DH", p);
74 aliceKeyAgree.init(alicePrivKey);
75 aliceKeyAgree.doPhase(bobPubKey, true);
76 byte[] sharedSecret = aliceKeyAgree.generateSecret();
77 System.out.println("shared secret:\n" + toHexString(sharedSecret));
78
79 // verify that leading zero is present
80 if (sharedSecret.length != 128) {
81 throw new Exception("Unexpected shared secret length");
82 }
83 if (sharedSecret[0] != 0) {
84 throw new Exception("First byte is not zero as expected");
85 }
86
87 // now, test TLS premaster secret
88 aliceKeyAgree.init(alicePrivKey);
89 aliceKeyAgree.doPhase(bobPubKey, true);
90 byte[] tlsPremasterSecret =
91 aliceKeyAgree.generateSecret("TlsPremasterSecret").getEncoded();
92 System.out.println(
93 "tls premaster secret:\n" + toHexString(tlsPremasterSecret));
94
95 // check that leading zero has been stripped
96 if (tlsPremasterSecret.length != 127) {
97 throw new Exception("Unexpected TLS premaster secret length");
98 }
99 if (tlsPremasterSecret[0] == 0) {
100 throw new Exception("First byte is zero");
101 }
102 for (int i = 0; i < tlsPremasterSecret.length; i++) {
103 if (tlsPremasterSecret[i] != sharedSecret[i+1]) {
104 throw new Exception("Shared secrets differ");
105 }
106 }
107
108 }
109
110 /*
111 * Converts a byte to hex digit and writes to the supplied buffer
112 */
113 private void byte2hex(byte b, StringBuffer buf) {
114 char[] hexChars = { '0', '1', '2', '3', '4', '5', '6', '7', '8',
115 '9', 'A', 'B', 'C', 'D', 'E', 'F' };
116 int high = ((b & 0xf0) >> 4);
117 int low = (b & 0x0f);
118 buf.append(hexChars[high]);
119 buf.append(hexChars[low]);
120 }
121
122 /*
123 * Converts a byte array to hex string
124 */
125 private String toHexString(byte[] block) {
126 StringBuffer buf = new StringBuffer();
127
128 int len = block.length;
129
130 for (int i = 0; i < len; i++) {
131 byte2hex(block[i], buf);
132 if (i < len-1) {
133 buf.append(":");
134 }
135 }
136 return buf.toString();
137 }
138
139 private static final byte alicePubKeyEnc[] = {
140 (byte)0x30, (byte)0x82, (byte)0x01, (byte)0x24,
141 (byte)0x30, (byte)0x81, (byte)0x99, (byte)0x06,
142 (byte)0x09, (byte)0x2A, (byte)0x86, (byte)0x48,
143 (byte)0x86, (byte)0xF7, (byte)0x0D, (byte)0x01,
144 (byte)0x03, (byte)0x01, (byte)0x30, (byte)0x81,
145 (byte)0x8B, (byte)0x02, (byte)0x81, (byte)0x81,
146 (byte)0x00, (byte)0xF4, (byte)0x88, (byte)0xFD,
147 (byte)0x58, (byte)0x4E, (byte)0x49, (byte)0xDB,
148 (byte)0xCD, (byte)0x20, (byte)0xB4, (byte)0x9D,
149 (byte)0xE4, (byte)0x91, (byte)0x07, (byte)0x36,
150 (byte)0x6B, (byte)0x33, (byte)0x6C, (byte)0x38,
151 (byte)0x0D, (byte)0x45, (byte)0x1D, (byte)0x0F,
152 (byte)0x7C, (byte)0x88, (byte)0xB3, (byte)0x1C,
153 (byte)0x7C, (byte)0x5B, (byte)0x2D, (byte)0x8E,
154 (byte)0xF6, (byte)0xF3, (byte)0xC9, (byte)0x23,
155 (byte)0xC0, (byte)0x43, (byte)0xF0, (byte)0xA5,
156 (byte)0x5B, (byte)0x18, (byte)0x8D, (byte)0x8E,
157 (byte)0xBB, (byte)0x55, (byte)0x8C, (byte)0xB8,
158 (byte)0x5D, (byte)0x38, (byte)0xD3, (byte)0x34,
159 (byte)0xFD, (byte)0x7C, (byte)0x17, (byte)0x57,
160 (byte)0x43, (byte)0xA3, (byte)0x1D, (byte)0x18,
161 (byte)0x6C, (byte)0xDE, (byte)0x33, (byte)0x21,
162 (byte)0x2C, (byte)0xB5, (byte)0x2A, (byte)0xFF,
163 (byte)0x3C, (byte)0xE1, (byte)0xB1, (byte)0x29,
164 (byte)0x40, (byte)0x18, (byte)0x11, (byte)0x8D,
165 (byte)0x7C, (byte)0x84, (byte)0xA7, (byte)0x0A,
166 (byte)0x72, (byte)0xD6, (byte)0x86, (byte)0xC4,
167 (byte)0x03, (byte)0x19, (byte)0xC8, (byte)0x07,
168 (byte)0x29, (byte)0x7A, (byte)0xCA, (byte)0x95,
169 (byte)0x0C, (byte)0xD9, (byte)0x96, (byte)0x9F,
170 (byte)0xAB, (byte)0xD0, (byte)0x0A, (byte)0x50,
171 (byte)0x9B, (byte)0x02, (byte)0x46, (byte)0xD3,
172 (byte)0x08, (byte)0x3D, (byte)0x66, (byte)0xA4,
173 (byte)0x5D, (byte)0x41, (byte)0x9F, (byte)0x9C,
174 (byte)0x7C, (byte)0xBD, (byte)0x89, (byte)0x4B,
175 (byte)0x22, (byte)0x19, (byte)0x26, (byte)0xBA,
176 (byte)0xAB, (byte)0xA2, (byte)0x5E, (byte)0xC3,
177 (byte)0x55, (byte)0xE9, (byte)0x2F, (byte)0x78,
178 (byte)0xC7, (byte)0x02, (byte)0x01, (byte)0x02,
179 (byte)0x02, (byte)0x02, (byte)0x02, (byte)0x00,
180 (byte)0x03, (byte)0x81, (byte)0x85, (byte)0x00,
181 (byte)0x02, (byte)0x81, (byte)0x81, (byte)0x00,
182 (byte)0xEE, (byte)0xD6, (byte)0xB1, (byte)0xA3,
183 (byte)0xB4, (byte)0x78, (byte)0x2B, (byte)0x35,
184 (byte)0xEF, (byte)0xCD, (byte)0x17, (byte)0x86,
185 (byte)0x63, (byte)0x2B, (byte)0x97, (byte)0x0E,
186 (byte)0x7A, (byte)0xD1, (byte)0xFF, (byte)0x7A,
187 (byte)0xEB, (byte)0x57, (byte)0x61, (byte)0xA1,
188 (byte)0xF7, (byte)0x90, (byte)0x11, (byte)0xA7,
189 (byte)0x79, (byte)0x28, (byte)0x69, (byte)0xBA,
190 (byte)0xA7, (byte)0xB2, (byte)0x37, (byte)0x17,
191 (byte)0xAE, (byte)0x3C, (byte)0x92, (byte)0x89,
192 (byte)0x88, (byte)0xE5, (byte)0x7E, (byte)0x8E,
193 (byte)0xF0, (byte)0x24, (byte)0xD0, (byte)0xE1,
194 (byte)0xC4, (byte)0xB0, (byte)0x26, (byte)0x5A,
195 (byte)0x1E, (byte)0xBD, (byte)0xA0, (byte)0xCF,
196 (byte)0x3E, (byte)0x97, (byte)0x2A, (byte)0x13,
197 (byte)0x92, (byte)0x3B, (byte)0x39, (byte)0xD0,
198 (byte)0x1D, (byte)0xA3, (byte)0x6B, (byte)0x3E,
199 (byte)0xC2, (byte)0xBB, (byte)0x14, (byte)0xB6,
200 (byte)0xE2, (byte)0x4C, (byte)0x0E, (byte)0x5B,
201 (byte)0x4B, (byte)0xA4, (byte)0x9D, (byte)0xA6,
202 (byte)0x21, (byte)0xB0, (byte)0xF9, (byte)0xDE,
203 (byte)0x55, (byte)0xAE, (byte)0x5C, (byte)0x29,
204 (byte)0x0E, (byte)0xC1, (byte)0xFC, (byte)0xBA,
205 (byte)0x51, (byte)0xD3, (byte)0xB6, (byte)0x6D,
206 (byte)0x75, (byte)0x72, (byte)0xDF, (byte)0x43,
207 (byte)0xAB, (byte)0x94, (byte)0x21, (byte)0x6E,
208 (byte)0x0C, (byte)0xD1, (byte)0x93, (byte)0x54,
209 (byte)0x56, (byte)0x7D, (byte)0x4B, (byte)0x90,
210 (byte)0xF1, (byte)0x94, (byte)0x45, (byte)0xD4,
211 (byte)0x2A, (byte)0x71, (byte)0xA1, (byte)0xB8,
212 (byte)0xDD, (byte)0xAA, (byte)0x05, (byte)0xF0,
213 (byte)0x27, (byte)0x37, (byte)0xBD, (byte)0x44
214 };
215
216 private static final byte alicePrivKeyEnc[] = {
217 (byte)0x30, (byte)0x81, (byte)0xE3, (byte)0x02,
218 (byte)0x01, (byte)0x00, (byte)0x30, (byte)0x81,
219 (byte)0x99, (byte)0x06, (byte)0x09, (byte)0x2A,
220 (byte)0x86, (byte)0x48, (byte)0x86, (byte)0xF7,
221 (byte)0x0D, (byte)0x01, (byte)0x03, (byte)0x01,
222 (byte)0x30, (byte)0x81, (byte)0x8B, (byte)0x02,
223 (byte)0x81, (byte)0x81, (byte)0x00, (byte)0xF4,
224 (byte)0x88, (byte)0xFD, (byte)0x58, (byte)0x4E,
225 (byte)0x49, (byte)0xDB, (byte)0xCD, (byte)0x20,
226 (byte)0xB4, (byte)0x9D, (byte)0xE4, (byte)0x91,
227 (byte)0x07, (byte)0x36, (byte)0x6B, (byte)0x33,
228 (byte)0x6C, (byte)0x38, (byte)0x0D, (byte)0x45,
229 (byte)0x1D, (byte)0x0F, (byte)0x7C, (byte)0x88,
230 (byte)0xB3, (byte)0x1C, (byte)0x7C, (byte)0x5B,
231 (byte)0x2D, (byte)0x8E, (byte)0xF6, (byte)0xF3,
232 (byte)0xC9, (byte)0x23, (byte)0xC0, (byte)0x43,
233 (byte)0xF0, (byte)0xA5, (byte)0x5B, (byte)0x18,
234 (byte)0x8D, (byte)0x8E, (byte)0xBB, (byte)0x55,
235 (byte)0x8C, (byte)0xB8, (byte)0x5D, (byte)0x38,
236 (byte)0xD3, (byte)0x34, (byte)0xFD, (byte)0x7C,
237 (byte)0x17, (byte)0x57, (byte)0x43, (byte)0xA3,
238 (byte)0x1D, (byte)0x18, (byte)0x6C, (byte)0xDE,
239 (byte)0x33, (byte)0x21, (byte)0x2C, (byte)0xB5,
240 (byte)0x2A, (byte)0xFF, (byte)0x3C, (byte)0xE1,
241 (byte)0xB1, (byte)0x29, (byte)0x40, (byte)0x18,
242 (byte)0x11, (byte)0x8D, (byte)0x7C, (byte)0x84,
243 (byte)0xA7, (byte)0x0A, (byte)0x72, (byte)0xD6,
244 (byte)0x86, (byte)0xC4, (byte)0x03, (byte)0x19,
245 (byte)0xC8, (byte)0x07, (byte)0x29, (byte)0x7A,
246 (byte)0xCA, (byte)0x95, (byte)0x0C, (byte)0xD9,
247 (byte)0x96, (byte)0x9F, (byte)0xAB, (byte)0xD0,
248 (byte)0x0A, (byte)0x50, (byte)0x9B, (byte)0x02,
249 (byte)0x46, (byte)0xD3, (byte)0x08, (byte)0x3D,
250 (byte)0x66, (byte)0xA4, (byte)0x5D, (byte)0x41,
251 (byte)0x9F, (byte)0x9C, (byte)0x7C, (byte)0xBD,
252 (byte)0x89, (byte)0x4B, (byte)0x22, (byte)0x19,
253 (byte)0x26, (byte)0xBA, (byte)0xAB, (byte)0xA2,
254 (byte)0x5E, (byte)0xC3, (byte)0x55, (byte)0xE9,
255 (byte)0x2F, (byte)0x78, (byte)0xC7, (byte)0x02,
256 (byte)0x01, (byte)0x02, (byte)0x02, (byte)0x02,
257 (byte)0x02, (byte)0x00, (byte)0x04, (byte)0x42,
258 (byte)0x02, (byte)0x40, (byte)0x36, (byte)0x4D,
259 (byte)0xD0, (byte)0x58, (byte)0x64, (byte)0x91,
260 (byte)0x78, (byte)0xA2, (byte)0x4B, (byte)0x79,
261 (byte)0x46, (byte)0xFE, (byte)0xC9, (byte)0xD9,
262 (byte)0xCA, (byte)0x5C, (byte)0xF9, (byte)0xFD,
263 (byte)0x6C, (byte)0x5D, (byte)0x76, (byte)0x3A,
264 (byte)0x41, (byte)0x6D, (byte)0x44, (byte)0x62,
265 (byte)0x75, (byte)0x93, (byte)0x81, (byte)0x93,
266 (byte)0x00, (byte)0x4C, (byte)0xB1, (byte)0xD8,
267 (byte)0x7D, (byte)0x9D, (byte)0xF3, (byte)0x16,
268 (byte)0x2C, (byte)0x6C, (byte)0x9F, (byte)0x7A,
269 (byte)0x84, (byte)0xA3, (byte)0x7A, (byte)0xC1,
270 (byte)0x4F, (byte)0x60, (byte)0xE3, (byte)0xB5,
271 (byte)0x86, (byte)0x28, (byte)0x08, (byte)0x4D,
272 (byte)0x94, (byte)0xB6, (byte)0x04, (byte)0x0D,
273 (byte)0xAC, (byte)0xBD, (byte)0x1F, (byte)0x42,
274 (byte)0x8F, (byte)0x1B
275 };
276
277 private static final byte bobPubKeyEnc[] = {
278 (byte)0x30, (byte)0x82, (byte)0x01, (byte)0x23,
279 (byte)0x30, (byte)0x81, (byte)0x99, (byte)0x06,
280 (byte)0x09, (byte)0x2A, (byte)0x86, (byte)0x48,
281 (byte)0x86, (byte)0xF7, (byte)0x0D, (byte)0x01,
282 (byte)0x03, (byte)0x01, (byte)0x30, (byte)0x81,
283 (byte)0x8B, (byte)0x02, (byte)0x81, (byte)0x81,
284 (byte)0x00, (byte)0xF4, (byte)0x88, (byte)0xFD,
285 (byte)0x58, (byte)0x4E, (byte)0x49, (byte)0xDB,
286 (byte)0xCD, (byte)0x20, (byte)0xB4, (byte)0x9D,
287 (byte)0xE4, (byte)0x91, (byte)0x07, (byte)0x36,
288 (byte)0x6B, (byte)0x33, (byte)0x6C, (byte)0x38,
289 (byte)0x0D, (byte)0x45, (byte)0x1D, (byte)0x0F,
290 (byte)0x7C, (byte)0x88, (byte)0xB3, (byte)0x1C,
291 (byte)0x7C, (byte)0x5B, (byte)0x2D, (byte)0x8E,
292 (byte)0xF6, (byte)0xF3, (byte)0xC9, (byte)0x23,
293 (byte)0xC0, (byte)0x43, (byte)0xF0, (byte)0xA5,
294 (byte)0x5B, (byte)0x18, (byte)0x8D, (byte)0x8E,
295 (byte)0xBB, (byte)0x55, (byte)0x8C, (byte)0xB8,
296 (byte)0x5D, (byte)0x38, (byte)0xD3, (byte)0x34,
297 (byte)0xFD, (byte)0x7C, (byte)0x17, (byte)0x57,
298 (byte)0x43, (byte)0xA3, (byte)0x1D, (byte)0x18,
299 (byte)0x6C, (byte)0xDE, (byte)0x33, (byte)0x21,
300 (byte)0x2C, (byte)0xB5, (byte)0x2A, (byte)0xFF,
301 (byte)0x3C, (byte)0xE1, (byte)0xB1, (byte)0x29,
302 (byte)0x40, (byte)0x18, (byte)0x11, (byte)0x8D,
303 (byte)0x7C, (byte)0x84, (byte)0xA7, (byte)0x0A,
304 (byte)0x72, (byte)0xD6, (byte)0x86, (byte)0xC4,
305 (byte)0x03, (byte)0x19, (byte)0xC8, (byte)0x07,
306 (byte)0x29, (byte)0x7A, (byte)0xCA, (byte)0x95,
307 (byte)0x0C, (byte)0xD9, (byte)0x96, (byte)0x9F,
308 (byte)0xAB, (byte)0xD0, (byte)0x0A, (byte)0x50,
309 (byte)0x9B, (byte)0x02, (byte)0x46, (byte)0xD3,
310 (byte)0x08, (byte)0x3D, (byte)0x66, (byte)0xA4,
311 (byte)0x5D, (byte)0x41, (byte)0x9F, (byte)0x9C,
312 (byte)0x7C, (byte)0xBD, (byte)0x89, (byte)0x4B,
313 (byte)0x22, (byte)0x19, (byte)0x26, (byte)0xBA,
314 (byte)0xAB, (byte)0xA2, (byte)0x5E, (byte)0xC3,
315 (byte)0x55, (byte)0xE9, (byte)0x2F, (byte)0x78,
316 (byte)0xC7, (byte)0x02, (byte)0x01, (byte)0x02,
317 (byte)0x02, (byte)0x02, (byte)0x02, (byte)0x00,
318 (byte)0x03, (byte)0x81, (byte)0x84, (byte)0x00,
319 (byte)0x02, (byte)0x81, (byte)0x80, (byte)0x2C,
320 (byte)0x40, (byte)0xFA, (byte)0xF6, (byte)0xA6,
321 (byte)0xF8, (byte)0xAC, (byte)0xC2, (byte)0x4F,
322 (byte)0xCD, (byte)0xC7, (byte)0x37, (byte)0x93,
323 (byte)0xE5, (byte)0xE4, (byte)0x5E, (byte)0x18,
324 (byte)0x14, (byte)0xE6, (byte)0x50, (byte)0xDA,
325 (byte)0x55, (byte)0x38, (byte)0x5D, (byte)0x24,
326 (byte)0xF5, (byte)0x42, (byte)0x68, (byte)0x5F,
327 (byte)0xF5, (byte)0x15, (byte)0xC8, (byte)0x9B,
328 (byte)0x5D, (byte)0x06, (byte)0x3D, (byte)0xE1,
329 (byte)0x52, (byte)0x2F, (byte)0x98, (byte)0xFF,
330 (byte)0x37, (byte)0xBB, (byte)0x75, (byte)0x48,
331 (byte)0x48, (byte)0xE9, (byte)0x65, (byte)0x84,
332 (byte)0x37, (byte)0xBB, (byte)0xB3, (byte)0xE9,
333 (byte)0x36, (byte)0x01, (byte)0xB4, (byte)0x6A,
334 (byte)0x1C, (byte)0xB2, (byte)0x11, (byte)0x82,
335 (byte)0xCE, (byte)0x3D, (byte)0x65, (byte)0xE5,
336 (byte)0x3C, (byte)0x89, (byte)0xE9, (byte)0x52,
337 (byte)0x19, (byte)0xBD, (byte)0x58, (byte)0xF6,
338 (byte)0xA2, (byte)0x03, (byte)0xA8, (byte)0xB2,
339 (byte)0xA5, (byte)0xDB, (byte)0xEB, (byte)0xF5,
340 (byte)0x94, (byte)0xF9, (byte)0x46, (byte)0xBE,
341 (byte)0x45, (byte)0x4C, (byte)0x65, (byte)0xD2,
342 (byte)0xD1, (byte)0xCF, (byte)0xFF, (byte)0xFF,
343 (byte)0xFA, (byte)0x38, (byte)0xF1, (byte)0x72,
344 (byte)0xAB, (byte)0xB9, (byte)0x14, (byte)0x4E,
345 (byte)0xF5, (byte)0xF0, (byte)0x7A, (byte)0x8E,
346 (byte)0x45, (byte)0xFD, (byte)0x5B, (byte)0xF9,
347 (byte)0xA2, (byte)0x97, (byte)0x1B, (byte)0xAE,
348 (byte)0x2C, (byte)0x7B, (byte)0x6B, (byte)0x7C,
349 (byte)0x98, (byte)0xFE, (byte)0x58, (byte)0xDD,
350 (byte)0xBE, (byte)0xF6, (byte)0x1C, (byte)0x8E,
351 (byte)0xD0, (byte)0xA1, (byte)0x72
352 };
353
354 private static final byte bobPrivKeyEnc[] = {
355 (byte)0x30, (byte)0x81, (byte)0xE4, (byte)0x02,
356 (byte)0x01, (byte)0x00, (byte)0x30, (byte)0x81,
357 (byte)0x99, (byte)0x06, (byte)0x09, (byte)0x2A,
358 (byte)0x86, (byte)0x48, (byte)0x86, (byte)0xF7,
359 (byte)0x0D, (byte)0x01, (byte)0x03, (byte)0x01,
360 (byte)0x30, (byte)0x81, (byte)0x8B, (byte)0x02,
361 (byte)0x81, (byte)0x81, (byte)0x00, (byte)0xF4,
362 (byte)0x88, (byte)0xFD, (byte)0x58, (byte)0x4E,
363 (byte)0x49, (byte)0xDB, (byte)0xCD, (byte)0x20,
364 (byte)0xB4, (byte)0x9D, (byte)0xE4, (byte)0x91,
365 (byte)0x07, (byte)0x36, (byte)0x6B, (byte)0x33,
366 (byte)0x6C, (byte)0x38, (byte)0x0D, (byte)0x45,
367 (byte)0x1D, (byte)0x0F, (byte)0x7C, (byte)0x88,
368 (byte)0xB3, (byte)0x1C, (byte)0x7C, (byte)0x5B,
369 (byte)0x2D, (byte)0x8E, (byte)0xF6, (byte)0xF3,
370 (byte)0xC9, (byte)0x23, (byte)0xC0, (byte)0x43,
371 (byte)0xF0, (byte)0xA5, (byte)0x5B, (byte)0x18,
372 (byte)0x8D, (byte)0x8E, (byte)0xBB, (byte)0x55,
373 (byte)0x8C, (byte)0xB8, (byte)0x5D, (byte)0x38,
374 (byte)0xD3, (byte)0x34, (byte)0xFD, (byte)0x7C,
375 (byte)0x17, (byte)0x57, (byte)0x43, (byte)0xA3,
376 (byte)0x1D, (byte)0x18, (byte)0x6C, (byte)0xDE,
377 (byte)0x33, (byte)0x21, (byte)0x2C, (byte)0xB5,
378 (byte)0x2A, (byte)0xFF, (byte)0x3C, (byte)0xE1,
379 (byte)0xB1, (byte)0x29, (byte)0x40, (byte)0x18,
380 (byte)0x11, (byte)0x8D, (byte)0x7C, (byte)0x84,
381 (byte)0xA7, (byte)0x0A, (byte)0x72, (byte)0xD6,
382 (byte)0x86, (byte)0xC4, (byte)0x03, (byte)0x19,
383 (byte)0xC8, (byte)0x07, (byte)0x29, (byte)0x7A,
384 (byte)0xCA, (byte)0x95, (byte)0x0C, (byte)0xD9,
385 (byte)0x96, (byte)0x9F, (byte)0xAB, (byte)0xD0,
386 (byte)0x0A, (byte)0x50, (byte)0x9B, (byte)0x02,
387 (byte)0x46, (byte)0xD3, (byte)0x08, (byte)0x3D,
388 (byte)0x66, (byte)0xA4, (byte)0x5D, (byte)0x41,
389 (byte)0x9F, (byte)0x9C, (byte)0x7C, (byte)0xBD,
390 (byte)0x89, (byte)0x4B, (byte)0x22, (byte)0x19,
391 (byte)0x26, (byte)0xBA, (byte)0xAB, (byte)0xA2,
392 (byte)0x5E, (byte)0xC3, (byte)0x55, (byte)0xE9,
393 (byte)0x2F, (byte)0x78, (byte)0xC7, (byte)0x02,
394 (byte)0x01, (byte)0x02, (byte)0x02, (byte)0x02,
395 (byte)0x02, (byte)0x00, (byte)0x04, (byte)0x43,
396 (byte)0x02, (byte)0x41, (byte)0x00, (byte)0xE0,
397 (byte)0x31, (byte)0xE7, (byte)0x77, (byte)0xB8,
398 (byte)0xD0, (byte)0x7E, (byte)0x0A, (byte)0x9B,
399 (byte)0x94, (byte)0xD5, (byte)0x3D, (byte)0x33,
400 (byte)0x62, (byte)0x32, (byte)0x51, (byte)0xCE,
401 (byte)0x74, (byte)0x5C, (byte)0xA5, (byte)0x72,
402 (byte)0xD9, (byte)0x36, (byte)0xF3, (byte)0x8A,
403 (byte)0x3F, (byte)0x8B, (byte)0xC6, (byte)0xFE,
404 (byte)0xEF, (byte)0x94, (byte)0x8B, (byte)0x50,
405 (byte)0x41, (byte)0x9B, (byte)0x14, (byte)0xC8,
406 (byte)0xE9, (byte)0x1F, (byte)0x24, (byte)0x1F,
407 (byte)0x65, (byte)0x8E, (byte)0xD3, (byte)0x85,
408 (byte)0xD0, (byte)0x68, (byte)0x6C, (byte)0xF1,
409 (byte)0x79, (byte)0x45, (byte)0xD0, (byte)0x06,
410 (byte)0xA4, (byte)0xB8, (byte)0xE0, (byte)0x64,
411 (byte)0xF5, (byte)0x38, (byte)0x72, (byte)0x97,
412 (byte)0x00, (byte)0x23, (byte)0x5F
413 };
414 }
415