@protontech/openpgp 6.0.0-alpha.0 → 6.0.0-alpha.1.patch.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/README.md +6 -6
  2. package/dist/lightweight/argon2id.min.mjs +1 -1
  3. package/dist/lightweight/argon2id.min.mjs.map +1 -1
  4. package/dist/lightweight/argon2id.mjs +1 -1
  5. package/dist/lightweight/bn.interface.min.mjs +2 -2
  6. package/dist/lightweight/bn.interface.min.mjs.map +1 -1
  7. package/dist/lightweight/bn.interface.mjs +3460 -2
  8. package/dist/lightweight/interface.min.mjs +1 -1
  9. package/dist/lightweight/interface.min.mjs.map +1 -1
  10. package/dist/lightweight/interface.mjs +1 -1
  11. package/dist/lightweight/legacy_ciphers.min.mjs +3 -0
  12. package/dist/lightweight/legacy_ciphers.min.mjs.map +1 -0
  13. package/dist/lightweight/legacy_ciphers.mjs +1829 -0
  14. package/dist/lightweight/native.interface.min.mjs +1 -1
  15. package/dist/lightweight/native.interface.min.mjs.map +1 -1
  16. package/dist/lightweight/native.interface.mjs +1 -1
  17. package/dist/lightweight/noble_curves.min.mjs +11 -11
  18. package/dist/lightweight/noble_curves.min.mjs.map +1 -1
  19. package/dist/lightweight/noble_curves.mjs +84 -55
  20. package/dist/lightweight/noble_hashes.min.mjs +2 -2
  21. package/dist/lightweight/noble_hashes.min.mjs.map +1 -1
  22. package/dist/lightweight/noble_hashes.mjs +1 -2
  23. package/dist/lightweight/openpgp.min.mjs +2 -2
  24. package/dist/lightweight/openpgp.min.mjs.map +1 -1
  25. package/dist/lightweight/openpgp.mjs +1373 -3341
  26. package/dist/lightweight/sha3.min.mjs +3 -3
  27. package/dist/lightweight/sha3.min.mjs.map +1 -1
  28. package/dist/lightweight/sha3.mjs +51 -37
  29. package/dist/node/openpgp.cjs +7887 -8057
  30. package/dist/node/openpgp.min.cjs +11 -11
  31. package/dist/node/openpgp.min.cjs.map +1 -1
  32. package/dist/node/openpgp.min.mjs +11 -11
  33. package/dist/node/openpgp.min.mjs.map +1 -1
  34. package/dist/node/openpgp.mjs +7886 -8058
  35. package/dist/openpgp.js +7940 -8020
  36. package/dist/openpgp.min.js +11 -11
  37. package/dist/openpgp.min.js.map +1 -1
  38. package/dist/openpgp.min.mjs +11 -11
  39. package/dist/openpgp.min.mjs.map +1 -1
  40. package/dist/openpgp.mjs +7939 -8021
  41. package/openpgp.d.ts +58 -43
  42. package/package.json +32 -34
  43. package/dist/lightweight/bn.min.mjs +0 -3
  44. package/dist/lightweight/bn.min.mjs.map +0 -1
  45. package/dist/lightweight/bn.mjs +0 -3449
@@ -0,0 +1,1829 @@
1
+ /*! OpenPGP.js v6.0.0-alpha.1.patch.0 - 2024-03-01 - this is LGPL licensed code, see LICENSE/our website https://openpgpjs.org/ for more information. */
2
+ const globalThis = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
3
+
4
+ import { enums } from './openpgp.mjs';
5
+
6
+ //Paul Tero, July 2001
7
+ //http://www.tero.co.uk/des/
8
+ //
9
+ //Optimised for performance with large blocks by Michael Hayworth, November 2001
10
+ //http://www.netdealing.com
11
+ //
12
+ // Modified by Recurity Labs GmbH
13
+
14
+ //THIS SOFTWARE IS PROVIDED "AS IS" AND
15
+ //ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16
+ //IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17
+ //ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18
+ //FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19
+ //DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20
+ //OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21
+ //HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22
+ //LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23
+ //OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24
+ //SUCH DAMAGE.
25
+
26
+ //des
27
+ //this takes the key, the message, and whether to encrypt or decrypt
28
+
29
+ function des(keys, message, encrypt, mode, iv, padding) {
30
+ //declaring this locally speeds things up a bit
31
+ const spfunction1 = [
32
+ 0x1010400, 0, 0x10000, 0x1010404, 0x1010004, 0x10404, 0x4, 0x10000, 0x400, 0x1010400,
33
+ 0x1010404, 0x400, 0x1000404, 0x1010004, 0x1000000, 0x4, 0x404, 0x1000400, 0x1000400, 0x10400, 0x10400, 0x1010000,
34
+ 0x1010000, 0x1000404, 0x10004, 0x1000004, 0x1000004, 0x10004, 0, 0x404, 0x10404, 0x1000000, 0x10000, 0x1010404, 0x4,
35
+ 0x1010000, 0x1010400, 0x1000000, 0x1000000, 0x400, 0x1010004, 0x10000, 0x10400, 0x1000004, 0x400, 0x4, 0x1000404,
36
+ 0x10404, 0x1010404, 0x10004, 0x1010000, 0x1000404, 0x1000004, 0x404, 0x10404, 0x1010400, 0x404, 0x1000400,
37
+ 0x1000400, 0, 0x10004, 0x10400, 0, 0x1010004
38
+ ];
39
+ const spfunction2 = [
40
+ -0x7fef7fe0, -0x7fff8000, 0x8000, 0x108020, 0x100000, 0x20, -0x7fefffe0, -0x7fff7fe0,
41
+ -0x7fffffe0, -0x7fef7fe0, -0x7fef8000, -0x80000000, -0x7fff8000, 0x100000, 0x20, -0x7fefffe0, 0x108000, 0x100020,
42
+ -0x7fff7fe0, 0, -0x80000000, 0x8000, 0x108020, -0x7ff00000, 0x100020, -0x7fffffe0, 0, 0x108000, 0x8020, -0x7fef8000,
43
+ -0x7ff00000, 0x8020, 0, 0x108020, -0x7fefffe0, 0x100000, -0x7fff7fe0, -0x7ff00000, -0x7fef8000, 0x8000, -0x7ff00000,
44
+ -0x7fff8000, 0x20, -0x7fef7fe0, 0x108020, 0x20, 0x8000, -0x80000000, 0x8020, -0x7fef8000, 0x100000, -0x7fffffe0,
45
+ 0x100020, -0x7fff7fe0, -0x7fffffe0, 0x100020, 0x108000, 0, -0x7fff8000, 0x8020, -0x80000000, -0x7fefffe0,
46
+ -0x7fef7fe0, 0x108000
47
+ ];
48
+ const spfunction3 = [
49
+ 0x208, 0x8020200, 0, 0x8020008, 0x8000200, 0, 0x20208, 0x8000200, 0x20008, 0x8000008,
50
+ 0x8000008, 0x20000, 0x8020208, 0x20008, 0x8020000, 0x208, 0x8000000, 0x8, 0x8020200, 0x200, 0x20200, 0x8020000,
51
+ 0x8020008, 0x20208, 0x8000208, 0x20200, 0x20000, 0x8000208, 0x8, 0x8020208, 0x200, 0x8000000, 0x8020200, 0x8000000,
52
+ 0x20008, 0x208, 0x20000, 0x8020200, 0x8000200, 0, 0x200, 0x20008, 0x8020208, 0x8000200, 0x8000008, 0x200, 0,
53
+ 0x8020008, 0x8000208, 0x20000, 0x8000000, 0x8020208, 0x8, 0x20208, 0x20200, 0x8000008, 0x8020000, 0x8000208, 0x208,
54
+ 0x8020000, 0x20208, 0x8, 0x8020008, 0x20200
55
+ ];
56
+ const spfunction4 = [
57
+ 0x802001, 0x2081, 0x2081, 0x80, 0x802080, 0x800081, 0x800001, 0x2001, 0, 0x802000,
58
+ 0x802000, 0x802081, 0x81, 0, 0x800080, 0x800001, 0x1, 0x2000, 0x800000, 0x802001, 0x80, 0x800000, 0x2001, 0x2080,
59
+ 0x800081, 0x1, 0x2080, 0x800080, 0x2000, 0x802080, 0x802081, 0x81, 0x800080, 0x800001, 0x802000, 0x802081, 0x81, 0,
60
+ 0, 0x802000, 0x2080, 0x800080, 0x800081, 0x1, 0x802001, 0x2081, 0x2081, 0x80, 0x802081, 0x81, 0x1, 0x2000, 0x800001,
61
+ 0x2001, 0x802080, 0x800081, 0x2001, 0x2080, 0x800000, 0x802001, 0x80, 0x800000, 0x2000, 0x802080
62
+ ];
63
+ const spfunction5 = [
64
+ 0x100, 0x2080100, 0x2080000, 0x42000100, 0x80000, 0x100, 0x40000000, 0x2080000,
65
+ 0x40080100, 0x80000, 0x2000100, 0x40080100, 0x42000100, 0x42080000, 0x80100, 0x40000000, 0x2000000, 0x40080000,
66
+ 0x40080000, 0, 0x40000100, 0x42080100, 0x42080100, 0x2000100, 0x42080000, 0x40000100, 0, 0x42000000, 0x2080100,
67
+ 0x2000000, 0x42000000, 0x80100, 0x80000, 0x42000100, 0x100, 0x2000000, 0x40000000, 0x2080000, 0x42000100,
68
+ 0x40080100, 0x2000100, 0x40000000, 0x42080000, 0x2080100, 0x40080100, 0x100, 0x2000000, 0x42080000, 0x42080100,
69
+ 0x80100, 0x42000000, 0x42080100, 0x2080000, 0, 0x40080000, 0x42000000, 0x80100, 0x2000100, 0x40000100, 0x80000, 0,
70
+ 0x40080000, 0x2080100, 0x40000100
71
+ ];
72
+ const spfunction6 = [
73
+ 0x20000010, 0x20400000, 0x4000, 0x20404010, 0x20400000, 0x10, 0x20404010, 0x400000,
74
+ 0x20004000, 0x404010, 0x400000, 0x20000010, 0x400010, 0x20004000, 0x20000000, 0x4010, 0, 0x400010, 0x20004010,
75
+ 0x4000, 0x404000, 0x20004010, 0x10, 0x20400010, 0x20400010, 0, 0x404010, 0x20404000, 0x4010, 0x404000, 0x20404000,
76
+ 0x20000000, 0x20004000, 0x10, 0x20400010, 0x404000, 0x20404010, 0x400000, 0x4010, 0x20000010, 0x400000, 0x20004000,
77
+ 0x20000000, 0x4010, 0x20000010, 0x20404010, 0x404000, 0x20400000, 0x404010, 0x20404000, 0, 0x20400010, 0x10, 0x4000,
78
+ 0x20400000, 0x404010, 0x4000, 0x400010, 0x20004010, 0, 0x20404000, 0x20000000, 0x400010, 0x20004010
79
+ ];
80
+ const spfunction7 = [
81
+ 0x200000, 0x4200002, 0x4000802, 0, 0x800, 0x4000802, 0x200802, 0x4200800, 0x4200802,
82
+ 0x200000, 0, 0x4000002, 0x2, 0x4000000, 0x4200002, 0x802, 0x4000800, 0x200802, 0x200002, 0x4000800, 0x4000002,
83
+ 0x4200000, 0x4200800, 0x200002, 0x4200000, 0x800, 0x802, 0x4200802, 0x200800, 0x2, 0x4000000, 0x200800, 0x4000000,
84
+ 0x200800, 0x200000, 0x4000802, 0x4000802, 0x4200002, 0x4200002, 0x2, 0x200002, 0x4000000, 0x4000800, 0x200000,
85
+ 0x4200800, 0x802, 0x200802, 0x4200800, 0x802, 0x4000002, 0x4200802, 0x4200000, 0x200800, 0, 0x2, 0x4200802, 0,
86
+ 0x200802, 0x4200000, 0x800, 0x4000002, 0x4000800, 0x800, 0x200002
87
+ ];
88
+ const spfunction8 = [
89
+ 0x10001040, 0x1000, 0x40000, 0x10041040, 0x10000000, 0x10001040, 0x40, 0x10000000,
90
+ 0x40040, 0x10040000, 0x10041040, 0x41000, 0x10041000, 0x41040, 0x1000, 0x40, 0x10040000, 0x10000040, 0x10001000,
91
+ 0x1040, 0x41000, 0x40040, 0x10040040, 0x10041000, 0x1040, 0, 0, 0x10040040, 0x10000040, 0x10001000, 0x41040,
92
+ 0x40000, 0x41040, 0x40000, 0x10041000, 0x1000, 0x40, 0x10040040, 0x1000, 0x41040, 0x10001000, 0x40, 0x10000040,
93
+ 0x10040000, 0x10040040, 0x10000000, 0x40000, 0x10001040, 0, 0x10041040, 0x40040, 0x10000040, 0x10040000, 0x10001000,
94
+ 0x10001040, 0, 0x10041040, 0x41000, 0x41000, 0x1040, 0x1040, 0x40040, 0x10000000, 0x10041000
95
+ ];
96
+
97
+ //create the 16 or 48 subkeys we will need
98
+ let m = 0;
99
+ let i;
100
+ let j;
101
+ let temp;
102
+ let right1;
103
+ let right2;
104
+ let left;
105
+ let right;
106
+ let looping;
107
+ let cbcleft;
108
+ let cbcleft2;
109
+ let cbcright;
110
+ let cbcright2;
111
+ let endloop;
112
+ let loopinc;
113
+ let len = message.length;
114
+
115
+ //set up the loops for single and triple des
116
+ const iterations = keys.length === 32 ? 3 : 9; //single or triple des
117
+ if (iterations === 3) {
118
+ looping = encrypt ? [0, 32, 2] : [30, -2, -2];
119
+ } else {
120
+ looping = encrypt ? [0, 32, 2, 62, 30, -2, 64, 96, 2] : [94, 62, -2, 32, 64, 2, 30, -2, -2];
121
+ }
122
+
123
+ //pad the message depending on the padding parameter
124
+ //only add padding if encrypting - note that you need to use the same padding option for both encrypt and decrypt
125
+ if (encrypt) {
126
+ message = desAddPadding(message, padding);
127
+ len = message.length;
128
+ }
129
+
130
+ //store the result here
131
+ let result = new Uint8Array(len);
132
+ let k = 0;
133
+
134
+ if (mode === 1) { //CBC mode
135
+ cbcleft = (iv[m++] << 24) | (iv[m++] << 16) | (iv[m++] << 8) | iv[m++];
136
+ cbcright = (iv[m++] << 24) | (iv[m++] << 16) | (iv[m++] << 8) | iv[m++];
137
+ m = 0;
138
+ }
139
+
140
+ //loop through each 64 bit chunk of the message
141
+ while (m < len) {
142
+ left = (message[m++] << 24) | (message[m++] << 16) | (message[m++] << 8) | message[m++];
143
+ right = (message[m++] << 24) | (message[m++] << 16) | (message[m++] << 8) | message[m++];
144
+
145
+ //for Cipher Block Chaining mode, xor the message with the previous result
146
+ if (mode === 1) {
147
+ if (encrypt) {
148
+ left ^= cbcleft;
149
+ right ^= cbcright;
150
+ } else {
151
+ cbcleft2 = cbcleft;
152
+ cbcright2 = cbcright;
153
+ cbcleft = left;
154
+ cbcright = right;
155
+ }
156
+ }
157
+
158
+ //first each 64 but chunk of the message must be permuted according to IP
159
+ temp = ((left >>> 4) ^ right) & 0x0f0f0f0f;
160
+ right ^= temp;
161
+ left ^= (temp << 4);
162
+ temp = ((left >>> 16) ^ right) & 0x0000ffff;
163
+ right ^= temp;
164
+ left ^= (temp << 16);
165
+ temp = ((right >>> 2) ^ left) & 0x33333333;
166
+ left ^= temp;
167
+ right ^= (temp << 2);
168
+ temp = ((right >>> 8) ^ left) & 0x00ff00ff;
169
+ left ^= temp;
170
+ right ^= (temp << 8);
171
+ temp = ((left >>> 1) ^ right) & 0x55555555;
172
+ right ^= temp;
173
+ left ^= (temp << 1);
174
+
175
+ left = ((left << 1) | (left >>> 31));
176
+ right = ((right << 1) | (right >>> 31));
177
+
178
+ //do this either 1 or 3 times for each chunk of the message
179
+ for (j = 0; j < iterations; j += 3) {
180
+ endloop = looping[j + 1];
181
+ loopinc = looping[j + 2];
182
+ //now go through and perform the encryption or decryption
183
+ for (i = looping[j]; i !== endloop; i += loopinc) { //for efficiency
184
+ right1 = right ^ keys[i];
185
+ right2 = ((right >>> 4) | (right << 28)) ^ keys[i + 1];
186
+ //the result is attained by passing these bytes through the S selection functions
187
+ temp = left;
188
+ left = right;
189
+ right = temp ^ (spfunction2[(right1 >>> 24) & 0x3f] | spfunction4[(right1 >>> 16) & 0x3f] | spfunction6[(right1 >>>
190
+ 8) & 0x3f] | spfunction8[right1 & 0x3f] | spfunction1[(right2 >>> 24) & 0x3f] | spfunction3[(right2 >>> 16) &
191
+ 0x3f] | spfunction5[(right2 >>> 8) & 0x3f] | spfunction7[right2 & 0x3f]);
192
+ }
193
+ temp = left;
194
+ left = right;
195
+ right = temp; //unreverse left and right
196
+ } //for either 1 or 3 iterations
197
+
198
+ //move then each one bit to the right
199
+ left = ((left >>> 1) | (left << 31));
200
+ right = ((right >>> 1) | (right << 31));
201
+
202
+ //now perform IP-1, which is IP in the opposite direction
203
+ temp = ((left >>> 1) ^ right) & 0x55555555;
204
+ right ^= temp;
205
+ left ^= (temp << 1);
206
+ temp = ((right >>> 8) ^ left) & 0x00ff00ff;
207
+ left ^= temp;
208
+ right ^= (temp << 8);
209
+ temp = ((right >>> 2) ^ left) & 0x33333333;
210
+ left ^= temp;
211
+ right ^= (temp << 2);
212
+ temp = ((left >>> 16) ^ right) & 0x0000ffff;
213
+ right ^= temp;
214
+ left ^= (temp << 16);
215
+ temp = ((left >>> 4) ^ right) & 0x0f0f0f0f;
216
+ right ^= temp;
217
+ left ^= (temp << 4);
218
+
219
+ //for Cipher Block Chaining mode, xor the message with the previous result
220
+ if (mode === 1) {
221
+ if (encrypt) {
222
+ cbcleft = left;
223
+ cbcright = right;
224
+ } else {
225
+ left ^= cbcleft2;
226
+ right ^= cbcright2;
227
+ }
228
+ }
229
+
230
+ result[k++] = (left >>> 24);
231
+ result[k++] = ((left >>> 16) & 0xff);
232
+ result[k++] = ((left >>> 8) & 0xff);
233
+ result[k++] = (left & 0xff);
234
+ result[k++] = (right >>> 24);
235
+ result[k++] = ((right >>> 16) & 0xff);
236
+ result[k++] = ((right >>> 8) & 0xff);
237
+ result[k++] = (right & 0xff);
238
+ } //for every 8 characters, or 64 bits in the message
239
+
240
+ //only remove padding if decrypting - note that you need to use the same padding option for both encrypt and decrypt
241
+ if (!encrypt) {
242
+ result = desRemovePadding(result, padding);
243
+ }
244
+
245
+ return result;
246
+ } //end of des
247
+
248
+
249
+ //desCreateKeys
250
+ //this takes as input a 64 bit key (even though only 56 bits are used)
251
+ //as an array of 2 integers, and returns 16 48 bit keys
252
+
253
+ function desCreateKeys(key) {
254
+ //declaring this locally speeds things up a bit
255
+ const pc2bytes0 = [
256
+ 0, 0x4, 0x20000000, 0x20000004, 0x10000, 0x10004, 0x20010000, 0x20010004, 0x200, 0x204,
257
+ 0x20000200, 0x20000204, 0x10200, 0x10204, 0x20010200, 0x20010204
258
+ ];
259
+ const pc2bytes1 = [
260
+ 0, 0x1, 0x100000, 0x100001, 0x4000000, 0x4000001, 0x4100000, 0x4100001, 0x100, 0x101, 0x100100,
261
+ 0x100101, 0x4000100, 0x4000101, 0x4100100, 0x4100101
262
+ ];
263
+ const pc2bytes2 = [
264
+ 0, 0x8, 0x800, 0x808, 0x1000000, 0x1000008, 0x1000800, 0x1000808, 0, 0x8, 0x800, 0x808,
265
+ 0x1000000, 0x1000008, 0x1000800, 0x1000808
266
+ ];
267
+ const pc2bytes3 = [
268
+ 0, 0x200000, 0x8000000, 0x8200000, 0x2000, 0x202000, 0x8002000, 0x8202000, 0x20000, 0x220000,
269
+ 0x8020000, 0x8220000, 0x22000, 0x222000, 0x8022000, 0x8222000
270
+ ];
271
+ const pc2bytes4 = [
272
+ 0, 0x40000, 0x10, 0x40010, 0, 0x40000, 0x10, 0x40010, 0x1000, 0x41000, 0x1010, 0x41010, 0x1000,
273
+ 0x41000, 0x1010, 0x41010
274
+ ];
275
+ const pc2bytes5 = [
276
+ 0, 0x400, 0x20, 0x420, 0, 0x400, 0x20, 0x420, 0x2000000, 0x2000400, 0x2000020, 0x2000420,
277
+ 0x2000000, 0x2000400, 0x2000020, 0x2000420
278
+ ];
279
+ const pc2bytes6 = [
280
+ 0, 0x10000000, 0x80000, 0x10080000, 0x2, 0x10000002, 0x80002, 0x10080002, 0, 0x10000000,
281
+ 0x80000, 0x10080000, 0x2, 0x10000002, 0x80002, 0x10080002
282
+ ];
283
+ const pc2bytes7 = [
284
+ 0, 0x10000, 0x800, 0x10800, 0x20000000, 0x20010000, 0x20000800, 0x20010800, 0x20000, 0x30000,
285
+ 0x20800, 0x30800, 0x20020000, 0x20030000, 0x20020800, 0x20030800
286
+ ];
287
+ const pc2bytes8 = [
288
+ 0, 0x40000, 0, 0x40000, 0x2, 0x40002, 0x2, 0x40002, 0x2000000, 0x2040000, 0x2000000, 0x2040000,
289
+ 0x2000002, 0x2040002, 0x2000002, 0x2040002
290
+ ];
291
+ const pc2bytes9 = [
292
+ 0, 0x10000000, 0x8, 0x10000008, 0, 0x10000000, 0x8, 0x10000008, 0x400, 0x10000400, 0x408,
293
+ 0x10000408, 0x400, 0x10000400, 0x408, 0x10000408
294
+ ];
295
+ const pc2bytes10 = [
296
+ 0, 0x20, 0, 0x20, 0x100000, 0x100020, 0x100000, 0x100020, 0x2000, 0x2020, 0x2000, 0x2020,
297
+ 0x102000, 0x102020, 0x102000, 0x102020
298
+ ];
299
+ const pc2bytes11 = [
300
+ 0, 0x1000000, 0x200, 0x1000200, 0x200000, 0x1200000, 0x200200, 0x1200200, 0x4000000, 0x5000000,
301
+ 0x4000200, 0x5000200, 0x4200000, 0x5200000, 0x4200200, 0x5200200
302
+ ];
303
+ const pc2bytes12 = [
304
+ 0, 0x1000, 0x8000000, 0x8001000, 0x80000, 0x81000, 0x8080000, 0x8081000, 0x10, 0x1010,
305
+ 0x8000010, 0x8001010, 0x80010, 0x81010, 0x8080010, 0x8081010
306
+ ];
307
+ const pc2bytes13 = [0, 0x4, 0x100, 0x104, 0, 0x4, 0x100, 0x104, 0x1, 0x5, 0x101, 0x105, 0x1, 0x5, 0x101, 0x105];
308
+
309
+ //how many iterations (1 for des, 3 for triple des)
310
+ const iterations = key.length > 8 ? 3 : 1; //changed by Paul 16/6/2007 to use Triple DES for 9+ byte keys
311
+ //stores the return keys
312
+ const keys = new Array(32 * iterations);
313
+ //now define the left shifts which need to be done
314
+ const shifts = [0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0];
315
+ //other variables
316
+ let lefttemp;
317
+ let righttemp;
318
+ let m = 0;
319
+ let n = 0;
320
+ let temp;
321
+
322
+ for (let j = 0; j < iterations; j++) { //either 1 or 3 iterations
323
+ let left = (key[m++] << 24) | (key[m++] << 16) | (key[m++] << 8) | key[m++];
324
+ let right = (key[m++] << 24) | (key[m++] << 16) | (key[m++] << 8) | key[m++];
325
+
326
+ temp = ((left >>> 4) ^ right) & 0x0f0f0f0f;
327
+ right ^= temp;
328
+ left ^= (temp << 4);
329
+ temp = ((right >>> -16) ^ left) & 0x0000ffff;
330
+ left ^= temp;
331
+ right ^= (temp << -16);
332
+ temp = ((left >>> 2) ^ right) & 0x33333333;
333
+ right ^= temp;
334
+ left ^= (temp << 2);
335
+ temp = ((right >>> -16) ^ left) & 0x0000ffff;
336
+ left ^= temp;
337
+ right ^= (temp << -16);
338
+ temp = ((left >>> 1) ^ right) & 0x55555555;
339
+ right ^= temp;
340
+ left ^= (temp << 1);
341
+ temp = ((right >>> 8) ^ left) & 0x00ff00ff;
342
+ left ^= temp;
343
+ right ^= (temp << 8);
344
+ temp = ((left >>> 1) ^ right) & 0x55555555;
345
+ right ^= temp;
346
+ left ^= (temp << 1);
347
+
348
+ //the right side needs to be shifted and to get the last four bits of the left side
349
+ temp = (left << 8) | ((right >>> 20) & 0x000000f0);
350
+ //left needs to be put upside down
351
+ left = (right << 24) | ((right << 8) & 0xff0000) | ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0);
352
+ right = temp;
353
+
354
+ //now go through and perform these shifts on the left and right keys
355
+ for (let i = 0; i < shifts.length; i++) {
356
+ //shift the keys either one or two bits to the left
357
+ if (shifts[i]) {
358
+ left = (left << 2) | (left >>> 26);
359
+ right = (right << 2) | (right >>> 26);
360
+ } else {
361
+ left = (left << 1) | (left >>> 27);
362
+ right = (right << 1) | (right >>> 27);
363
+ }
364
+ left &= -0xf;
365
+ right &= -0xf;
366
+
367
+ //now apply PC-2, in such a way that E is easier when encrypting or decrypting
368
+ //this conversion will look like PC-2 except only the last 6 bits of each byte are used
369
+ //rather than 48 consecutive bits and the order of lines will be according to
370
+ //how the S selection functions will be applied: S2, S4, S6, S8, S1, S3, S5, S7
371
+ lefttemp = pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf] | pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(
372
+ left >>> 16) & 0xf] | pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf] | pc2bytes6[(left >>> 4) &
373
+ 0xf];
374
+ righttemp = pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf] | pc2bytes9[(right >>> 20) & 0xf] |
375
+ pc2bytes10[(right >>> 16) & 0xf] | pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf] |
376
+ pc2bytes13[(right >>> 4) & 0xf];
377
+ temp = ((righttemp >>> 16) ^ lefttemp) & 0x0000ffff;
378
+ keys[n++] = lefttemp ^ temp;
379
+ keys[n++] = righttemp ^ (temp << 16);
380
+ }
381
+ } //for each iterations
382
+ //return the keys we've created
383
+ return keys;
384
+ } //end of desCreateKeys
385
+
386
+
387
+ function desAddPadding(message, padding) {
388
+ const padLength = 8 - (message.length % 8);
389
+
390
+ let pad;
391
+ if (padding === 2 && (padLength < 8)) { //pad the message with spaces
392
+ pad = ' '.charCodeAt(0);
393
+ } else if (padding === 1) { //PKCS7 padding
394
+ pad = padLength;
395
+ } else if (!padding && (padLength < 8)) { //pad the message out with null bytes
396
+ pad = 0;
397
+ } else if (padLength === 8) {
398
+ return message;
399
+ } else {
400
+ throw new Error('des: invalid padding');
401
+ }
402
+
403
+ const paddedMessage = new Uint8Array(message.length + padLength);
404
+ for (let i = 0; i < message.length; i++) {
405
+ paddedMessage[i] = message[i];
406
+ }
407
+ for (let j = 0; j < padLength; j++) {
408
+ paddedMessage[message.length + j] = pad;
409
+ }
410
+
411
+ return paddedMessage;
412
+ }
413
+
414
+ function desRemovePadding(message, padding) {
415
+ let padLength = null;
416
+ let pad;
417
+ if (padding === 2) { // space padded
418
+ pad = ' '.charCodeAt(0);
419
+ } else if (padding === 1) { // PKCS7
420
+ padLength = message[message.length - 1];
421
+ } else if (!padding) { // null padding
422
+ pad = 0;
423
+ } else {
424
+ throw new Error('des: invalid padding');
425
+ }
426
+
427
+ if (!padLength) {
428
+ padLength = 1;
429
+ while (message[message.length - padLength] === pad) {
430
+ padLength++;
431
+ }
432
+ padLength--;
433
+ }
434
+
435
+ return message.subarray(0, message.length - padLength);
436
+ }
437
+
438
+ // added by Recurity Labs
439
+
440
+ function TripleDES(key) {
441
+ this.key = [];
442
+
443
+ for (let i = 0; i < 3; i++) {
444
+ this.key.push(new Uint8Array(key.subarray(i * 8, (i * 8) + 8)));
445
+ }
446
+
447
+ this.encrypt = function(block) {
448
+ return des(
449
+ desCreateKeys(this.key[2]),
450
+ des(
451
+ desCreateKeys(this.key[1]),
452
+ des(
453
+ desCreateKeys(this.key[0]),
454
+ block, true, 0, null, null
455
+ ),
456
+ false, 0, null, null
457
+ ), true, 0, null, null
458
+ );
459
+ };
460
+ }
461
+
462
+ TripleDES.keySize = TripleDES.prototype.keySize = 24;
463
+ TripleDES.blockSize = TripleDES.prototype.blockSize = 8;
464
+
465
+ // Use of this source code is governed by a BSD-style
466
+ // license that can be found in the LICENSE file.
467
+
468
+ // Copyright 2010 pjacobs@xeekr.com . All rights reserved.
469
+
470
+ // Modified by Recurity Labs GmbH
471
+
472
+ // fixed/modified by Herbert Hanewinkel, www.haneWIN.de
473
+ // check www.haneWIN.de for the latest version
474
+
475
+ // cast5.js is a Javascript implementation of CAST-128, as defined in RFC 2144.
476
+ // CAST-128 is a common OpenPGP cipher.
477
+
478
+
479
+ // CAST5 constructor
480
+
481
+ function OpenPGPSymEncCAST5() {
482
+ this.BlockSize = 8;
483
+ this.KeySize = 16;
484
+
485
+ this.setKey = function(key) {
486
+ this.masking = new Array(16);
487
+ this.rotate = new Array(16);
488
+
489
+ this.reset();
490
+
491
+ if (key.length === this.KeySize) {
492
+ this.keySchedule(key);
493
+ } else {
494
+ throw new Error('CAST-128: keys must be 16 bytes');
495
+ }
496
+ return true;
497
+ };
498
+
499
+ this.reset = function() {
500
+ for (let i = 0; i < 16; i++) {
501
+ this.masking[i] = 0;
502
+ this.rotate[i] = 0;
503
+ }
504
+ };
505
+
506
+ this.getBlockSize = function() {
507
+ return this.BlockSize;
508
+ };
509
+
510
+ this.encrypt = function(src) {
511
+ const dst = new Array(src.length);
512
+
513
+ for (let i = 0; i < src.length; i += 8) {
514
+ let l = (src[i] << 24) | (src[i + 1] << 16) | (src[i + 2] << 8) | src[i + 3];
515
+ let r = (src[i + 4] << 24) | (src[i + 5] << 16) | (src[i + 6] << 8) | src[i + 7];
516
+ let t;
517
+
518
+ t = r;
519
+ r = l ^ f1(r, this.masking[0], this.rotate[0]);
520
+ l = t;
521
+ t = r;
522
+ r = l ^ f2(r, this.masking[1], this.rotate[1]);
523
+ l = t;
524
+ t = r;
525
+ r = l ^ f3(r, this.masking[2], this.rotate[2]);
526
+ l = t;
527
+ t = r;
528
+ r = l ^ f1(r, this.masking[3], this.rotate[3]);
529
+ l = t;
530
+
531
+ t = r;
532
+ r = l ^ f2(r, this.masking[4], this.rotate[4]);
533
+ l = t;
534
+ t = r;
535
+ r = l ^ f3(r, this.masking[5], this.rotate[5]);
536
+ l = t;
537
+ t = r;
538
+ r = l ^ f1(r, this.masking[6], this.rotate[6]);
539
+ l = t;
540
+ t = r;
541
+ r = l ^ f2(r, this.masking[7], this.rotate[7]);
542
+ l = t;
543
+
544
+ t = r;
545
+ r = l ^ f3(r, this.masking[8], this.rotate[8]);
546
+ l = t;
547
+ t = r;
548
+ r = l ^ f1(r, this.masking[9], this.rotate[9]);
549
+ l = t;
550
+ t = r;
551
+ r = l ^ f2(r, this.masking[10], this.rotate[10]);
552
+ l = t;
553
+ t = r;
554
+ r = l ^ f3(r, this.masking[11], this.rotate[11]);
555
+ l = t;
556
+
557
+ t = r;
558
+ r = l ^ f1(r, this.masking[12], this.rotate[12]);
559
+ l = t;
560
+ t = r;
561
+ r = l ^ f2(r, this.masking[13], this.rotate[13]);
562
+ l = t;
563
+ t = r;
564
+ r = l ^ f3(r, this.masking[14], this.rotate[14]);
565
+ l = t;
566
+ t = r;
567
+ r = l ^ f1(r, this.masking[15], this.rotate[15]);
568
+ l = t;
569
+
570
+ dst[i] = (r >>> 24) & 255;
571
+ dst[i + 1] = (r >>> 16) & 255;
572
+ dst[i + 2] = (r >>> 8) & 255;
573
+ dst[i + 3] = r & 255;
574
+ dst[i + 4] = (l >>> 24) & 255;
575
+ dst[i + 5] = (l >>> 16) & 255;
576
+ dst[i + 6] = (l >>> 8) & 255;
577
+ dst[i + 7] = l & 255;
578
+ }
579
+
580
+ return dst;
581
+ };
582
+
583
+ this.decrypt = function(src) {
584
+ const dst = new Array(src.length);
585
+
586
+ for (let i = 0; i < src.length; i += 8) {
587
+ let l = (src[i] << 24) | (src[i + 1] << 16) | (src[i + 2] << 8) | src[i + 3];
588
+ let r = (src[i + 4] << 24) | (src[i + 5] << 16) | (src[i + 6] << 8) | src[i + 7];
589
+ let t;
590
+
591
+ t = r;
592
+ r = l ^ f1(r, this.masking[15], this.rotate[15]);
593
+ l = t;
594
+ t = r;
595
+ r = l ^ f3(r, this.masking[14], this.rotate[14]);
596
+ l = t;
597
+ t = r;
598
+ r = l ^ f2(r, this.masking[13], this.rotate[13]);
599
+ l = t;
600
+ t = r;
601
+ r = l ^ f1(r, this.masking[12], this.rotate[12]);
602
+ l = t;
603
+
604
+ t = r;
605
+ r = l ^ f3(r, this.masking[11], this.rotate[11]);
606
+ l = t;
607
+ t = r;
608
+ r = l ^ f2(r, this.masking[10], this.rotate[10]);
609
+ l = t;
610
+ t = r;
611
+ r = l ^ f1(r, this.masking[9], this.rotate[9]);
612
+ l = t;
613
+ t = r;
614
+ r = l ^ f3(r, this.masking[8], this.rotate[8]);
615
+ l = t;
616
+
617
+ t = r;
618
+ r = l ^ f2(r, this.masking[7], this.rotate[7]);
619
+ l = t;
620
+ t = r;
621
+ r = l ^ f1(r, this.masking[6], this.rotate[6]);
622
+ l = t;
623
+ t = r;
624
+ r = l ^ f3(r, this.masking[5], this.rotate[5]);
625
+ l = t;
626
+ t = r;
627
+ r = l ^ f2(r, this.masking[4], this.rotate[4]);
628
+ l = t;
629
+
630
+ t = r;
631
+ r = l ^ f1(r, this.masking[3], this.rotate[3]);
632
+ l = t;
633
+ t = r;
634
+ r = l ^ f3(r, this.masking[2], this.rotate[2]);
635
+ l = t;
636
+ t = r;
637
+ r = l ^ f2(r, this.masking[1], this.rotate[1]);
638
+ l = t;
639
+ t = r;
640
+ r = l ^ f1(r, this.masking[0], this.rotate[0]);
641
+ l = t;
642
+
643
+ dst[i] = (r >>> 24) & 255;
644
+ dst[i + 1] = (r >>> 16) & 255;
645
+ dst[i + 2] = (r >>> 8) & 255;
646
+ dst[i + 3] = r & 255;
647
+ dst[i + 4] = (l >>> 24) & 255;
648
+ dst[i + 5] = (l >> 16) & 255;
649
+ dst[i + 6] = (l >> 8) & 255;
650
+ dst[i + 7] = l & 255;
651
+ }
652
+
653
+ return dst;
654
+ };
655
+ const scheduleA = new Array(4);
656
+
657
+ scheduleA[0] = new Array(4);
658
+ scheduleA[0][0] = [4, 0, 0xd, 0xf, 0xc, 0xe, 0x8];
659
+ scheduleA[0][1] = [5, 2, 16 + 0, 16 + 2, 16 + 1, 16 + 3, 0xa];
660
+ scheduleA[0][2] = [6, 3, 16 + 7, 16 + 6, 16 + 5, 16 + 4, 9];
661
+ scheduleA[0][3] = [7, 1, 16 + 0xa, 16 + 9, 16 + 0xb, 16 + 8, 0xb];
662
+
663
+ scheduleA[1] = new Array(4);
664
+ scheduleA[1][0] = [0, 6, 16 + 5, 16 + 7, 16 + 4, 16 + 6, 16 + 0];
665
+ scheduleA[1][1] = [1, 4, 0, 2, 1, 3, 16 + 2];
666
+ scheduleA[1][2] = [2, 5, 7, 6, 5, 4, 16 + 1];
667
+ scheduleA[1][3] = [3, 7, 0xa, 9, 0xb, 8, 16 + 3];
668
+
669
+ scheduleA[2] = new Array(4);
670
+ scheduleA[2][0] = [4, 0, 0xd, 0xf, 0xc, 0xe, 8];
671
+ scheduleA[2][1] = [5, 2, 16 + 0, 16 + 2, 16 + 1, 16 + 3, 0xa];
672
+ scheduleA[2][2] = [6, 3, 16 + 7, 16 + 6, 16 + 5, 16 + 4, 9];
673
+ scheduleA[2][3] = [7, 1, 16 + 0xa, 16 + 9, 16 + 0xb, 16 + 8, 0xb];
674
+
675
+
676
+ scheduleA[3] = new Array(4);
677
+ scheduleA[3][0] = [0, 6, 16 + 5, 16 + 7, 16 + 4, 16 + 6, 16 + 0];
678
+ scheduleA[3][1] = [1, 4, 0, 2, 1, 3, 16 + 2];
679
+ scheduleA[3][2] = [2, 5, 7, 6, 5, 4, 16 + 1];
680
+ scheduleA[3][3] = [3, 7, 0xa, 9, 0xb, 8, 16 + 3];
681
+
682
+ const scheduleB = new Array(4);
683
+
684
+ scheduleB[0] = new Array(4);
685
+ scheduleB[0][0] = [16 + 8, 16 + 9, 16 + 7, 16 + 6, 16 + 2];
686
+ scheduleB[0][1] = [16 + 0xa, 16 + 0xb, 16 + 5, 16 + 4, 16 + 6];
687
+ scheduleB[0][2] = [16 + 0xc, 16 + 0xd, 16 + 3, 16 + 2, 16 + 9];
688
+ scheduleB[0][3] = [16 + 0xe, 16 + 0xf, 16 + 1, 16 + 0, 16 + 0xc];
689
+
690
+ scheduleB[1] = new Array(4);
691
+ scheduleB[1][0] = [3, 2, 0xc, 0xd, 8];
692
+ scheduleB[1][1] = [1, 0, 0xe, 0xf, 0xd];
693
+ scheduleB[1][2] = [7, 6, 8, 9, 3];
694
+ scheduleB[1][3] = [5, 4, 0xa, 0xb, 7];
695
+
696
+
697
+ scheduleB[2] = new Array(4);
698
+ scheduleB[2][0] = [16 + 3, 16 + 2, 16 + 0xc, 16 + 0xd, 16 + 9];
699
+ scheduleB[2][1] = [16 + 1, 16 + 0, 16 + 0xe, 16 + 0xf, 16 + 0xc];
700
+ scheduleB[2][2] = [16 + 7, 16 + 6, 16 + 8, 16 + 9, 16 + 2];
701
+ scheduleB[2][3] = [16 + 5, 16 + 4, 16 + 0xa, 16 + 0xb, 16 + 6];
702
+
703
+
704
+ scheduleB[3] = new Array(4);
705
+ scheduleB[3][0] = [8, 9, 7, 6, 3];
706
+ scheduleB[3][1] = [0xa, 0xb, 5, 4, 7];
707
+ scheduleB[3][2] = [0xc, 0xd, 3, 2, 8];
708
+ scheduleB[3][3] = [0xe, 0xf, 1, 0, 0xd];
709
+
710
+ // changed 'in' to 'inn' (in javascript 'in' is a reserved word)
711
+ this.keySchedule = function(inn) {
712
+ const t = new Array(8);
713
+ const k = new Array(32);
714
+
715
+ let j;
716
+
717
+ for (let i = 0; i < 4; i++) {
718
+ j = i * 4;
719
+ t[i] = (inn[j] << 24) | (inn[j + 1] << 16) | (inn[j + 2] << 8) | inn[j + 3];
720
+ }
721
+
722
+ const x = [6, 7, 4, 5];
723
+ let ki = 0;
724
+ let w;
725
+
726
+ for (let half = 0; half < 2; half++) {
727
+ for (let round = 0; round < 4; round++) {
728
+ for (j = 0; j < 4; j++) {
729
+ const a = scheduleA[round][j];
730
+ w = t[a[1]];
731
+
732
+ w ^= sBox[4][(t[a[2] >>> 2] >>> (24 - 8 * (a[2] & 3))) & 0xff];
733
+ w ^= sBox[5][(t[a[3] >>> 2] >>> (24 - 8 * (a[3] & 3))) & 0xff];
734
+ w ^= sBox[6][(t[a[4] >>> 2] >>> (24 - 8 * (a[4] & 3))) & 0xff];
735
+ w ^= sBox[7][(t[a[5] >>> 2] >>> (24 - 8 * (a[5] & 3))) & 0xff];
736
+ w ^= sBox[x[j]][(t[a[6] >>> 2] >>> (24 - 8 * (a[6] & 3))) & 0xff];
737
+ t[a[0]] = w;
738
+ }
739
+
740
+ for (j = 0; j < 4; j++) {
741
+ const b = scheduleB[round][j];
742
+ w = sBox[4][(t[b[0] >>> 2] >>> (24 - 8 * (b[0] & 3))) & 0xff];
743
+
744
+ w ^= sBox[5][(t[b[1] >>> 2] >>> (24 - 8 * (b[1] & 3))) & 0xff];
745
+ w ^= sBox[6][(t[b[2] >>> 2] >>> (24 - 8 * (b[2] & 3))) & 0xff];
746
+ w ^= sBox[7][(t[b[3] >>> 2] >>> (24 - 8 * (b[3] & 3))) & 0xff];
747
+ w ^= sBox[4 + j][(t[b[4] >>> 2] >>> (24 - 8 * (b[4] & 3))) & 0xff];
748
+ k[ki] = w;
749
+ ki++;
750
+ }
751
+ }
752
+ }
753
+
754
+ for (let i = 0; i < 16; i++) {
755
+ this.masking[i] = k[i];
756
+ this.rotate[i] = k[16 + i] & 0x1f;
757
+ }
758
+ };
759
+
760
+ // These are the three 'f' functions. See RFC 2144, section 2.2.
761
+
762
+ function f1(d, m, r) {
763
+ const t = m + d;
764
+ const I = (t << r) | (t >>> (32 - r));
765
+ return ((sBox[0][I >>> 24] ^ sBox[1][(I >>> 16) & 255]) - sBox[2][(I >>> 8) & 255]) + sBox[3][I & 255];
766
+ }
767
+
768
+ function f2(d, m, r) {
769
+ const t = m ^ d;
770
+ const I = (t << r) | (t >>> (32 - r));
771
+ return ((sBox[0][I >>> 24] - sBox[1][(I >>> 16) & 255]) + sBox[2][(I >>> 8) & 255]) ^ sBox[3][I & 255];
772
+ }
773
+
774
+ function f3(d, m, r) {
775
+ const t = m - d;
776
+ const I = (t << r) | (t >>> (32 - r));
777
+ return ((sBox[0][I >>> 24] + sBox[1][(I >>> 16) & 255]) ^ sBox[2][(I >>> 8) & 255]) - sBox[3][I & 255];
778
+ }
779
+
780
+ const sBox = new Array(8);
781
+ sBox[0] = [
782
+ 0x30fb40d4, 0x9fa0ff0b, 0x6beccd2f, 0x3f258c7a, 0x1e213f2f, 0x9c004dd3, 0x6003e540, 0xcf9fc949,
783
+ 0xbfd4af27, 0x88bbbdb5, 0xe2034090, 0x98d09675, 0x6e63a0e0, 0x15c361d2, 0xc2e7661d, 0x22d4ff8e,
784
+ 0x28683b6f, 0xc07fd059, 0xff2379c8, 0x775f50e2, 0x43c340d3, 0xdf2f8656, 0x887ca41a, 0xa2d2bd2d,
785
+ 0xa1c9e0d6, 0x346c4819, 0x61b76d87, 0x22540f2f, 0x2abe32e1, 0xaa54166b, 0x22568e3a, 0xa2d341d0,
786
+ 0x66db40c8, 0xa784392f, 0x004dff2f, 0x2db9d2de, 0x97943fac, 0x4a97c1d8, 0x527644b7, 0xb5f437a7,
787
+ 0xb82cbaef, 0xd751d159, 0x6ff7f0ed, 0x5a097a1f, 0x827b68d0, 0x90ecf52e, 0x22b0c054, 0xbc8e5935,
788
+ 0x4b6d2f7f, 0x50bb64a2, 0xd2664910, 0xbee5812d, 0xb7332290, 0xe93b159f, 0xb48ee411, 0x4bff345d,
789
+ 0xfd45c240, 0xad31973f, 0xc4f6d02e, 0x55fc8165, 0xd5b1caad, 0xa1ac2dae, 0xa2d4b76d, 0xc19b0c50,
790
+ 0x882240f2, 0x0c6e4f38, 0xa4e4bfd7, 0x4f5ba272, 0x564c1d2f, 0xc59c5319, 0xb949e354, 0xb04669fe,
791
+ 0xb1b6ab8a, 0xc71358dd, 0x6385c545, 0x110f935d, 0x57538ad5, 0x6a390493, 0xe63d37e0, 0x2a54f6b3,
792
+ 0x3a787d5f, 0x6276a0b5, 0x19a6fcdf, 0x7a42206a, 0x29f9d4d5, 0xf61b1891, 0xbb72275e, 0xaa508167,
793
+ 0x38901091, 0xc6b505eb, 0x84c7cb8c, 0x2ad75a0f, 0x874a1427, 0xa2d1936b, 0x2ad286af, 0xaa56d291,
794
+ 0xd7894360, 0x425c750d, 0x93b39e26, 0x187184c9, 0x6c00b32d, 0x73e2bb14, 0xa0bebc3c, 0x54623779,
795
+ 0x64459eab, 0x3f328b82, 0x7718cf82, 0x59a2cea6, 0x04ee002e, 0x89fe78e6, 0x3fab0950, 0x325ff6c2,
796
+ 0x81383f05, 0x6963c5c8, 0x76cb5ad6, 0xd49974c9, 0xca180dcf, 0x380782d5, 0xc7fa5cf6, 0x8ac31511,
797
+ 0x35e79e13, 0x47da91d0, 0xf40f9086, 0xa7e2419e, 0x31366241, 0x051ef495, 0xaa573b04, 0x4a805d8d,
798
+ 0x548300d0, 0x00322a3c, 0xbf64cddf, 0xba57a68e, 0x75c6372b, 0x50afd341, 0xa7c13275, 0x915a0bf5,
799
+ 0x6b54bfab, 0x2b0b1426, 0xab4cc9d7, 0x449ccd82, 0xf7fbf265, 0xab85c5f3, 0x1b55db94, 0xaad4e324,
800
+ 0xcfa4bd3f, 0x2deaa3e2, 0x9e204d02, 0xc8bd25ac, 0xeadf55b3, 0xd5bd9e98, 0xe31231b2, 0x2ad5ad6c,
801
+ 0x954329de, 0xadbe4528, 0xd8710f69, 0xaa51c90f, 0xaa786bf6, 0x22513f1e, 0xaa51a79b, 0x2ad344cc,
802
+ 0x7b5a41f0, 0xd37cfbad, 0x1b069505, 0x41ece491, 0xb4c332e6, 0x032268d4, 0xc9600acc, 0xce387e6d,
803
+ 0xbf6bb16c, 0x6a70fb78, 0x0d03d9c9, 0xd4df39de, 0xe01063da, 0x4736f464, 0x5ad328d8, 0xb347cc96,
804
+ 0x75bb0fc3, 0x98511bfb, 0x4ffbcc35, 0xb58bcf6a, 0xe11f0abc, 0xbfc5fe4a, 0xa70aec10, 0xac39570a,
805
+ 0x3f04442f, 0x6188b153, 0xe0397a2e, 0x5727cb79, 0x9ceb418f, 0x1cacd68d, 0x2ad37c96, 0x0175cb9d,
806
+ 0xc69dff09, 0xc75b65f0, 0xd9db40d8, 0xec0e7779, 0x4744ead4, 0xb11c3274, 0xdd24cb9e, 0x7e1c54bd,
807
+ 0xf01144f9, 0xd2240eb1, 0x9675b3fd, 0xa3ac3755, 0xd47c27af, 0x51c85f4d, 0x56907596, 0xa5bb15e6,
808
+ 0x580304f0, 0xca042cf1, 0x011a37ea, 0x8dbfaadb, 0x35ba3e4a, 0x3526ffa0, 0xc37b4d09, 0xbc306ed9,
809
+ 0x98a52666, 0x5648f725, 0xff5e569d, 0x0ced63d0, 0x7c63b2cf, 0x700b45e1, 0xd5ea50f1, 0x85a92872,
810
+ 0xaf1fbda7, 0xd4234870, 0xa7870bf3, 0x2d3b4d79, 0x42e04198, 0x0cd0ede7, 0x26470db8, 0xf881814c,
811
+ 0x474d6ad7, 0x7c0c5e5c, 0xd1231959, 0x381b7298, 0xf5d2f4db, 0xab838653, 0x6e2f1e23, 0x83719c9e,
812
+ 0xbd91e046, 0x9a56456e, 0xdc39200c, 0x20c8c571, 0x962bda1c, 0xe1e696ff, 0xb141ab08, 0x7cca89b9,
813
+ 0x1a69e783, 0x02cc4843, 0xa2f7c579, 0x429ef47d, 0x427b169c, 0x5ac9f049, 0xdd8f0f00, 0x5c8165bf
814
+ ];
815
+
816
+ sBox[1] = [
817
+ 0x1f201094, 0xef0ba75b, 0x69e3cf7e, 0x393f4380, 0xfe61cf7a, 0xeec5207a, 0x55889c94, 0x72fc0651,
818
+ 0xada7ef79, 0x4e1d7235, 0xd55a63ce, 0xde0436ba, 0x99c430ef, 0x5f0c0794, 0x18dcdb7d, 0xa1d6eff3,
819
+ 0xa0b52f7b, 0x59e83605, 0xee15b094, 0xe9ffd909, 0xdc440086, 0xef944459, 0xba83ccb3, 0xe0c3cdfb,
820
+ 0xd1da4181, 0x3b092ab1, 0xf997f1c1, 0xa5e6cf7b, 0x01420ddb, 0xe4e7ef5b, 0x25a1ff41, 0xe180f806,
821
+ 0x1fc41080, 0x179bee7a, 0xd37ac6a9, 0xfe5830a4, 0x98de8b7f, 0x77e83f4e, 0x79929269, 0x24fa9f7b,
822
+ 0xe113c85b, 0xacc40083, 0xd7503525, 0xf7ea615f, 0x62143154, 0x0d554b63, 0x5d681121, 0xc866c359,
823
+ 0x3d63cf73, 0xcee234c0, 0xd4d87e87, 0x5c672b21, 0x071f6181, 0x39f7627f, 0x361e3084, 0xe4eb573b,
824
+ 0x602f64a4, 0xd63acd9c, 0x1bbc4635, 0x9e81032d, 0x2701f50c, 0x99847ab4, 0xa0e3df79, 0xba6cf38c,
825
+ 0x10843094, 0x2537a95e, 0xf46f6ffe, 0xa1ff3b1f, 0x208cfb6a, 0x8f458c74, 0xd9e0a227, 0x4ec73a34,
826
+ 0xfc884f69, 0x3e4de8df, 0xef0e0088, 0x3559648d, 0x8a45388c, 0x1d804366, 0x721d9bfd, 0xa58684bb,
827
+ 0xe8256333, 0x844e8212, 0x128d8098, 0xfed33fb4, 0xce280ae1, 0x27e19ba5, 0xd5a6c252, 0xe49754bd,
828
+ 0xc5d655dd, 0xeb667064, 0x77840b4d, 0xa1b6a801, 0x84db26a9, 0xe0b56714, 0x21f043b7, 0xe5d05860,
829
+ 0x54f03084, 0x066ff472, 0xa31aa153, 0xdadc4755, 0xb5625dbf, 0x68561be6, 0x83ca6b94, 0x2d6ed23b,
830
+ 0xeccf01db, 0xa6d3d0ba, 0xb6803d5c, 0xaf77a709, 0x33b4a34c, 0x397bc8d6, 0x5ee22b95, 0x5f0e5304,
831
+ 0x81ed6f61, 0x20e74364, 0xb45e1378, 0xde18639b, 0x881ca122, 0xb96726d1, 0x8049a7e8, 0x22b7da7b,
832
+ 0x5e552d25, 0x5272d237, 0x79d2951c, 0xc60d894c, 0x488cb402, 0x1ba4fe5b, 0xa4b09f6b, 0x1ca815cf,
833
+ 0xa20c3005, 0x8871df63, 0xb9de2fcb, 0x0cc6c9e9, 0x0beeff53, 0xe3214517, 0xb4542835, 0x9f63293c,
834
+ 0xee41e729, 0x6e1d2d7c, 0x50045286, 0x1e6685f3, 0xf33401c6, 0x30a22c95, 0x31a70850, 0x60930f13,
835
+ 0x73f98417, 0xa1269859, 0xec645c44, 0x52c877a9, 0xcdff33a6, 0xa02b1741, 0x7cbad9a2, 0x2180036f,
836
+ 0x50d99c08, 0xcb3f4861, 0xc26bd765, 0x64a3f6ab, 0x80342676, 0x25a75e7b, 0xe4e6d1fc, 0x20c710e6,
837
+ 0xcdf0b680, 0x17844d3b, 0x31eef84d, 0x7e0824e4, 0x2ccb49eb, 0x846a3bae, 0x8ff77888, 0xee5d60f6,
838
+ 0x7af75673, 0x2fdd5cdb, 0xa11631c1, 0x30f66f43, 0xb3faec54, 0x157fd7fa, 0xef8579cc, 0xd152de58,
839
+ 0xdb2ffd5e, 0x8f32ce19, 0x306af97a, 0x02f03ef8, 0x99319ad5, 0xc242fa0f, 0xa7e3ebb0, 0xc68e4906,
840
+ 0xb8da230c, 0x80823028, 0xdcdef3c8, 0xd35fb171, 0x088a1bc8, 0xbec0c560, 0x61a3c9e8, 0xbca8f54d,
841
+ 0xc72feffa, 0x22822e99, 0x82c570b4, 0xd8d94e89, 0x8b1c34bc, 0x301e16e6, 0x273be979, 0xb0ffeaa6,
842
+ 0x61d9b8c6, 0x00b24869, 0xb7ffce3f, 0x08dc283b, 0x43daf65a, 0xf7e19798, 0x7619b72f, 0x8f1c9ba4,
843
+ 0xdc8637a0, 0x16a7d3b1, 0x9fc393b7, 0xa7136eeb, 0xc6bcc63e, 0x1a513742, 0xef6828bc, 0x520365d6,
844
+ 0x2d6a77ab, 0x3527ed4b, 0x821fd216, 0x095c6e2e, 0xdb92f2fb, 0x5eea29cb, 0x145892f5, 0x91584f7f,
845
+ 0x5483697b, 0x2667a8cc, 0x85196048, 0x8c4bacea, 0x833860d4, 0x0d23e0f9, 0x6c387e8a, 0x0ae6d249,
846
+ 0xb284600c, 0xd835731d, 0xdcb1c647, 0xac4c56ea, 0x3ebd81b3, 0x230eabb0, 0x6438bc87, 0xf0b5b1fa,
847
+ 0x8f5ea2b3, 0xfc184642, 0x0a036b7a, 0x4fb089bd, 0x649da589, 0xa345415e, 0x5c038323, 0x3e5d3bb9,
848
+ 0x43d79572, 0x7e6dd07c, 0x06dfdf1e, 0x6c6cc4ef, 0x7160a539, 0x73bfbe70, 0x83877605, 0x4523ecf1
849
+ ];
850
+
851
+ sBox[2] = [
852
+ 0x8defc240, 0x25fa5d9f, 0xeb903dbf, 0xe810c907, 0x47607fff, 0x369fe44b, 0x8c1fc644, 0xaececa90,
853
+ 0xbeb1f9bf, 0xeefbcaea, 0xe8cf1950, 0x51df07ae, 0x920e8806, 0xf0ad0548, 0xe13c8d83, 0x927010d5,
854
+ 0x11107d9f, 0x07647db9, 0xb2e3e4d4, 0x3d4f285e, 0xb9afa820, 0xfade82e0, 0xa067268b, 0x8272792e,
855
+ 0x553fb2c0, 0x489ae22b, 0xd4ef9794, 0x125e3fbc, 0x21fffcee, 0x825b1bfd, 0x9255c5ed, 0x1257a240,
856
+ 0x4e1a8302, 0xbae07fff, 0x528246e7, 0x8e57140e, 0x3373f7bf, 0x8c9f8188, 0xa6fc4ee8, 0xc982b5a5,
857
+ 0xa8c01db7, 0x579fc264, 0x67094f31, 0xf2bd3f5f, 0x40fff7c1, 0x1fb78dfc, 0x8e6bd2c1, 0x437be59b,
858
+ 0x99b03dbf, 0xb5dbc64b, 0x638dc0e6, 0x55819d99, 0xa197c81c, 0x4a012d6e, 0xc5884a28, 0xccc36f71,
859
+ 0xb843c213, 0x6c0743f1, 0x8309893c, 0x0feddd5f, 0x2f7fe850, 0xd7c07f7e, 0x02507fbf, 0x5afb9a04,
860
+ 0xa747d2d0, 0x1651192e, 0xaf70bf3e, 0x58c31380, 0x5f98302e, 0x727cc3c4, 0x0a0fb402, 0x0f7fef82,
861
+ 0x8c96fdad, 0x5d2c2aae, 0x8ee99a49, 0x50da88b8, 0x8427f4a0, 0x1eac5790, 0x796fb449, 0x8252dc15,
862
+ 0xefbd7d9b, 0xa672597d, 0xada840d8, 0x45f54504, 0xfa5d7403, 0xe83ec305, 0x4f91751a, 0x925669c2,
863
+ 0x23efe941, 0xa903f12e, 0x60270df2, 0x0276e4b6, 0x94fd6574, 0x927985b2, 0x8276dbcb, 0x02778176,
864
+ 0xf8af918d, 0x4e48f79e, 0x8f616ddf, 0xe29d840e, 0x842f7d83, 0x340ce5c8, 0x96bbb682, 0x93b4b148,
865
+ 0xef303cab, 0x984faf28, 0x779faf9b, 0x92dc560d, 0x224d1e20, 0x8437aa88, 0x7d29dc96, 0x2756d3dc,
866
+ 0x8b907cee, 0xb51fd240, 0xe7c07ce3, 0xe566b4a1, 0xc3e9615e, 0x3cf8209d, 0x6094d1e3, 0xcd9ca341,
867
+ 0x5c76460e, 0x00ea983b, 0xd4d67881, 0xfd47572c, 0xf76cedd9, 0xbda8229c, 0x127dadaa, 0x438a074e,
868
+ 0x1f97c090, 0x081bdb8a, 0x93a07ebe, 0xb938ca15, 0x97b03cff, 0x3dc2c0f8, 0x8d1ab2ec, 0x64380e51,
869
+ 0x68cc7bfb, 0xd90f2788, 0x12490181, 0x5de5ffd4, 0xdd7ef86a, 0x76a2e214, 0xb9a40368, 0x925d958f,
870
+ 0x4b39fffa, 0xba39aee9, 0xa4ffd30b, 0xfaf7933b, 0x6d498623, 0x193cbcfa, 0x27627545, 0x825cf47a,
871
+ 0x61bd8ba0, 0xd11e42d1, 0xcead04f4, 0x127ea392, 0x10428db7, 0x8272a972, 0x9270c4a8, 0x127de50b,
872
+ 0x285ba1c8, 0x3c62f44f, 0x35c0eaa5, 0xe805d231, 0x428929fb, 0xb4fcdf82, 0x4fb66a53, 0x0e7dc15b,
873
+ 0x1f081fab, 0x108618ae, 0xfcfd086d, 0xf9ff2889, 0x694bcc11, 0x236a5cae, 0x12deca4d, 0x2c3f8cc5,
874
+ 0xd2d02dfe, 0xf8ef5896, 0xe4cf52da, 0x95155b67, 0x494a488c, 0xb9b6a80c, 0x5c8f82bc, 0x89d36b45,
875
+ 0x3a609437, 0xec00c9a9, 0x44715253, 0x0a874b49, 0xd773bc40, 0x7c34671c, 0x02717ef6, 0x4feb5536,
876
+ 0xa2d02fff, 0xd2bf60c4, 0xd43f03c0, 0x50b4ef6d, 0x07478cd1, 0x006e1888, 0xa2e53f55, 0xb9e6d4bc,
877
+ 0xa2048016, 0x97573833, 0xd7207d67, 0xde0f8f3d, 0x72f87b33, 0xabcc4f33, 0x7688c55d, 0x7b00a6b0,
878
+ 0x947b0001, 0x570075d2, 0xf9bb88f8, 0x8942019e, 0x4264a5ff, 0x856302e0, 0x72dbd92b, 0xee971b69,
879
+ 0x6ea22fde, 0x5f08ae2b, 0xaf7a616d, 0xe5c98767, 0xcf1febd2, 0x61efc8c2, 0xf1ac2571, 0xcc8239c2,
880
+ 0x67214cb8, 0xb1e583d1, 0xb7dc3e62, 0x7f10bdce, 0xf90a5c38, 0x0ff0443d, 0x606e6dc6, 0x60543a49,
881
+ 0x5727c148, 0x2be98a1d, 0x8ab41738, 0x20e1be24, 0xaf96da0f, 0x68458425, 0x99833be5, 0x600d457d,
882
+ 0x282f9350, 0x8334b362, 0xd91d1120, 0x2b6d8da0, 0x642b1e31, 0x9c305a00, 0x52bce688, 0x1b03588a,
883
+ 0xf7baefd5, 0x4142ed9c, 0xa4315c11, 0x83323ec5, 0xdfef4636, 0xa133c501, 0xe9d3531c, 0xee353783
884
+ ];
885
+
886
+ sBox[3] = [
887
+ 0x9db30420, 0x1fb6e9de, 0xa7be7bef, 0xd273a298, 0x4a4f7bdb, 0x64ad8c57, 0x85510443, 0xfa020ed1,
888
+ 0x7e287aff, 0xe60fb663, 0x095f35a1, 0x79ebf120, 0xfd059d43, 0x6497b7b1, 0xf3641f63, 0x241e4adf,
889
+ 0x28147f5f, 0x4fa2b8cd, 0xc9430040, 0x0cc32220, 0xfdd30b30, 0xc0a5374f, 0x1d2d00d9, 0x24147b15,
890
+ 0xee4d111a, 0x0fca5167, 0x71ff904c, 0x2d195ffe, 0x1a05645f, 0x0c13fefe, 0x081b08ca, 0x05170121,
891
+ 0x80530100, 0xe83e5efe, 0xac9af4f8, 0x7fe72701, 0xd2b8ee5f, 0x06df4261, 0xbb9e9b8a, 0x7293ea25,
892
+ 0xce84ffdf, 0xf5718801, 0x3dd64b04, 0xa26f263b, 0x7ed48400, 0x547eebe6, 0x446d4ca0, 0x6cf3d6f5,
893
+ 0x2649abdf, 0xaea0c7f5, 0x36338cc1, 0x503f7e93, 0xd3772061, 0x11b638e1, 0x72500e03, 0xf80eb2bb,
894
+ 0xabe0502e, 0xec8d77de, 0x57971e81, 0xe14f6746, 0xc9335400, 0x6920318f, 0x081dbb99, 0xffc304a5,
895
+ 0x4d351805, 0x7f3d5ce3, 0xa6c866c6, 0x5d5bcca9, 0xdaec6fea, 0x9f926f91, 0x9f46222f, 0x3991467d,
896
+ 0xa5bf6d8e, 0x1143c44f, 0x43958302, 0xd0214eeb, 0x022083b8, 0x3fb6180c, 0x18f8931e, 0x281658e6,
897
+ 0x26486e3e, 0x8bd78a70, 0x7477e4c1, 0xb506e07c, 0xf32d0a25, 0x79098b02, 0xe4eabb81, 0x28123b23,
898
+ 0x69dead38, 0x1574ca16, 0xdf871b62, 0x211c40b7, 0xa51a9ef9, 0x0014377b, 0x041e8ac8, 0x09114003,
899
+ 0xbd59e4d2, 0xe3d156d5, 0x4fe876d5, 0x2f91a340, 0x557be8de, 0x00eae4a7, 0x0ce5c2ec, 0x4db4bba6,
900
+ 0xe756bdff, 0xdd3369ac, 0xec17b035, 0x06572327, 0x99afc8b0, 0x56c8c391, 0x6b65811c, 0x5e146119,
901
+ 0x6e85cb75, 0xbe07c002, 0xc2325577, 0x893ff4ec, 0x5bbfc92d, 0xd0ec3b25, 0xb7801ab7, 0x8d6d3b24,
902
+ 0x20c763ef, 0xc366a5fc, 0x9c382880, 0x0ace3205, 0xaac9548a, 0xeca1d7c7, 0x041afa32, 0x1d16625a,
903
+ 0x6701902c, 0x9b757a54, 0x31d477f7, 0x9126b031, 0x36cc6fdb, 0xc70b8b46, 0xd9e66a48, 0x56e55a79,
904
+ 0x026a4ceb, 0x52437eff, 0x2f8f76b4, 0x0df980a5, 0x8674cde3, 0xedda04eb, 0x17a9be04, 0x2c18f4df,
905
+ 0xb7747f9d, 0xab2af7b4, 0xefc34d20, 0x2e096b7c, 0x1741a254, 0xe5b6a035, 0x213d42f6, 0x2c1c7c26,
906
+ 0x61c2f50f, 0x6552daf9, 0xd2c231f8, 0x25130f69, 0xd8167fa2, 0x0418f2c8, 0x001a96a6, 0x0d1526ab,
907
+ 0x63315c21, 0x5e0a72ec, 0x49bafefd, 0x187908d9, 0x8d0dbd86, 0x311170a7, 0x3e9b640c, 0xcc3e10d7,
908
+ 0xd5cad3b6, 0x0caec388, 0xf73001e1, 0x6c728aff, 0x71eae2a1, 0x1f9af36e, 0xcfcbd12f, 0xc1de8417,
909
+ 0xac07be6b, 0xcb44a1d8, 0x8b9b0f56, 0x013988c3, 0xb1c52fca, 0xb4be31cd, 0xd8782806, 0x12a3a4e2,
910
+ 0x6f7de532, 0x58fd7eb6, 0xd01ee900, 0x24adffc2, 0xf4990fc5, 0x9711aac5, 0x001d7b95, 0x82e5e7d2,
911
+ 0x109873f6, 0x00613096, 0xc32d9521, 0xada121ff, 0x29908415, 0x7fbb977f, 0xaf9eb3db, 0x29c9ed2a,
912
+ 0x5ce2a465, 0xa730f32c, 0xd0aa3fe8, 0x8a5cc091, 0xd49e2ce7, 0x0ce454a9, 0xd60acd86, 0x015f1919,
913
+ 0x77079103, 0xdea03af6, 0x78a8565e, 0xdee356df, 0x21f05cbe, 0x8b75e387, 0xb3c50651, 0xb8a5c3ef,
914
+ 0xd8eeb6d2, 0xe523be77, 0xc2154529, 0x2f69efdf, 0xafe67afb, 0xf470c4b2, 0xf3e0eb5b, 0xd6cc9876,
915
+ 0x39e4460c, 0x1fda8538, 0x1987832f, 0xca007367, 0xa99144f8, 0x296b299e, 0x492fc295, 0x9266beab,
916
+ 0xb5676e69, 0x9bd3ddda, 0xdf7e052f, 0xdb25701c, 0x1b5e51ee, 0xf65324e6, 0x6afce36c, 0x0316cc04,
917
+ 0x8644213e, 0xb7dc59d0, 0x7965291f, 0xccd6fd43, 0x41823979, 0x932bcdf6, 0xb657c34d, 0x4edfd282,
918
+ 0x7ae5290c, 0x3cb9536b, 0x851e20fe, 0x9833557e, 0x13ecf0b0, 0xd3ffb372, 0x3f85c5c1, 0x0aef7ed2
919
+ ];
920
+
921
+ sBox[4] = [
922
+ 0x7ec90c04, 0x2c6e74b9, 0x9b0e66df, 0xa6337911, 0xb86a7fff, 0x1dd358f5, 0x44dd9d44, 0x1731167f,
923
+ 0x08fbf1fa, 0xe7f511cc, 0xd2051b00, 0x735aba00, 0x2ab722d8, 0x386381cb, 0xacf6243a, 0x69befd7a,
924
+ 0xe6a2e77f, 0xf0c720cd, 0xc4494816, 0xccf5c180, 0x38851640, 0x15b0a848, 0xe68b18cb, 0x4caadeff,
925
+ 0x5f480a01, 0x0412b2aa, 0x259814fc, 0x41d0efe2, 0x4e40b48d, 0x248eb6fb, 0x8dba1cfe, 0x41a99b02,
926
+ 0x1a550a04, 0xba8f65cb, 0x7251f4e7, 0x95a51725, 0xc106ecd7, 0x97a5980a, 0xc539b9aa, 0x4d79fe6a,
927
+ 0xf2f3f763, 0x68af8040, 0xed0c9e56, 0x11b4958b, 0xe1eb5a88, 0x8709e6b0, 0xd7e07156, 0x4e29fea7,
928
+ 0x6366e52d, 0x02d1c000, 0xc4ac8e05, 0x9377f571, 0x0c05372a, 0x578535f2, 0x2261be02, 0xd642a0c9,
929
+ 0xdf13a280, 0x74b55bd2, 0x682199c0, 0xd421e5ec, 0x53fb3ce8, 0xc8adedb3, 0x28a87fc9, 0x3d959981,
930
+ 0x5c1ff900, 0xfe38d399, 0x0c4eff0b, 0x062407ea, 0xaa2f4fb1, 0x4fb96976, 0x90c79505, 0xb0a8a774,
931
+ 0xef55a1ff, 0xe59ca2c2, 0xa6b62d27, 0xe66a4263, 0xdf65001f, 0x0ec50966, 0xdfdd55bc, 0x29de0655,
932
+ 0x911e739a, 0x17af8975, 0x32c7911c, 0x89f89468, 0x0d01e980, 0x524755f4, 0x03b63cc9, 0x0cc844b2,
933
+ 0xbcf3f0aa, 0x87ac36e9, 0xe53a7426, 0x01b3d82b, 0x1a9e7449, 0x64ee2d7e, 0xcddbb1da, 0x01c94910,
934
+ 0xb868bf80, 0x0d26f3fd, 0x9342ede7, 0x04a5c284, 0x636737b6, 0x50f5b616, 0xf24766e3, 0x8eca36c1,
935
+ 0x136e05db, 0xfef18391, 0xfb887a37, 0xd6e7f7d4, 0xc7fb7dc9, 0x3063fcdf, 0xb6f589de, 0xec2941da,
936
+ 0x26e46695, 0xb7566419, 0xf654efc5, 0xd08d58b7, 0x48925401, 0xc1bacb7f, 0xe5ff550f, 0xb6083049,
937
+ 0x5bb5d0e8, 0x87d72e5a, 0xab6a6ee1, 0x223a66ce, 0xc62bf3cd, 0x9e0885f9, 0x68cb3e47, 0x086c010f,
938
+ 0xa21de820, 0xd18b69de, 0xf3f65777, 0xfa02c3f6, 0x407edac3, 0xcbb3d550, 0x1793084d, 0xb0d70eba,
939
+ 0x0ab378d5, 0xd951fb0c, 0xded7da56, 0x4124bbe4, 0x94ca0b56, 0x0f5755d1, 0xe0e1e56e, 0x6184b5be,
940
+ 0x580a249f, 0x94f74bc0, 0xe327888e, 0x9f7b5561, 0xc3dc0280, 0x05687715, 0x646c6bd7, 0x44904db3,
941
+ 0x66b4f0a3, 0xc0f1648a, 0x697ed5af, 0x49e92ff6, 0x309e374f, 0x2cb6356a, 0x85808573, 0x4991f840,
942
+ 0x76f0ae02, 0x083be84d, 0x28421c9a, 0x44489406, 0x736e4cb8, 0xc1092910, 0x8bc95fc6, 0x7d869cf4,
943
+ 0x134f616f, 0x2e77118d, 0xb31b2be1, 0xaa90b472, 0x3ca5d717, 0x7d161bba, 0x9cad9010, 0xaf462ba2,
944
+ 0x9fe459d2, 0x45d34559, 0xd9f2da13, 0xdbc65487, 0xf3e4f94e, 0x176d486f, 0x097c13ea, 0x631da5c7,
945
+ 0x445f7382, 0x175683f4, 0xcdc66a97, 0x70be0288, 0xb3cdcf72, 0x6e5dd2f3, 0x20936079, 0x459b80a5,
946
+ 0xbe60e2db, 0xa9c23101, 0xeba5315c, 0x224e42f2, 0x1c5c1572, 0xf6721b2c, 0x1ad2fff3, 0x8c25404e,
947
+ 0x324ed72f, 0x4067b7fd, 0x0523138e, 0x5ca3bc78, 0xdc0fd66e, 0x75922283, 0x784d6b17, 0x58ebb16e,
948
+ 0x44094f85, 0x3f481d87, 0xfcfeae7b, 0x77b5ff76, 0x8c2302bf, 0xaaf47556, 0x5f46b02a, 0x2b092801,
949
+ 0x3d38f5f7, 0x0ca81f36, 0x52af4a8a, 0x66d5e7c0, 0xdf3b0874, 0x95055110, 0x1b5ad7a8, 0xf61ed5ad,
950
+ 0x6cf6e479, 0x20758184, 0xd0cefa65, 0x88f7be58, 0x4a046826, 0x0ff6f8f3, 0xa09c7f70, 0x5346aba0,
951
+ 0x5ce96c28, 0xe176eda3, 0x6bac307f, 0x376829d2, 0x85360fa9, 0x17e3fe2a, 0x24b79767, 0xf5a96b20,
952
+ 0xd6cd2595, 0x68ff1ebf, 0x7555442c, 0xf19f06be, 0xf9e0659a, 0xeeb9491d, 0x34010718, 0xbb30cab8,
953
+ 0xe822fe15, 0x88570983, 0x750e6249, 0xda627e55, 0x5e76ffa8, 0xb1534546, 0x6d47de08, 0xefe9e7d4
954
+ ];
955
+
956
+ sBox[5] = [
957
+ 0xf6fa8f9d, 0x2cac6ce1, 0x4ca34867, 0xe2337f7c, 0x95db08e7, 0x016843b4, 0xeced5cbc, 0x325553ac,
958
+ 0xbf9f0960, 0xdfa1e2ed, 0x83f0579d, 0x63ed86b9, 0x1ab6a6b8, 0xde5ebe39, 0xf38ff732, 0x8989b138,
959
+ 0x33f14961, 0xc01937bd, 0xf506c6da, 0xe4625e7e, 0xa308ea99, 0x4e23e33c, 0x79cbd7cc, 0x48a14367,
960
+ 0xa3149619, 0xfec94bd5, 0xa114174a, 0xeaa01866, 0xa084db2d, 0x09a8486f, 0xa888614a, 0x2900af98,
961
+ 0x01665991, 0xe1992863, 0xc8f30c60, 0x2e78ef3c, 0xd0d51932, 0xcf0fec14, 0xf7ca07d2, 0xd0a82072,
962
+ 0xfd41197e, 0x9305a6b0, 0xe86be3da, 0x74bed3cd, 0x372da53c, 0x4c7f4448, 0xdab5d440, 0x6dba0ec3,
963
+ 0x083919a7, 0x9fbaeed9, 0x49dbcfb0, 0x4e670c53, 0x5c3d9c01, 0x64bdb941, 0x2c0e636a, 0xba7dd9cd,
964
+ 0xea6f7388, 0xe70bc762, 0x35f29adb, 0x5c4cdd8d, 0xf0d48d8c, 0xb88153e2, 0x08a19866, 0x1ae2eac8,
965
+ 0x284caf89, 0xaa928223, 0x9334be53, 0x3b3a21bf, 0x16434be3, 0x9aea3906, 0xefe8c36e, 0xf890cdd9,
966
+ 0x80226dae, 0xc340a4a3, 0xdf7e9c09, 0xa694a807, 0x5b7c5ecc, 0x221db3a6, 0x9a69a02f, 0x68818a54,
967
+ 0xceb2296f, 0x53c0843a, 0xfe893655, 0x25bfe68a, 0xb4628abc, 0xcf222ebf, 0x25ac6f48, 0xa9a99387,
968
+ 0x53bddb65, 0xe76ffbe7, 0xe967fd78, 0x0ba93563, 0x8e342bc1, 0xe8a11be9, 0x4980740d, 0xc8087dfc,
969
+ 0x8de4bf99, 0xa11101a0, 0x7fd37975, 0xda5a26c0, 0xe81f994f, 0x9528cd89, 0xfd339fed, 0xb87834bf,
970
+ 0x5f04456d, 0x22258698, 0xc9c4c83b, 0x2dc156be, 0x4f628daa, 0x57f55ec5, 0xe2220abe, 0xd2916ebf,
971
+ 0x4ec75b95, 0x24f2c3c0, 0x42d15d99, 0xcd0d7fa0, 0x7b6e27ff, 0xa8dc8af0, 0x7345c106, 0xf41e232f,
972
+ 0x35162386, 0xe6ea8926, 0x3333b094, 0x157ec6f2, 0x372b74af, 0x692573e4, 0xe9a9d848, 0xf3160289,
973
+ 0x3a62ef1d, 0xa787e238, 0xf3a5f676, 0x74364853, 0x20951063, 0x4576698d, 0xb6fad407, 0x592af950,
974
+ 0x36f73523, 0x4cfb6e87, 0x7da4cec0, 0x6c152daa, 0xcb0396a8, 0xc50dfe5d, 0xfcd707ab, 0x0921c42f,
975
+ 0x89dff0bb, 0x5fe2be78, 0x448f4f33, 0x754613c9, 0x2b05d08d, 0x48b9d585, 0xdc049441, 0xc8098f9b,
976
+ 0x7dede786, 0xc39a3373, 0x42410005, 0x6a091751, 0x0ef3c8a6, 0x890072d6, 0x28207682, 0xa9a9f7be,
977
+ 0xbf32679d, 0xd45b5b75, 0xb353fd00, 0xcbb0e358, 0x830f220a, 0x1f8fb214, 0xd372cf08, 0xcc3c4a13,
978
+ 0x8cf63166, 0x061c87be, 0x88c98f88, 0x6062e397, 0x47cf8e7a, 0xb6c85283, 0x3cc2acfb, 0x3fc06976,
979
+ 0x4e8f0252, 0x64d8314d, 0xda3870e3, 0x1e665459, 0xc10908f0, 0x513021a5, 0x6c5b68b7, 0x822f8aa0,
980
+ 0x3007cd3e, 0x74719eef, 0xdc872681, 0x073340d4, 0x7e432fd9, 0x0c5ec241, 0x8809286c, 0xf592d891,
981
+ 0x08a930f6, 0x957ef305, 0xb7fbffbd, 0xc266e96f, 0x6fe4ac98, 0xb173ecc0, 0xbc60b42a, 0x953498da,
982
+ 0xfba1ae12, 0x2d4bd736, 0x0f25faab, 0xa4f3fceb, 0xe2969123, 0x257f0c3d, 0x9348af49, 0x361400bc,
983
+ 0xe8816f4a, 0x3814f200, 0xa3f94043, 0x9c7a54c2, 0xbc704f57, 0xda41e7f9, 0xc25ad33a, 0x54f4a084,
984
+ 0xb17f5505, 0x59357cbe, 0xedbd15c8, 0x7f97c5ab, 0xba5ac7b5, 0xb6f6deaf, 0x3a479c3a, 0x5302da25,
985
+ 0x653d7e6a, 0x54268d49, 0x51a477ea, 0x5017d55b, 0xd7d25d88, 0x44136c76, 0x0404a8c8, 0xb8e5a121,
986
+ 0xb81a928a, 0x60ed5869, 0x97c55b96, 0xeaec991b, 0x29935913, 0x01fdb7f1, 0x088e8dfa, 0x9ab6f6f5,
987
+ 0x3b4cbf9f, 0x4a5de3ab, 0xe6051d35, 0xa0e1d855, 0xd36b4cf1, 0xf544edeb, 0xb0e93524, 0xbebb8fbd,
988
+ 0xa2d762cf, 0x49c92f54, 0x38b5f331, 0x7128a454, 0x48392905, 0xa65b1db8, 0x851c97bd, 0xd675cf2f
989
+ ];
990
+
991
+ sBox[6] = [
992
+ 0x85e04019, 0x332bf567, 0x662dbfff, 0xcfc65693, 0x2a8d7f6f, 0xab9bc912, 0xde6008a1, 0x2028da1f,
993
+ 0x0227bce7, 0x4d642916, 0x18fac300, 0x50f18b82, 0x2cb2cb11, 0xb232e75c, 0x4b3695f2, 0xb28707de,
994
+ 0xa05fbcf6, 0xcd4181e9, 0xe150210c, 0xe24ef1bd, 0xb168c381, 0xfde4e789, 0x5c79b0d8, 0x1e8bfd43,
995
+ 0x4d495001, 0x38be4341, 0x913cee1d, 0x92a79c3f, 0x089766be, 0xbaeeadf4, 0x1286becf, 0xb6eacb19,
996
+ 0x2660c200, 0x7565bde4, 0x64241f7a, 0x8248dca9, 0xc3b3ad66, 0x28136086, 0x0bd8dfa8, 0x356d1cf2,
997
+ 0x107789be, 0xb3b2e9ce, 0x0502aa8f, 0x0bc0351e, 0x166bf52a, 0xeb12ff82, 0xe3486911, 0xd34d7516,
998
+ 0x4e7b3aff, 0x5f43671b, 0x9cf6e037, 0x4981ac83, 0x334266ce, 0x8c9341b7, 0xd0d854c0, 0xcb3a6c88,
999
+ 0x47bc2829, 0x4725ba37, 0xa66ad22b, 0x7ad61f1e, 0x0c5cbafa, 0x4437f107, 0xb6e79962, 0x42d2d816,
1000
+ 0x0a961288, 0xe1a5c06e, 0x13749e67, 0x72fc081a, 0xb1d139f7, 0xf9583745, 0xcf19df58, 0xbec3f756,
1001
+ 0xc06eba30, 0x07211b24, 0x45c28829, 0xc95e317f, 0xbc8ec511, 0x38bc46e9, 0xc6e6fa14, 0xbae8584a,
1002
+ 0xad4ebc46, 0x468f508b, 0x7829435f, 0xf124183b, 0x821dba9f, 0xaff60ff4, 0xea2c4e6d, 0x16e39264,
1003
+ 0x92544a8b, 0x009b4fc3, 0xaba68ced, 0x9ac96f78, 0x06a5b79a, 0xb2856e6e, 0x1aec3ca9, 0xbe838688,
1004
+ 0x0e0804e9, 0x55f1be56, 0xe7e5363b, 0xb3a1f25d, 0xf7debb85, 0x61fe033c, 0x16746233, 0x3c034c28,
1005
+ 0xda6d0c74, 0x79aac56c, 0x3ce4e1ad, 0x51f0c802, 0x98f8f35a, 0x1626a49f, 0xeed82b29, 0x1d382fe3,
1006
+ 0x0c4fb99a, 0xbb325778, 0x3ec6d97b, 0x6e77a6a9, 0xcb658b5c, 0xd45230c7, 0x2bd1408b, 0x60c03eb7,
1007
+ 0xb9068d78, 0xa33754f4, 0xf430c87d, 0xc8a71302, 0xb96d8c32, 0xebd4e7be, 0xbe8b9d2d, 0x7979fb06,
1008
+ 0xe7225308, 0x8b75cf77, 0x11ef8da4, 0xe083c858, 0x8d6b786f, 0x5a6317a6, 0xfa5cf7a0, 0x5dda0033,
1009
+ 0xf28ebfb0, 0xf5b9c310, 0xa0eac280, 0x08b9767a, 0xa3d9d2b0, 0x79d34217, 0x021a718d, 0x9ac6336a,
1010
+ 0x2711fd60, 0x438050e3, 0x069908a8, 0x3d7fedc4, 0x826d2bef, 0x4eeb8476, 0x488dcf25, 0x36c9d566,
1011
+ 0x28e74e41, 0xc2610aca, 0x3d49a9cf, 0xbae3b9df, 0xb65f8de6, 0x92aeaf64, 0x3ac7d5e6, 0x9ea80509,
1012
+ 0xf22b017d, 0xa4173f70, 0xdd1e16c3, 0x15e0d7f9, 0x50b1b887, 0x2b9f4fd5, 0x625aba82, 0x6a017962,
1013
+ 0x2ec01b9c, 0x15488aa9, 0xd716e740, 0x40055a2c, 0x93d29a22, 0xe32dbf9a, 0x058745b9, 0x3453dc1e,
1014
+ 0xd699296e, 0x496cff6f, 0x1c9f4986, 0xdfe2ed07, 0xb87242d1, 0x19de7eae, 0x053e561a, 0x15ad6f8c,
1015
+ 0x66626c1c, 0x7154c24c, 0xea082b2a, 0x93eb2939, 0x17dcb0f0, 0x58d4f2ae, 0x9ea294fb, 0x52cf564c,
1016
+ 0x9883fe66, 0x2ec40581, 0x763953c3, 0x01d6692e, 0xd3a0c108, 0xa1e7160e, 0xe4f2dfa6, 0x693ed285,
1017
+ 0x74904698, 0x4c2b0edd, 0x4f757656, 0x5d393378, 0xa132234f, 0x3d321c5d, 0xc3f5e194, 0x4b269301,
1018
+ 0xc79f022f, 0x3c997e7e, 0x5e4f9504, 0x3ffafbbd, 0x76f7ad0e, 0x296693f4, 0x3d1fce6f, 0xc61e45be,
1019
+ 0xd3b5ab34, 0xf72bf9b7, 0x1b0434c0, 0x4e72b567, 0x5592a33d, 0xb5229301, 0xcfd2a87f, 0x60aeb767,
1020
+ 0x1814386b, 0x30bcc33d, 0x38a0c07d, 0xfd1606f2, 0xc363519b, 0x589dd390, 0x5479f8e6, 0x1cb8d647,
1021
+ 0x97fd61a9, 0xea7759f4, 0x2d57539d, 0x569a58cf, 0xe84e63ad, 0x462e1b78, 0x6580f87e, 0xf3817914,
1022
+ 0x91da55f4, 0x40a230f3, 0xd1988f35, 0xb6e318d2, 0x3ffa50bc, 0x3d40f021, 0xc3c0bdae, 0x4958c24c,
1023
+ 0x518f36b2, 0x84b1d370, 0x0fedce83, 0x878ddada, 0xf2a279c7, 0x94e01be8, 0x90716f4b, 0x954b8aa3
1024
+ ];
1025
+
1026
+ sBox[7] = [
1027
+ 0xe216300d, 0xbbddfffc, 0xa7ebdabd, 0x35648095, 0x7789f8b7, 0xe6c1121b, 0x0e241600, 0x052ce8b5,
1028
+ 0x11a9cfb0, 0xe5952f11, 0xece7990a, 0x9386d174, 0x2a42931c, 0x76e38111, 0xb12def3a, 0x37ddddfc,
1029
+ 0xde9adeb1, 0x0a0cc32c, 0xbe197029, 0x84a00940, 0xbb243a0f, 0xb4d137cf, 0xb44e79f0, 0x049eedfd,
1030
+ 0x0b15a15d, 0x480d3168, 0x8bbbde5a, 0x669ded42, 0xc7ece831, 0x3f8f95e7, 0x72df191b, 0x7580330d,
1031
+ 0x94074251, 0x5c7dcdfa, 0xabbe6d63, 0xaa402164, 0xb301d40a, 0x02e7d1ca, 0x53571dae, 0x7a3182a2,
1032
+ 0x12a8ddec, 0xfdaa335d, 0x176f43e8, 0x71fb46d4, 0x38129022, 0xce949ad4, 0xb84769ad, 0x965bd862,
1033
+ 0x82f3d055, 0x66fb9767, 0x15b80b4e, 0x1d5b47a0, 0x4cfde06f, 0xc28ec4b8, 0x57e8726e, 0x647a78fc,
1034
+ 0x99865d44, 0x608bd593, 0x6c200e03, 0x39dc5ff6, 0x5d0b00a3, 0xae63aff2, 0x7e8bd632, 0x70108c0c,
1035
+ 0xbbd35049, 0x2998df04, 0x980cf42a, 0x9b6df491, 0x9e7edd53, 0x06918548, 0x58cb7e07, 0x3b74ef2e,
1036
+ 0x522fffb1, 0xd24708cc, 0x1c7e27cd, 0xa4eb215b, 0x3cf1d2e2, 0x19b47a38, 0x424f7618, 0x35856039,
1037
+ 0x9d17dee7, 0x27eb35e6, 0xc9aff67b, 0x36baf5b8, 0x09c467cd, 0xc18910b1, 0xe11dbf7b, 0x06cd1af8,
1038
+ 0x7170c608, 0x2d5e3354, 0xd4de495a, 0x64c6d006, 0xbcc0c62c, 0x3dd00db3, 0x708f8f34, 0x77d51b42,
1039
+ 0x264f620f, 0x24b8d2bf, 0x15c1b79e, 0x46a52564, 0xf8d7e54e, 0x3e378160, 0x7895cda5, 0x859c15a5,
1040
+ 0xe6459788, 0xc37bc75f, 0xdb07ba0c, 0x0676a3ab, 0x7f229b1e, 0x31842e7b, 0x24259fd7, 0xf8bef472,
1041
+ 0x835ffcb8, 0x6df4c1f2, 0x96f5b195, 0xfd0af0fc, 0xb0fe134c, 0xe2506d3d, 0x4f9b12ea, 0xf215f225,
1042
+ 0xa223736f, 0x9fb4c428, 0x25d04979, 0x34c713f8, 0xc4618187, 0xea7a6e98, 0x7cd16efc, 0x1436876c,
1043
+ 0xf1544107, 0xbedeee14, 0x56e9af27, 0xa04aa441, 0x3cf7c899, 0x92ecbae6, 0xdd67016d, 0x151682eb,
1044
+ 0xa842eedf, 0xfdba60b4, 0xf1907b75, 0x20e3030f, 0x24d8c29e, 0xe139673b, 0xefa63fb8, 0x71873054,
1045
+ 0xb6f2cf3b, 0x9f326442, 0xcb15a4cc, 0xb01a4504, 0xf1e47d8d, 0x844a1be5, 0xbae7dfdc, 0x42cbda70,
1046
+ 0xcd7dae0a, 0x57e85b7a, 0xd53f5af6, 0x20cf4d8c, 0xcea4d428, 0x79d130a4, 0x3486ebfb, 0x33d3cddc,
1047
+ 0x77853b53, 0x37effcb5, 0xc5068778, 0xe580b3e6, 0x4e68b8f4, 0xc5c8b37e, 0x0d809ea2, 0x398feb7c,
1048
+ 0x132a4f94, 0x43b7950e, 0x2fee7d1c, 0x223613bd, 0xdd06caa2, 0x37df932b, 0xc4248289, 0xacf3ebc3,
1049
+ 0x5715f6b7, 0xef3478dd, 0xf267616f, 0xc148cbe4, 0x9052815e, 0x5e410fab, 0xb48a2465, 0x2eda7fa4,
1050
+ 0xe87b40e4, 0xe98ea084, 0x5889e9e1, 0xefd390fc, 0xdd07d35b, 0xdb485694, 0x38d7e5b2, 0x57720101,
1051
+ 0x730edebc, 0x5b643113, 0x94917e4f, 0x503c2fba, 0x646f1282, 0x7523d24a, 0xe0779695, 0xf9c17a8f,
1052
+ 0x7a5b2121, 0xd187b896, 0x29263a4d, 0xba510cdf, 0x81f47c9f, 0xad1163ed, 0xea7b5965, 0x1a00726e,
1053
+ 0x11403092, 0x00da6d77, 0x4a0cdd61, 0xad1f4603, 0x605bdfb0, 0x9eedc364, 0x22ebe6a8, 0xcee7d28a,
1054
+ 0xa0e736a0, 0x5564a6b9, 0x10853209, 0xc7eb8f37, 0x2de705ca, 0x8951570f, 0xdf09822b, 0xbd691a6c,
1055
+ 0xaa12e4f2, 0x87451c0f, 0xe0f6a27a, 0x3ada4819, 0x4cf1764f, 0x0d771c2b, 0x67cdb156, 0x350d8384,
1056
+ 0x5938fa0f, 0x42399ef3, 0x36997b07, 0x0e84093d, 0x4aa93e61, 0x8360d87b, 0x1fa98b0c, 0x1149382c,
1057
+ 0xe97625a5, 0x0614d1b7, 0x0e25244b, 0x0c768347, 0x589e8d82, 0x0d2059d1, 0xa466bb1e, 0xf8da0a82,
1058
+ 0x04f19130, 0xba6e4ec0, 0x99265164, 0x1ee7230d, 0x50b2ad80, 0xeaee6801, 0x8db2a283, 0xea8bf59e
1059
+ ];
1060
+ }
1061
+
1062
+ function CAST5(key) {
1063
+ this.cast5 = new OpenPGPSymEncCAST5();
1064
+ this.cast5.setKey(key);
1065
+
1066
+ this.encrypt = function(block) {
1067
+ return this.cast5.encrypt(block);
1068
+ };
1069
+ }
1070
+
1071
+ CAST5.blockSize = CAST5.prototype.blockSize = 8;
1072
+ CAST5.keySize = CAST5.prototype.keySize = 16;
1073
+
1074
+ /* eslint-disable no-mixed-operators, no-fallthrough */
1075
+
1076
+
1077
+ /* Modified by Recurity Labs GmbH
1078
+ *
1079
+ * Cipher.js
1080
+ * A block-cipher algorithm implementation on JavaScript
1081
+ * See Cipher.readme.txt for further information.
1082
+ *
1083
+ * Copyright(c) 2009 Atsushi Oka [ http://oka.nu/ ]
1084
+ * This script file is distributed under the LGPL
1085
+ *
1086
+ * ACKNOWLEDGMENT
1087
+ *
1088
+ * The main subroutines are written by Michiel van Everdingen.
1089
+ *
1090
+ * Michiel van Everdingen
1091
+ * http://home.versatel.nl/MAvanEverdingen/index.html
1092
+ *
1093
+ * All rights for these routines are reserved to Michiel van Everdingen.
1094
+ *
1095
+ */
1096
+
1097
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
1098
+ //Math
1099
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
1100
+
1101
+ const MAXINT = 0xFFFFFFFF;
1102
+
1103
+ function rotw(w, n) {
1104
+ return (w << n | w >>> (32 - n)) & MAXINT;
1105
+ }
1106
+
1107
+ function getW(a, i) {
1108
+ return a[i] | a[i + 1] << 8 | a[i + 2] << 16 | a[i + 3] << 24;
1109
+ }
1110
+
1111
+ function setW(a, i, w) {
1112
+ a.splice(i, 4, w & 0xFF, (w >>> 8) & 0xFF, (w >>> 16) & 0xFF, (w >>> 24) & 0xFF);
1113
+ }
1114
+
1115
+ function getB(x, n) {
1116
+ return (x >>> (n * 8)) & 0xFF;
1117
+ }
1118
+
1119
+ // //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
1120
+ // Twofish
1121
+ // //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
1122
+
1123
+ function createTwofish() {
1124
+ //
1125
+ let keyBytes = null;
1126
+ let dataBytes = null;
1127
+ let dataOffset = -1;
1128
+ // var dataLength = -1;
1129
+ // var idx2 = -1;
1130
+ //
1131
+
1132
+ let tfsKey = [];
1133
+ let tfsM = [
1134
+ [],
1135
+ [],
1136
+ [],
1137
+ []
1138
+ ];
1139
+
1140
+ function tfsInit(key) {
1141
+ keyBytes = key;
1142
+ let i;
1143
+ let a;
1144
+ let b;
1145
+ let c;
1146
+ let d;
1147
+ const meKey = [];
1148
+ const moKey = [];
1149
+ const inKey = [];
1150
+ let kLen;
1151
+ const sKey = [];
1152
+ let f01;
1153
+ let f5b;
1154
+ let fef;
1155
+
1156
+ const q0 = [
1157
+ [8, 1, 7, 13, 6, 15, 3, 2, 0, 11, 5, 9, 14, 12, 10, 4],
1158
+ [2, 8, 11, 13, 15, 7, 6, 14, 3, 1, 9, 4, 0, 10, 12, 5]
1159
+ ];
1160
+ const q1 = [
1161
+ [14, 12, 11, 8, 1, 2, 3, 5, 15, 4, 10, 6, 7, 0, 9, 13],
1162
+ [1, 14, 2, 11, 4, 12, 3, 7, 6, 13, 10, 5, 15, 9, 0, 8]
1163
+ ];
1164
+ const q2 = [
1165
+ [11, 10, 5, 14, 6, 13, 9, 0, 12, 8, 15, 3, 2, 4, 7, 1],
1166
+ [4, 12, 7, 5, 1, 6, 9, 10, 0, 14, 13, 8, 2, 11, 3, 15]
1167
+ ];
1168
+ const q3 = [
1169
+ [13, 7, 15, 4, 1, 2, 6, 14, 9, 11, 3, 0, 8, 5, 12, 10],
1170
+ [11, 9, 5, 1, 12, 3, 13, 14, 6, 4, 7, 15, 2, 0, 8, 10]
1171
+ ];
1172
+ const ror4 = [0, 8, 1, 9, 2, 10, 3, 11, 4, 12, 5, 13, 6, 14, 7, 15];
1173
+ const ashx = [0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 5, 14, 7];
1174
+ const q = [
1175
+ [],
1176
+ []
1177
+ ];
1178
+ const m = [
1179
+ [],
1180
+ [],
1181
+ [],
1182
+ []
1183
+ ];
1184
+
1185
+ function ffm5b(x) {
1186
+ return x ^ (x >> 2) ^ [0, 90, 180, 238][x & 3];
1187
+ }
1188
+
1189
+ function ffmEf(x) {
1190
+ return x ^ (x >> 1) ^ (x >> 2) ^ [0, 238, 180, 90][x & 3];
1191
+ }
1192
+
1193
+ function mdsRem(p, q) {
1194
+ let i;
1195
+ let t;
1196
+ let u;
1197
+ for (i = 0; i < 8; i++) {
1198
+ t = q >>> 24;
1199
+ q = ((q << 8) & MAXINT) | p >>> 24;
1200
+ p = (p << 8) & MAXINT;
1201
+ u = t << 1;
1202
+ if (t & 128) {
1203
+ u ^= 333;
1204
+ }
1205
+ q ^= t ^ (u << 16);
1206
+ u ^= t >>> 1;
1207
+ if (t & 1) {
1208
+ u ^= 166;
1209
+ }
1210
+ q ^= u << 24 | u << 8;
1211
+ }
1212
+ return q;
1213
+ }
1214
+
1215
+ function qp(n, x) {
1216
+ const a = x >> 4;
1217
+ const b = x & 15;
1218
+ const c = q0[n][a ^ b];
1219
+ const d = q1[n][ror4[b] ^ ashx[a]];
1220
+ return q3[n][ror4[d] ^ ashx[c]] << 4 | q2[n][c ^ d];
1221
+ }
1222
+
1223
+ function hFun(x, key) {
1224
+ let a = getB(x, 0);
1225
+ let b = getB(x, 1);
1226
+ let c = getB(x, 2);
1227
+ let d = getB(x, 3);
1228
+ switch (kLen) {
1229
+ case 4:
1230
+ a = q[1][a] ^ getB(key[3], 0);
1231
+ b = q[0][b] ^ getB(key[3], 1);
1232
+ c = q[0][c] ^ getB(key[3], 2);
1233
+ d = q[1][d] ^ getB(key[3], 3);
1234
+ case 3:
1235
+ a = q[1][a] ^ getB(key[2], 0);
1236
+ b = q[1][b] ^ getB(key[2], 1);
1237
+ c = q[0][c] ^ getB(key[2], 2);
1238
+ d = q[0][d] ^ getB(key[2], 3);
1239
+ case 2:
1240
+ a = q[0][q[0][a] ^ getB(key[1], 0)] ^ getB(key[0], 0);
1241
+ b = q[0][q[1][b] ^ getB(key[1], 1)] ^ getB(key[0], 1);
1242
+ c = q[1][q[0][c] ^ getB(key[1], 2)] ^ getB(key[0], 2);
1243
+ d = q[1][q[1][d] ^ getB(key[1], 3)] ^ getB(key[0], 3);
1244
+ }
1245
+ return m[0][a] ^ m[1][b] ^ m[2][c] ^ m[3][d];
1246
+ }
1247
+
1248
+ keyBytes = keyBytes.slice(0, 32);
1249
+ i = keyBytes.length;
1250
+ while (i !== 16 && i !== 24 && i !== 32) {
1251
+ keyBytes[i++] = 0;
1252
+ }
1253
+
1254
+ for (i = 0; i < keyBytes.length; i += 4) {
1255
+ inKey[i >> 2] = getW(keyBytes, i);
1256
+ }
1257
+ for (i = 0; i < 256; i++) {
1258
+ q[0][i] = qp(0, i);
1259
+ q[1][i] = qp(1, i);
1260
+ }
1261
+ for (i = 0; i < 256; i++) {
1262
+ f01 = q[1][i];
1263
+ f5b = ffm5b(f01);
1264
+ fef = ffmEf(f01);
1265
+ m[0][i] = f01 + (f5b << 8) + (fef << 16) + (fef << 24);
1266
+ m[2][i] = f5b + (fef << 8) + (f01 << 16) + (fef << 24);
1267
+ f01 = q[0][i];
1268
+ f5b = ffm5b(f01);
1269
+ fef = ffmEf(f01);
1270
+ m[1][i] = fef + (fef << 8) + (f5b << 16) + (f01 << 24);
1271
+ m[3][i] = f5b + (f01 << 8) + (fef << 16) + (f5b << 24);
1272
+ }
1273
+
1274
+ kLen = inKey.length / 2;
1275
+ for (i = 0; i < kLen; i++) {
1276
+ a = inKey[i + i];
1277
+ meKey[i] = a;
1278
+ b = inKey[i + i + 1];
1279
+ moKey[i] = b;
1280
+ sKey[kLen - i - 1] = mdsRem(a, b);
1281
+ }
1282
+ for (i = 0; i < 40; i += 2) {
1283
+ a = 0x1010101 * i;
1284
+ b = a + 0x1010101;
1285
+ a = hFun(a, meKey);
1286
+ b = rotw(hFun(b, moKey), 8);
1287
+ tfsKey[i] = (a + b) & MAXINT;
1288
+ tfsKey[i + 1] = rotw(a + 2 * b, 9);
1289
+ }
1290
+ for (i = 0; i < 256; i++) {
1291
+ a = b = c = d = i;
1292
+ switch (kLen) {
1293
+ case 4:
1294
+ a = q[1][a] ^ getB(sKey[3], 0);
1295
+ b = q[0][b] ^ getB(sKey[3], 1);
1296
+ c = q[0][c] ^ getB(sKey[3], 2);
1297
+ d = q[1][d] ^ getB(sKey[3], 3);
1298
+ case 3:
1299
+ a = q[1][a] ^ getB(sKey[2], 0);
1300
+ b = q[1][b] ^ getB(sKey[2], 1);
1301
+ c = q[0][c] ^ getB(sKey[2], 2);
1302
+ d = q[0][d] ^ getB(sKey[2], 3);
1303
+ case 2:
1304
+ tfsM[0][i] = m[0][q[0][q[0][a] ^ getB(sKey[1], 0)] ^ getB(sKey[0], 0)];
1305
+ tfsM[1][i] = m[1][q[0][q[1][b] ^ getB(sKey[1], 1)] ^ getB(sKey[0], 1)];
1306
+ tfsM[2][i] = m[2][q[1][q[0][c] ^ getB(sKey[1], 2)] ^ getB(sKey[0], 2)];
1307
+ tfsM[3][i] = m[3][q[1][q[1][d] ^ getB(sKey[1], 3)] ^ getB(sKey[0], 3)];
1308
+ }
1309
+ }
1310
+ }
1311
+
1312
+ function tfsG0(x) {
1313
+ return tfsM[0][getB(x, 0)] ^ tfsM[1][getB(x, 1)] ^ tfsM[2][getB(x, 2)] ^ tfsM[3][getB(x, 3)];
1314
+ }
1315
+
1316
+ function tfsG1(x) {
1317
+ return tfsM[0][getB(x, 3)] ^ tfsM[1][getB(x, 0)] ^ tfsM[2][getB(x, 1)] ^ tfsM[3][getB(x, 2)];
1318
+ }
1319
+
1320
+ function tfsFrnd(r, blk) {
1321
+ let a = tfsG0(blk[0]);
1322
+ let b = tfsG1(blk[1]);
1323
+ blk[2] = rotw(blk[2] ^ (a + b + tfsKey[4 * r + 8]) & MAXINT, 31);
1324
+ blk[3] = rotw(blk[3], 1) ^ (a + 2 * b + tfsKey[4 * r + 9]) & MAXINT;
1325
+ a = tfsG0(blk[2]);
1326
+ b = tfsG1(blk[3]);
1327
+ blk[0] = rotw(blk[0] ^ (a + b + tfsKey[4 * r + 10]) & MAXINT, 31);
1328
+ blk[1] = rotw(blk[1], 1) ^ (a + 2 * b + tfsKey[4 * r + 11]) & MAXINT;
1329
+ }
1330
+
1331
+ function tfsIrnd(i, blk) {
1332
+ let a = tfsG0(blk[0]);
1333
+ let b = tfsG1(blk[1]);
1334
+ blk[2] = rotw(blk[2], 1) ^ (a + b + tfsKey[4 * i + 10]) & MAXINT;
1335
+ blk[3] = rotw(blk[3] ^ (a + 2 * b + tfsKey[4 * i + 11]) & MAXINT, 31);
1336
+ a = tfsG0(blk[2]);
1337
+ b = tfsG1(blk[3]);
1338
+ blk[0] = rotw(blk[0], 1) ^ (a + b + tfsKey[4 * i + 8]) & MAXINT;
1339
+ blk[1] = rotw(blk[1] ^ (a + 2 * b + tfsKey[4 * i + 9]) & MAXINT, 31);
1340
+ }
1341
+
1342
+ function tfsClose() {
1343
+ tfsKey = [];
1344
+ tfsM = [
1345
+ [],
1346
+ [],
1347
+ [],
1348
+ []
1349
+ ];
1350
+ }
1351
+
1352
+ function tfsEncrypt(data, offset) {
1353
+ dataBytes = data;
1354
+ dataOffset = offset;
1355
+ const blk = [getW(dataBytes, dataOffset) ^ tfsKey[0],
1356
+ getW(dataBytes, dataOffset + 4) ^ tfsKey[1],
1357
+ getW(dataBytes, dataOffset + 8) ^ tfsKey[2],
1358
+ getW(dataBytes, dataOffset + 12) ^ tfsKey[3]];
1359
+ for (let j = 0; j < 8; j++) {
1360
+ tfsFrnd(j, blk);
1361
+ }
1362
+ setW(dataBytes, dataOffset, blk[2] ^ tfsKey[4]);
1363
+ setW(dataBytes, dataOffset + 4, blk[3] ^ tfsKey[5]);
1364
+ setW(dataBytes, dataOffset + 8, blk[0] ^ tfsKey[6]);
1365
+ setW(dataBytes, dataOffset + 12, blk[1] ^ tfsKey[7]);
1366
+ dataOffset += 16;
1367
+ return dataBytes;
1368
+ }
1369
+
1370
+ function tfsDecrypt(data, offset) {
1371
+ dataBytes = data;
1372
+ dataOffset = offset;
1373
+ const blk = [getW(dataBytes, dataOffset) ^ tfsKey[4],
1374
+ getW(dataBytes, dataOffset + 4) ^ tfsKey[5],
1375
+ getW(dataBytes, dataOffset + 8) ^ tfsKey[6],
1376
+ getW(dataBytes, dataOffset + 12) ^ tfsKey[7]];
1377
+ for (let j = 7; j >= 0; j--) {
1378
+ tfsIrnd(j, blk);
1379
+ }
1380
+ setW(dataBytes, dataOffset, blk[2] ^ tfsKey[0]);
1381
+ setW(dataBytes, dataOffset + 4, blk[3] ^ tfsKey[1]);
1382
+ setW(dataBytes, dataOffset + 8, blk[0] ^ tfsKey[2]);
1383
+ setW(dataBytes, dataOffset + 12, blk[1] ^ tfsKey[3]);
1384
+ dataOffset += 16;
1385
+ }
1386
+
1387
+ // added by Recurity Labs
1388
+
1389
+ function tfsFinal() {
1390
+ return dataBytes;
1391
+ }
1392
+
1393
+ return {
1394
+ name: 'twofish',
1395
+ blocksize: 128 / 8,
1396
+ open: tfsInit,
1397
+ close: tfsClose,
1398
+ encrypt: tfsEncrypt,
1399
+ decrypt: tfsDecrypt,
1400
+ // added by Recurity Labs
1401
+ finalize: tfsFinal
1402
+ };
1403
+ }
1404
+
1405
+ // added by Recurity Labs
1406
+
1407
+ function TF(key) {
1408
+ this.tf = createTwofish();
1409
+ this.tf.open(Array.from(key), 0);
1410
+
1411
+ this.encrypt = function(block) {
1412
+ return this.tf.encrypt(Array.from(block), 0);
1413
+ };
1414
+ }
1415
+
1416
+ TF.keySize = TF.prototype.keySize = 32;
1417
+ TF.blockSize = TF.prototype.blockSize = 16;
1418
+
1419
+ /* Modified by Recurity Labs GmbH
1420
+ *
1421
+ * Originally written by nklein software (nklein.com)
1422
+ */
1423
+
1424
+ /*
1425
+ * Javascript implementation based on Bruce Schneier's reference implementation.
1426
+ *
1427
+ *
1428
+ * The constructor doesn't do much of anything. It's just here
1429
+ * so we can start defining properties and methods and such.
1430
+ */
1431
+ function Blowfish() {}
1432
+
1433
+ /*
1434
+ * Declare the block size so that protocols know what size
1435
+ * Initialization Vector (IV) they will need.
1436
+ */
1437
+ Blowfish.prototype.BLOCKSIZE = 8;
1438
+
1439
+ /*
1440
+ * These are the default SBOXES.
1441
+ */
1442
+ Blowfish.prototype.SBOXES = [
1443
+ [
1444
+ 0xd1310ba6, 0x98dfb5ac, 0x2ffd72db, 0xd01adfb7, 0xb8e1afed, 0x6a267e96,
1445
+ 0xba7c9045, 0xf12c7f99, 0x24a19947, 0xb3916cf7, 0x0801f2e2, 0x858efc16,
1446
+ 0x636920d8, 0x71574e69, 0xa458fea3, 0xf4933d7e, 0x0d95748f, 0x728eb658,
1447
+ 0x718bcd58, 0x82154aee, 0x7b54a41d, 0xc25a59b5, 0x9c30d539, 0x2af26013,
1448
+ 0xc5d1b023, 0x286085f0, 0xca417918, 0xb8db38ef, 0x8e79dcb0, 0x603a180e,
1449
+ 0x6c9e0e8b, 0xb01e8a3e, 0xd71577c1, 0xbd314b27, 0x78af2fda, 0x55605c60,
1450
+ 0xe65525f3, 0xaa55ab94, 0x57489862, 0x63e81440, 0x55ca396a, 0x2aab10b6,
1451
+ 0xb4cc5c34, 0x1141e8ce, 0xa15486af, 0x7c72e993, 0xb3ee1411, 0x636fbc2a,
1452
+ 0x2ba9c55d, 0x741831f6, 0xce5c3e16, 0x9b87931e, 0xafd6ba33, 0x6c24cf5c,
1453
+ 0x7a325381, 0x28958677, 0x3b8f4898, 0x6b4bb9af, 0xc4bfe81b, 0x66282193,
1454
+ 0x61d809cc, 0xfb21a991, 0x487cac60, 0x5dec8032, 0xef845d5d, 0xe98575b1,
1455
+ 0xdc262302, 0xeb651b88, 0x23893e81, 0xd396acc5, 0x0f6d6ff3, 0x83f44239,
1456
+ 0x2e0b4482, 0xa4842004, 0x69c8f04a, 0x9e1f9b5e, 0x21c66842, 0xf6e96c9a,
1457
+ 0x670c9c61, 0xabd388f0, 0x6a51a0d2, 0xd8542f68, 0x960fa728, 0xab5133a3,
1458
+ 0x6eef0b6c, 0x137a3be4, 0xba3bf050, 0x7efb2a98, 0xa1f1651d, 0x39af0176,
1459
+ 0x66ca593e, 0x82430e88, 0x8cee8619, 0x456f9fb4, 0x7d84a5c3, 0x3b8b5ebe,
1460
+ 0xe06f75d8, 0x85c12073, 0x401a449f, 0x56c16aa6, 0x4ed3aa62, 0x363f7706,
1461
+ 0x1bfedf72, 0x429b023d, 0x37d0d724, 0xd00a1248, 0xdb0fead3, 0x49f1c09b,
1462
+ 0x075372c9, 0x80991b7b, 0x25d479d8, 0xf6e8def7, 0xe3fe501a, 0xb6794c3b,
1463
+ 0x976ce0bd, 0x04c006ba, 0xc1a94fb6, 0x409f60c4, 0x5e5c9ec2, 0x196a2463,
1464
+ 0x68fb6faf, 0x3e6c53b5, 0x1339b2eb, 0x3b52ec6f, 0x6dfc511f, 0x9b30952c,
1465
+ 0xcc814544, 0xaf5ebd09, 0xbee3d004, 0xde334afd, 0x660f2807, 0x192e4bb3,
1466
+ 0xc0cba857, 0x45c8740f, 0xd20b5f39, 0xb9d3fbdb, 0x5579c0bd, 0x1a60320a,
1467
+ 0xd6a100c6, 0x402c7279, 0x679f25fe, 0xfb1fa3cc, 0x8ea5e9f8, 0xdb3222f8,
1468
+ 0x3c7516df, 0xfd616b15, 0x2f501ec8, 0xad0552ab, 0x323db5fa, 0xfd238760,
1469
+ 0x53317b48, 0x3e00df82, 0x9e5c57bb, 0xca6f8ca0, 0x1a87562e, 0xdf1769db,
1470
+ 0xd542a8f6, 0x287effc3, 0xac6732c6, 0x8c4f5573, 0x695b27b0, 0xbbca58c8,
1471
+ 0xe1ffa35d, 0xb8f011a0, 0x10fa3d98, 0xfd2183b8, 0x4afcb56c, 0x2dd1d35b,
1472
+ 0x9a53e479, 0xb6f84565, 0xd28e49bc, 0x4bfb9790, 0xe1ddf2da, 0xa4cb7e33,
1473
+ 0x62fb1341, 0xcee4c6e8, 0xef20cada, 0x36774c01, 0xd07e9efe, 0x2bf11fb4,
1474
+ 0x95dbda4d, 0xae909198, 0xeaad8e71, 0x6b93d5a0, 0xd08ed1d0, 0xafc725e0,
1475
+ 0x8e3c5b2f, 0x8e7594b7, 0x8ff6e2fb, 0xf2122b64, 0x8888b812, 0x900df01c,
1476
+ 0x4fad5ea0, 0x688fc31c, 0xd1cff191, 0xb3a8c1ad, 0x2f2f2218, 0xbe0e1777,
1477
+ 0xea752dfe, 0x8b021fa1, 0xe5a0cc0f, 0xb56f74e8, 0x18acf3d6, 0xce89e299,
1478
+ 0xb4a84fe0, 0xfd13e0b7, 0x7cc43b81, 0xd2ada8d9, 0x165fa266, 0x80957705,
1479
+ 0x93cc7314, 0x211a1477, 0xe6ad2065, 0x77b5fa86, 0xc75442f5, 0xfb9d35cf,
1480
+ 0xebcdaf0c, 0x7b3e89a0, 0xd6411bd3, 0xae1e7e49, 0x00250e2d, 0x2071b35e,
1481
+ 0x226800bb, 0x57b8e0af, 0x2464369b, 0xf009b91e, 0x5563911d, 0x59dfa6aa,
1482
+ 0x78c14389, 0xd95a537f, 0x207d5ba2, 0x02e5b9c5, 0x83260376, 0x6295cfa9,
1483
+ 0x11c81968, 0x4e734a41, 0xb3472dca, 0x7b14a94a, 0x1b510052, 0x9a532915,
1484
+ 0xd60f573f, 0xbc9bc6e4, 0x2b60a476, 0x81e67400, 0x08ba6fb5, 0x571be91f,
1485
+ 0xf296ec6b, 0x2a0dd915, 0xb6636521, 0xe7b9f9b6, 0xff34052e, 0xc5855664,
1486
+ 0x53b02d5d, 0xa99f8fa1, 0x08ba4799, 0x6e85076a
1487
+ ],
1488
+ [
1489
+ 0x4b7a70e9, 0xb5b32944, 0xdb75092e, 0xc4192623, 0xad6ea6b0, 0x49a7df7d,
1490
+ 0x9cee60b8, 0x8fedb266, 0xecaa8c71, 0x699a17ff, 0x5664526c, 0xc2b19ee1,
1491
+ 0x193602a5, 0x75094c29, 0xa0591340, 0xe4183a3e, 0x3f54989a, 0x5b429d65,
1492
+ 0x6b8fe4d6, 0x99f73fd6, 0xa1d29c07, 0xefe830f5, 0x4d2d38e6, 0xf0255dc1,
1493
+ 0x4cdd2086, 0x8470eb26, 0x6382e9c6, 0x021ecc5e, 0x09686b3f, 0x3ebaefc9,
1494
+ 0x3c971814, 0x6b6a70a1, 0x687f3584, 0x52a0e286, 0xb79c5305, 0xaa500737,
1495
+ 0x3e07841c, 0x7fdeae5c, 0x8e7d44ec, 0x5716f2b8, 0xb03ada37, 0xf0500c0d,
1496
+ 0xf01c1f04, 0x0200b3ff, 0xae0cf51a, 0x3cb574b2, 0x25837a58, 0xdc0921bd,
1497
+ 0xd19113f9, 0x7ca92ff6, 0x94324773, 0x22f54701, 0x3ae5e581, 0x37c2dadc,
1498
+ 0xc8b57634, 0x9af3dda7, 0xa9446146, 0x0fd0030e, 0xecc8c73e, 0xa4751e41,
1499
+ 0xe238cd99, 0x3bea0e2f, 0x3280bba1, 0x183eb331, 0x4e548b38, 0x4f6db908,
1500
+ 0x6f420d03, 0xf60a04bf, 0x2cb81290, 0x24977c79, 0x5679b072, 0xbcaf89af,
1501
+ 0xde9a771f, 0xd9930810, 0xb38bae12, 0xdccf3f2e, 0x5512721f, 0x2e6b7124,
1502
+ 0x501adde6, 0x9f84cd87, 0x7a584718, 0x7408da17, 0xbc9f9abc, 0xe94b7d8c,
1503
+ 0xec7aec3a, 0xdb851dfa, 0x63094366, 0xc464c3d2, 0xef1c1847, 0x3215d908,
1504
+ 0xdd433b37, 0x24c2ba16, 0x12a14d43, 0x2a65c451, 0x50940002, 0x133ae4dd,
1505
+ 0x71dff89e, 0x10314e55, 0x81ac77d6, 0x5f11199b, 0x043556f1, 0xd7a3c76b,
1506
+ 0x3c11183b, 0x5924a509, 0xf28fe6ed, 0x97f1fbfa, 0x9ebabf2c, 0x1e153c6e,
1507
+ 0x86e34570, 0xeae96fb1, 0x860e5e0a, 0x5a3e2ab3, 0x771fe71c, 0x4e3d06fa,
1508
+ 0x2965dcb9, 0x99e71d0f, 0x803e89d6, 0x5266c825, 0x2e4cc978, 0x9c10b36a,
1509
+ 0xc6150eba, 0x94e2ea78, 0xa5fc3c53, 0x1e0a2df4, 0xf2f74ea7, 0x361d2b3d,
1510
+ 0x1939260f, 0x19c27960, 0x5223a708, 0xf71312b6, 0xebadfe6e, 0xeac31f66,
1511
+ 0xe3bc4595, 0xa67bc883, 0xb17f37d1, 0x018cff28, 0xc332ddef, 0xbe6c5aa5,
1512
+ 0x65582185, 0x68ab9802, 0xeecea50f, 0xdb2f953b, 0x2aef7dad, 0x5b6e2f84,
1513
+ 0x1521b628, 0x29076170, 0xecdd4775, 0x619f1510, 0x13cca830, 0xeb61bd96,
1514
+ 0x0334fe1e, 0xaa0363cf, 0xb5735c90, 0x4c70a239, 0xd59e9e0b, 0xcbaade14,
1515
+ 0xeecc86bc, 0x60622ca7, 0x9cab5cab, 0xb2f3846e, 0x648b1eaf, 0x19bdf0ca,
1516
+ 0xa02369b9, 0x655abb50, 0x40685a32, 0x3c2ab4b3, 0x319ee9d5, 0xc021b8f7,
1517
+ 0x9b540b19, 0x875fa099, 0x95f7997e, 0x623d7da8, 0xf837889a, 0x97e32d77,
1518
+ 0x11ed935f, 0x16681281, 0x0e358829, 0xc7e61fd6, 0x96dedfa1, 0x7858ba99,
1519
+ 0x57f584a5, 0x1b227263, 0x9b83c3ff, 0x1ac24696, 0xcdb30aeb, 0x532e3054,
1520
+ 0x8fd948e4, 0x6dbc3128, 0x58ebf2ef, 0x34c6ffea, 0xfe28ed61, 0xee7c3c73,
1521
+ 0x5d4a14d9, 0xe864b7e3, 0x42105d14, 0x203e13e0, 0x45eee2b6, 0xa3aaabea,
1522
+ 0xdb6c4f15, 0xfacb4fd0, 0xc742f442, 0xef6abbb5, 0x654f3b1d, 0x41cd2105,
1523
+ 0xd81e799e, 0x86854dc7, 0xe44b476a, 0x3d816250, 0xcf62a1f2, 0x5b8d2646,
1524
+ 0xfc8883a0, 0xc1c7b6a3, 0x7f1524c3, 0x69cb7492, 0x47848a0b, 0x5692b285,
1525
+ 0x095bbf00, 0xad19489d, 0x1462b174, 0x23820e00, 0x58428d2a, 0x0c55f5ea,
1526
+ 0x1dadf43e, 0x233f7061, 0x3372f092, 0x8d937e41, 0xd65fecf1, 0x6c223bdb,
1527
+ 0x7cde3759, 0xcbee7460, 0x4085f2a7, 0xce77326e, 0xa6078084, 0x19f8509e,
1528
+ 0xe8efd855, 0x61d99735, 0xa969a7aa, 0xc50c06c2, 0x5a04abfc, 0x800bcadc,
1529
+ 0x9e447a2e, 0xc3453484, 0xfdd56705, 0x0e1e9ec9, 0xdb73dbd3, 0x105588cd,
1530
+ 0x675fda79, 0xe3674340, 0xc5c43465, 0x713e38d8, 0x3d28f89e, 0xf16dff20,
1531
+ 0x153e21e7, 0x8fb03d4a, 0xe6e39f2b, 0xdb83adf7
1532
+ ],
1533
+ [
1534
+ 0xe93d5a68, 0x948140f7, 0xf64c261c, 0x94692934, 0x411520f7, 0x7602d4f7,
1535
+ 0xbcf46b2e, 0xd4a20068, 0xd4082471, 0x3320f46a, 0x43b7d4b7, 0x500061af,
1536
+ 0x1e39f62e, 0x97244546, 0x14214f74, 0xbf8b8840, 0x4d95fc1d, 0x96b591af,
1537
+ 0x70f4ddd3, 0x66a02f45, 0xbfbc09ec, 0x03bd9785, 0x7fac6dd0, 0x31cb8504,
1538
+ 0x96eb27b3, 0x55fd3941, 0xda2547e6, 0xabca0a9a, 0x28507825, 0x530429f4,
1539
+ 0x0a2c86da, 0xe9b66dfb, 0x68dc1462, 0xd7486900, 0x680ec0a4, 0x27a18dee,
1540
+ 0x4f3ffea2, 0xe887ad8c, 0xb58ce006, 0x7af4d6b6, 0xaace1e7c, 0xd3375fec,
1541
+ 0xce78a399, 0x406b2a42, 0x20fe9e35, 0xd9f385b9, 0xee39d7ab, 0x3b124e8b,
1542
+ 0x1dc9faf7, 0x4b6d1856, 0x26a36631, 0xeae397b2, 0x3a6efa74, 0xdd5b4332,
1543
+ 0x6841e7f7, 0xca7820fb, 0xfb0af54e, 0xd8feb397, 0x454056ac, 0xba489527,
1544
+ 0x55533a3a, 0x20838d87, 0xfe6ba9b7, 0xd096954b, 0x55a867bc, 0xa1159a58,
1545
+ 0xcca92963, 0x99e1db33, 0xa62a4a56, 0x3f3125f9, 0x5ef47e1c, 0x9029317c,
1546
+ 0xfdf8e802, 0x04272f70, 0x80bb155c, 0x05282ce3, 0x95c11548, 0xe4c66d22,
1547
+ 0x48c1133f, 0xc70f86dc, 0x07f9c9ee, 0x41041f0f, 0x404779a4, 0x5d886e17,
1548
+ 0x325f51eb, 0xd59bc0d1, 0xf2bcc18f, 0x41113564, 0x257b7834, 0x602a9c60,
1549
+ 0xdff8e8a3, 0x1f636c1b, 0x0e12b4c2, 0x02e1329e, 0xaf664fd1, 0xcad18115,
1550
+ 0x6b2395e0, 0x333e92e1, 0x3b240b62, 0xeebeb922, 0x85b2a20e, 0xe6ba0d99,
1551
+ 0xde720c8c, 0x2da2f728, 0xd0127845, 0x95b794fd, 0x647d0862, 0xe7ccf5f0,
1552
+ 0x5449a36f, 0x877d48fa, 0xc39dfd27, 0xf33e8d1e, 0x0a476341, 0x992eff74,
1553
+ 0x3a6f6eab, 0xf4f8fd37, 0xa812dc60, 0xa1ebddf8, 0x991be14c, 0xdb6e6b0d,
1554
+ 0xc67b5510, 0x6d672c37, 0x2765d43b, 0xdcd0e804, 0xf1290dc7, 0xcc00ffa3,
1555
+ 0xb5390f92, 0x690fed0b, 0x667b9ffb, 0xcedb7d9c, 0xa091cf0b, 0xd9155ea3,
1556
+ 0xbb132f88, 0x515bad24, 0x7b9479bf, 0x763bd6eb, 0x37392eb3, 0xcc115979,
1557
+ 0x8026e297, 0xf42e312d, 0x6842ada7, 0xc66a2b3b, 0x12754ccc, 0x782ef11c,
1558
+ 0x6a124237, 0xb79251e7, 0x06a1bbe6, 0x4bfb6350, 0x1a6b1018, 0x11caedfa,
1559
+ 0x3d25bdd8, 0xe2e1c3c9, 0x44421659, 0x0a121386, 0xd90cec6e, 0xd5abea2a,
1560
+ 0x64af674e, 0xda86a85f, 0xbebfe988, 0x64e4c3fe, 0x9dbc8057, 0xf0f7c086,
1561
+ 0x60787bf8, 0x6003604d, 0xd1fd8346, 0xf6381fb0, 0x7745ae04, 0xd736fccc,
1562
+ 0x83426b33, 0xf01eab71, 0xb0804187, 0x3c005e5f, 0x77a057be, 0xbde8ae24,
1563
+ 0x55464299, 0xbf582e61, 0x4e58f48f, 0xf2ddfda2, 0xf474ef38, 0x8789bdc2,
1564
+ 0x5366f9c3, 0xc8b38e74, 0xb475f255, 0x46fcd9b9, 0x7aeb2661, 0x8b1ddf84,
1565
+ 0x846a0e79, 0x915f95e2, 0x466e598e, 0x20b45770, 0x8cd55591, 0xc902de4c,
1566
+ 0xb90bace1, 0xbb8205d0, 0x11a86248, 0x7574a99e, 0xb77f19b6, 0xe0a9dc09,
1567
+ 0x662d09a1, 0xc4324633, 0xe85a1f02, 0x09f0be8c, 0x4a99a025, 0x1d6efe10,
1568
+ 0x1ab93d1d, 0x0ba5a4df, 0xa186f20f, 0x2868f169, 0xdcb7da83, 0x573906fe,
1569
+ 0xa1e2ce9b, 0x4fcd7f52, 0x50115e01, 0xa70683fa, 0xa002b5c4, 0x0de6d027,
1570
+ 0x9af88c27, 0x773f8641, 0xc3604c06, 0x61a806b5, 0xf0177a28, 0xc0f586e0,
1571
+ 0x006058aa, 0x30dc7d62, 0x11e69ed7, 0x2338ea63, 0x53c2dd94, 0xc2c21634,
1572
+ 0xbbcbee56, 0x90bcb6de, 0xebfc7da1, 0xce591d76, 0x6f05e409, 0x4b7c0188,
1573
+ 0x39720a3d, 0x7c927c24, 0x86e3725f, 0x724d9db9, 0x1ac15bb4, 0xd39eb8fc,
1574
+ 0xed545578, 0x08fca5b5, 0xd83d7cd3, 0x4dad0fc4, 0x1e50ef5e, 0xb161e6f8,
1575
+ 0xa28514d9, 0x6c51133c, 0x6fd5c7e7, 0x56e14ec4, 0x362abfce, 0xddc6c837,
1576
+ 0xd79a3234, 0x92638212, 0x670efa8e, 0x406000e0
1577
+ ],
1578
+ [
1579
+ 0x3a39ce37, 0xd3faf5cf, 0xabc27737, 0x5ac52d1b, 0x5cb0679e, 0x4fa33742,
1580
+ 0xd3822740, 0x99bc9bbe, 0xd5118e9d, 0xbf0f7315, 0xd62d1c7e, 0xc700c47b,
1581
+ 0xb78c1b6b, 0x21a19045, 0xb26eb1be, 0x6a366eb4, 0x5748ab2f, 0xbc946e79,
1582
+ 0xc6a376d2, 0x6549c2c8, 0x530ff8ee, 0x468dde7d, 0xd5730a1d, 0x4cd04dc6,
1583
+ 0x2939bbdb, 0xa9ba4650, 0xac9526e8, 0xbe5ee304, 0xa1fad5f0, 0x6a2d519a,
1584
+ 0x63ef8ce2, 0x9a86ee22, 0xc089c2b8, 0x43242ef6, 0xa51e03aa, 0x9cf2d0a4,
1585
+ 0x83c061ba, 0x9be96a4d, 0x8fe51550, 0xba645bd6, 0x2826a2f9, 0xa73a3ae1,
1586
+ 0x4ba99586, 0xef5562e9, 0xc72fefd3, 0xf752f7da, 0x3f046f69, 0x77fa0a59,
1587
+ 0x80e4a915, 0x87b08601, 0x9b09e6ad, 0x3b3ee593, 0xe990fd5a, 0x9e34d797,
1588
+ 0x2cf0b7d9, 0x022b8b51, 0x96d5ac3a, 0x017da67d, 0xd1cf3ed6, 0x7c7d2d28,
1589
+ 0x1f9f25cf, 0xadf2b89b, 0x5ad6b472, 0x5a88f54c, 0xe029ac71, 0xe019a5e6,
1590
+ 0x47b0acfd, 0xed93fa9b, 0xe8d3c48d, 0x283b57cc, 0xf8d56629, 0x79132e28,
1591
+ 0x785f0191, 0xed756055, 0xf7960e44, 0xe3d35e8c, 0x15056dd4, 0x88f46dba,
1592
+ 0x03a16125, 0x0564f0bd, 0xc3eb9e15, 0x3c9057a2, 0x97271aec, 0xa93a072a,
1593
+ 0x1b3f6d9b, 0x1e6321f5, 0xf59c66fb, 0x26dcf319, 0x7533d928, 0xb155fdf5,
1594
+ 0x03563482, 0x8aba3cbb, 0x28517711, 0xc20ad9f8, 0xabcc5167, 0xccad925f,
1595
+ 0x4de81751, 0x3830dc8e, 0x379d5862, 0x9320f991, 0xea7a90c2, 0xfb3e7bce,
1596
+ 0x5121ce64, 0x774fbe32, 0xa8b6e37e, 0xc3293d46, 0x48de5369, 0x6413e680,
1597
+ 0xa2ae0810, 0xdd6db224, 0x69852dfd, 0x09072166, 0xb39a460a, 0x6445c0dd,
1598
+ 0x586cdecf, 0x1c20c8ae, 0x5bbef7dd, 0x1b588d40, 0xccd2017f, 0x6bb4e3bb,
1599
+ 0xdda26a7e, 0x3a59ff45, 0x3e350a44, 0xbcb4cdd5, 0x72eacea8, 0xfa6484bb,
1600
+ 0x8d6612ae, 0xbf3c6f47, 0xd29be463, 0x542f5d9e, 0xaec2771b, 0xf64e6370,
1601
+ 0x740e0d8d, 0xe75b1357, 0xf8721671, 0xaf537d5d, 0x4040cb08, 0x4eb4e2cc,
1602
+ 0x34d2466a, 0x0115af84, 0xe1b00428, 0x95983a1d, 0x06b89fb4, 0xce6ea048,
1603
+ 0x6f3f3b82, 0x3520ab82, 0x011a1d4b, 0x277227f8, 0x611560b1, 0xe7933fdc,
1604
+ 0xbb3a792b, 0x344525bd, 0xa08839e1, 0x51ce794b, 0x2f32c9b7, 0xa01fbac9,
1605
+ 0xe01cc87e, 0xbcc7d1f6, 0xcf0111c3, 0xa1e8aac7, 0x1a908749, 0xd44fbd9a,
1606
+ 0xd0dadecb, 0xd50ada38, 0x0339c32a, 0xc6913667, 0x8df9317c, 0xe0b12b4f,
1607
+ 0xf79e59b7, 0x43f5bb3a, 0xf2d519ff, 0x27d9459c, 0xbf97222c, 0x15e6fc2a,
1608
+ 0x0f91fc71, 0x9b941525, 0xfae59361, 0xceb69ceb, 0xc2a86459, 0x12baa8d1,
1609
+ 0xb6c1075e, 0xe3056a0c, 0x10d25065, 0xcb03a442, 0xe0ec6e0e, 0x1698db3b,
1610
+ 0x4c98a0be, 0x3278e964, 0x9f1f9532, 0xe0d392df, 0xd3a0342b, 0x8971f21e,
1611
+ 0x1b0a7441, 0x4ba3348c, 0xc5be7120, 0xc37632d8, 0xdf359f8d, 0x9b992f2e,
1612
+ 0xe60b6f47, 0x0fe3f11d, 0xe54cda54, 0x1edad891, 0xce6279cf, 0xcd3e7e6f,
1613
+ 0x1618b166, 0xfd2c1d05, 0x848fd2c5, 0xf6fb2299, 0xf523f357, 0xa6327623,
1614
+ 0x93a83531, 0x56cccd02, 0xacf08162, 0x5a75ebb5, 0x6e163697, 0x88d273cc,
1615
+ 0xde966292, 0x81b949d0, 0x4c50901b, 0x71c65614, 0xe6c6c7bd, 0x327a140a,
1616
+ 0x45e1d006, 0xc3f27b9a, 0xc9aa53fd, 0x62a80f00, 0xbb25bfe2, 0x35bdd2f6,
1617
+ 0x71126905, 0xb2040222, 0xb6cbcf7c, 0xcd769c2b, 0x53113ec0, 0x1640e3d3,
1618
+ 0x38abbd60, 0x2547adf0, 0xba38209c, 0xf746ce76, 0x77afa1c5, 0x20756060,
1619
+ 0x85cbfe4e, 0x8ae88dd8, 0x7aaaf9b0, 0x4cf9aa7e, 0x1948c25c, 0x02fb8a8c,
1620
+ 0x01c36ae4, 0xd6ebe1f9, 0x90d4f869, 0xa65cdea0, 0x3f09252d, 0xc208e69f,
1621
+ 0xb74e6132, 0xce77e25b, 0x578fdfe3, 0x3ac372e6
1622
+ ]
1623
+ ];
1624
+
1625
+ //*
1626
+ //* This is the default PARRAY
1627
+ //*
1628
+ Blowfish.prototype.PARRAY = [
1629
+ 0x243f6a88, 0x85a308d3, 0x13198a2e, 0x03707344, 0xa4093822, 0x299f31d0,
1630
+ 0x082efa98, 0xec4e6c89, 0x452821e6, 0x38d01377, 0xbe5466cf, 0x34e90c6c,
1631
+ 0xc0ac29b7, 0xc97c50dd, 0x3f84d5b5, 0xb5470917, 0x9216d5d9, 0x8979fb1b
1632
+ ];
1633
+
1634
+ //*
1635
+ //* This is the number of rounds the cipher will go
1636
+ //*
1637
+ Blowfish.prototype.NN = 16;
1638
+
1639
+ //*
1640
+ //* This function is needed to get rid of problems
1641
+ //* with the high-bit getting set. If we don't do
1642
+ //* this, then sometimes ( aa & 0x00FFFFFFFF ) is not
1643
+ //* equal to ( bb & 0x00FFFFFFFF ) even when they
1644
+ //* agree bit-for-bit for the first 32 bits.
1645
+ //*
1646
+ Blowfish.prototype._clean = function(xx) {
1647
+ if (xx < 0) {
1648
+ const yy = xx & 0x7FFFFFFF;
1649
+ xx = yy + 0x80000000;
1650
+ }
1651
+ return xx;
1652
+ };
1653
+
1654
+ //*
1655
+ //* This is the mixing function that uses the sboxes
1656
+ //*
1657
+ Blowfish.prototype._F = function(xx) {
1658
+ let yy;
1659
+
1660
+ const dd = xx & 0x00FF;
1661
+ xx >>>= 8;
1662
+ const cc = xx & 0x00FF;
1663
+ xx >>>= 8;
1664
+ const bb = xx & 0x00FF;
1665
+ xx >>>= 8;
1666
+ const aa = xx & 0x00FF;
1667
+
1668
+ yy = this.sboxes[0][aa] + this.sboxes[1][bb];
1669
+ yy ^= this.sboxes[2][cc];
1670
+ yy += this.sboxes[3][dd];
1671
+
1672
+ return yy;
1673
+ };
1674
+
1675
+ //*
1676
+ //* This method takes an array with two values, left and right
1677
+ //* and does NN rounds of Blowfish on them.
1678
+ //*
1679
+ Blowfish.prototype._encryptBlock = function(vals) {
1680
+ let dataL = vals[0];
1681
+ let dataR = vals[1];
1682
+
1683
+ let ii;
1684
+
1685
+ for (ii = 0; ii < this.NN; ++ii) {
1686
+ dataL ^= this.parray[ii];
1687
+ dataR = this._F(dataL) ^ dataR;
1688
+
1689
+ const tmp = dataL;
1690
+ dataL = dataR;
1691
+ dataR = tmp;
1692
+ }
1693
+
1694
+ dataL ^= this.parray[this.NN + 0];
1695
+ dataR ^= this.parray[this.NN + 1];
1696
+
1697
+ vals[0] = this._clean(dataR);
1698
+ vals[1] = this._clean(dataL);
1699
+ };
1700
+
1701
+ //*
1702
+ //* This method takes a vector of numbers and turns them
1703
+ //* into long words so that they can be processed by the
1704
+ //* real algorithm.
1705
+ //*
1706
+ //* Maybe I should make the real algorithm above take a vector
1707
+ //* instead. That will involve more looping, but it won't require
1708
+ //* the F() method to deconstruct the vector.
1709
+ //*
1710
+ Blowfish.prototype.encryptBlock = function(vector) {
1711
+ let ii;
1712
+ const vals = [0, 0];
1713
+ const off = this.BLOCKSIZE / 2;
1714
+ for (ii = 0; ii < this.BLOCKSIZE / 2; ++ii) {
1715
+ vals[0] = (vals[0] << 8) | (vector[ii + 0] & 0x00FF);
1716
+ vals[1] = (vals[1] << 8) | (vector[ii + off] & 0x00FF);
1717
+ }
1718
+
1719
+ this._encryptBlock(vals);
1720
+
1721
+ const ret = [];
1722
+ for (ii = 0; ii < this.BLOCKSIZE / 2; ++ii) {
1723
+ ret[ii + 0] = ((vals[0] >>> (24 - 8 * (ii))) & 0x00FF);
1724
+ ret[ii + off] = ((vals[1] >>> (24 - 8 * (ii))) & 0x00FF);
1725
+ // vals[ 0 ] = ( vals[ 0 ] >>> 8 );
1726
+ // vals[ 1 ] = ( vals[ 1 ] >>> 8 );
1727
+ }
1728
+
1729
+ return ret;
1730
+ };
1731
+
1732
+ //*
1733
+ //* This method takes an array with two values, left and right
1734
+ //* and undoes NN rounds of Blowfish on them.
1735
+ //*
1736
+ Blowfish.prototype._decryptBlock = function(vals) {
1737
+ let dataL = vals[0];
1738
+ let dataR = vals[1];
1739
+
1740
+ let ii;
1741
+
1742
+ for (ii = this.NN + 1; ii > 1; --ii) {
1743
+ dataL ^= this.parray[ii];
1744
+ dataR = this._F(dataL) ^ dataR;
1745
+
1746
+ const tmp = dataL;
1747
+ dataL = dataR;
1748
+ dataR = tmp;
1749
+ }
1750
+
1751
+ dataL ^= this.parray[1];
1752
+ dataR ^= this.parray[0];
1753
+
1754
+ vals[0] = this._clean(dataR);
1755
+ vals[1] = this._clean(dataL);
1756
+ };
1757
+
1758
+ //*
1759
+ //* This method takes a key array and initializes the
1760
+ //* sboxes and parray for this encryption.
1761
+ //*
1762
+ Blowfish.prototype.init = function(key) {
1763
+ let ii;
1764
+ let jj = 0;
1765
+
1766
+ this.parray = [];
1767
+ for (ii = 0; ii < this.NN + 2; ++ii) {
1768
+ let data = 0x00000000;
1769
+ for (let kk = 0; kk < 4; ++kk) {
1770
+ data = (data << 8) | (key[jj] & 0x00FF);
1771
+ if (++jj >= key.length) {
1772
+ jj = 0;
1773
+ }
1774
+ }
1775
+ this.parray[ii] = this.PARRAY[ii] ^ data;
1776
+ }
1777
+
1778
+ this.sboxes = [];
1779
+ for (ii = 0; ii < 4; ++ii) {
1780
+ this.sboxes[ii] = [];
1781
+ for (jj = 0; jj < 256; ++jj) {
1782
+ this.sboxes[ii][jj] = this.SBOXES[ii][jj];
1783
+ }
1784
+ }
1785
+
1786
+ const vals = [0x00000000, 0x00000000];
1787
+
1788
+ for (ii = 0; ii < this.NN + 2; ii += 2) {
1789
+ this._encryptBlock(vals);
1790
+ this.parray[ii + 0] = vals[0];
1791
+ this.parray[ii + 1] = vals[1];
1792
+ }
1793
+
1794
+ for (ii = 0; ii < 4; ++ii) {
1795
+ for (jj = 0; jj < 256; jj += 2) {
1796
+ this._encryptBlock(vals);
1797
+ this.sboxes[ii][jj + 0] = vals[0];
1798
+ this.sboxes[ii][jj + 1] = vals[1];
1799
+ }
1800
+ }
1801
+ };
1802
+
1803
+ // added by Recurity Labs
1804
+ function BF(key) {
1805
+ this.bf = new Blowfish();
1806
+ this.bf.init(key);
1807
+
1808
+ this.encrypt = function(block) {
1809
+ return this.bf.encryptBlock(block);
1810
+ };
1811
+ }
1812
+
1813
+ BF.keySize = BF.prototype.keySize = 16;
1814
+ BF.blockSize = BF.prototype.blockSize = 8;
1815
+
1816
+ /**
1817
+ * This file is needed to dynamic import the legacy ciphers.
1818
+ * Separate dynamic imports are not convenient as they result in multiple chunks.
1819
+ */
1820
+
1821
+
1822
+ const legacyCiphers = new Map([
1823
+ [enums.symmetric.tripledes, TripleDES],
1824
+ [enums.symmetric.cast5, CAST5],
1825
+ [enums.symmetric.blowfish, BF],
1826
+ [enums.symmetric.twofish, TF]
1827
+ ]);
1828
+
1829
+ export { legacyCiphers };