@novnc/novnc 1.3.0-beta → 1.3.0-g1075cd8

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 (43) hide show
  1. package/README.md +13 -3
  2. package/core/decoders/jpeg.js +141 -0
  3. package/core/decoders/raw.js +1 -1
  4. package/core/decoders/zrle.js +185 -0
  5. package/core/encodings.js +4 -0
  6. package/core/ra2.js +567 -0
  7. package/core/rfb.js +219 -8
  8. package/core/util/md5.js +79 -0
  9. package/docs/API.md +44 -4
  10. package/lib/base64.js +1 -1
  11. package/lib/decoders/copyrect.js +1 -1
  12. package/lib/decoders/hextile.js +2 -2
  13. package/lib/decoders/jpeg.js +188 -0
  14. package/lib/decoders/raw.js +2 -2
  15. package/lib/decoders/rre.js +1 -1
  16. package/lib/decoders/tight.js +2 -2
  17. package/lib/decoders/tightpng.js +3 -3
  18. package/lib/decoders/zrle.js +234 -0
  19. package/lib/deflator.js +1 -1
  20. package/lib/des.js +1 -1
  21. package/lib/display.js +2 -2
  22. package/lib/encodings.js +8 -0
  23. package/lib/inflator.js +1 -1
  24. package/lib/input/gesturehandler.js +1 -1
  25. package/lib/input/keyboard.js +2 -2
  26. package/lib/input/util.js +2 -2
  27. package/lib/ra2.js +1257 -0
  28. package/lib/rfb.js +373 -27
  29. package/lib/util/browser.js +10 -6
  30. package/lib/util/cursor.js +1 -1
  31. package/lib/util/events.js +2 -2
  32. package/lib/util/eventtarget.js +1 -1
  33. package/lib/util/int.js +1 -1
  34. package/lib/util/logging.js +2 -2
  35. package/lib/util/md5.js +103 -0
  36. package/lib/vendor/pako/lib/utils/common.js +2 -2
  37. package/lib/vendor/pako/lib/zlib/deflate.js +6 -5
  38. package/lib/vendor/pako/lib/zlib/inffast.js +6 -2
  39. package/lib/vendor/pako/lib/zlib/inflate.js +41 -18
  40. package/lib/vendor/pako/lib/zlib/inftrees.js +1 -1
  41. package/lib/vendor/pako/lib/zlib/trees.js +3 -3
  42. package/lib/websock.js +2 -2
  43. package/package.json +2 -7
package/lib/ra2.js ADDED
@@ -0,0 +1,1257 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = exports.RSACipher = exports.RA2Cipher = exports.AESEAXCipher = void 0;
9
+
10
+ var _base = _interopRequireDefault(require("./base64.js"));
11
+
12
+ var _strings = require("./util/strings.js");
13
+
14
+ var _eventtarget = _interopRequireDefault(require("./util/eventtarget.js"));
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
17
+
18
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
19
+
20
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
21
+
22
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
23
+
24
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
25
+
26
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
27
+
28
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
29
+
30
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
31
+
32
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
33
+
34
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
35
+
36
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
37
+
38
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
39
+
40
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
41
+
42
+ var AESEAXCipher = /*#__PURE__*/function () {
43
+ function AESEAXCipher() {
44
+ _classCallCheck(this, AESEAXCipher);
45
+
46
+ this._rawKey = null;
47
+ this._ctrKey = null;
48
+ this._cbcKey = null;
49
+ this._zeroBlock = new Uint8Array(16);
50
+ this._prefixBlock0 = this._zeroBlock;
51
+ this._prefixBlock1 = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]);
52
+ this._prefixBlock2 = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2]);
53
+ }
54
+
55
+ _createClass(AESEAXCipher, [{
56
+ key: "_encryptBlock",
57
+ value: function () {
58
+ var _encryptBlock2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(block) {
59
+ var encrypted;
60
+ return regeneratorRuntime.wrap(function _callee$(_context) {
61
+ while (1) {
62
+ switch (_context.prev = _context.next) {
63
+ case 0:
64
+ _context.next = 2;
65
+ return window.crypto.subtle.encrypt({
66
+ name: "AES-CBC",
67
+ iv: this._zeroBlock
68
+ }, this._cbcKey, block);
69
+
70
+ case 2:
71
+ encrypted = _context.sent;
72
+ return _context.abrupt("return", new Uint8Array(encrypted).slice(0, 16));
73
+
74
+ case 4:
75
+ case "end":
76
+ return _context.stop();
77
+ }
78
+ }
79
+ }, _callee, this);
80
+ }));
81
+
82
+ function _encryptBlock(_x) {
83
+ return _encryptBlock2.apply(this, arguments);
84
+ }
85
+
86
+ return _encryptBlock;
87
+ }()
88
+ }, {
89
+ key: "_initCMAC",
90
+ value: function () {
91
+ var _initCMAC2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {
92
+ var k1, k2, v, i, lut;
93
+ return regeneratorRuntime.wrap(function _callee2$(_context2) {
94
+ while (1) {
95
+ switch (_context2.prev = _context2.next) {
96
+ case 0:
97
+ _context2.next = 2;
98
+ return this._encryptBlock(this._zeroBlock);
99
+
100
+ case 2:
101
+ k1 = _context2.sent;
102
+ k2 = new Uint8Array(16);
103
+ v = k1[0] >>> 6;
104
+
105
+ for (i = 0; i < 15; i++) {
106
+ k2[i] = k1[i + 1] >> 6 | k1[i] << 2;
107
+ k1[i] = k1[i + 1] >> 7 | k1[i] << 1;
108
+ }
109
+
110
+ lut = [0x0, 0x87, 0x0e, 0x89];
111
+ k2[14] ^= v >>> 1;
112
+ k2[15] = k1[15] << 2 ^ lut[v];
113
+ k1[15] = k1[15] << 1 ^ lut[v >> 1];
114
+ this._k1 = k1;
115
+ this._k2 = k2;
116
+
117
+ case 12:
118
+ case "end":
119
+ return _context2.stop();
120
+ }
121
+ }
122
+ }, _callee2, this);
123
+ }));
124
+
125
+ function _initCMAC() {
126
+ return _initCMAC2.apply(this, arguments);
127
+ }
128
+
129
+ return _initCMAC;
130
+ }()
131
+ }, {
132
+ key: "_encryptCTR",
133
+ value: function () {
134
+ var _encryptCTR2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(data, counter) {
135
+ var encrypted;
136
+ return regeneratorRuntime.wrap(function _callee3$(_context3) {
137
+ while (1) {
138
+ switch (_context3.prev = _context3.next) {
139
+ case 0:
140
+ _context3.next = 2;
141
+ return window.crypto.subtle.encrypt({
142
+ "name": "AES-CTR",
143
+ counter: counter,
144
+ length: 128
145
+ }, this._ctrKey, data);
146
+
147
+ case 2:
148
+ encrypted = _context3.sent;
149
+ return _context3.abrupt("return", new Uint8Array(encrypted));
150
+
151
+ case 4:
152
+ case "end":
153
+ return _context3.stop();
154
+ }
155
+ }
156
+ }, _callee3, this);
157
+ }));
158
+
159
+ function _encryptCTR(_x2, _x3) {
160
+ return _encryptCTR2.apply(this, arguments);
161
+ }
162
+
163
+ return _encryptCTR;
164
+ }()
165
+ }, {
166
+ key: "_decryptCTR",
167
+ value: function () {
168
+ var _decryptCTR2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(data, counter) {
169
+ var decrypted;
170
+ return regeneratorRuntime.wrap(function _callee4$(_context4) {
171
+ while (1) {
172
+ switch (_context4.prev = _context4.next) {
173
+ case 0:
174
+ _context4.next = 2;
175
+ return window.crypto.subtle.decrypt({
176
+ "name": "AES-CTR",
177
+ counter: counter,
178
+ length: 128
179
+ }, this._ctrKey, data);
180
+
181
+ case 2:
182
+ decrypted = _context4.sent;
183
+ return _context4.abrupt("return", new Uint8Array(decrypted));
184
+
185
+ case 4:
186
+ case "end":
187
+ return _context4.stop();
188
+ }
189
+ }
190
+ }, _callee4, this);
191
+ }));
192
+
193
+ function _decryptCTR(_x4, _x5) {
194
+ return _decryptCTR2.apply(this, arguments);
195
+ }
196
+
197
+ return _decryptCTR;
198
+ }()
199
+ }, {
200
+ key: "_computeCMAC",
201
+ value: function () {
202
+ var _computeCMAC2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5(data, prefixBlock) {
203
+ var n, m, r, cbcData, i, _i, cbcEncrypted, mac;
204
+
205
+ return regeneratorRuntime.wrap(function _callee5$(_context5) {
206
+ while (1) {
207
+ switch (_context5.prev = _context5.next) {
208
+ case 0:
209
+ if (!(prefixBlock.length !== 16)) {
210
+ _context5.next = 2;
211
+ break;
212
+ }
213
+
214
+ return _context5.abrupt("return", null);
215
+
216
+ case 2:
217
+ n = Math.floor(data.length / 16);
218
+ m = Math.ceil(data.length / 16);
219
+ r = data.length - n * 16;
220
+ cbcData = new Uint8Array((m + 1) * 16);
221
+ cbcData.set(prefixBlock);
222
+ cbcData.set(data, 16);
223
+
224
+ if (r === 0) {
225
+ for (i = 0; i < 16; i++) {
226
+ cbcData[n * 16 + i] ^= this._k1[i];
227
+ }
228
+ } else {
229
+ cbcData[(n + 1) * 16 + r] = 0x80;
230
+
231
+ for (_i = 0; _i < 16; _i++) {
232
+ cbcData[(n + 1) * 16 + _i] ^= this._k2[_i];
233
+ }
234
+ }
235
+
236
+ _context5.next = 11;
237
+ return window.crypto.subtle.encrypt({
238
+ name: "AES-CBC",
239
+ iv: this._zeroBlock
240
+ }, this._cbcKey, cbcData);
241
+
242
+ case 11:
243
+ cbcEncrypted = _context5.sent;
244
+ cbcEncrypted = new Uint8Array(cbcEncrypted);
245
+ mac = cbcEncrypted.slice(cbcEncrypted.length - 32, cbcEncrypted.length - 16);
246
+ return _context5.abrupt("return", mac);
247
+
248
+ case 15:
249
+ case "end":
250
+ return _context5.stop();
251
+ }
252
+ }
253
+ }, _callee5, this);
254
+ }));
255
+
256
+ function _computeCMAC(_x6, _x7) {
257
+ return _computeCMAC2.apply(this, arguments);
258
+ }
259
+
260
+ return _computeCMAC;
261
+ }()
262
+ }, {
263
+ key: "setKey",
264
+ value: function () {
265
+ var _setKey = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6(key) {
266
+ return regeneratorRuntime.wrap(function _callee6$(_context6) {
267
+ while (1) {
268
+ switch (_context6.prev = _context6.next) {
269
+ case 0:
270
+ this._rawKey = key;
271
+ _context6.next = 3;
272
+ return window.crypto.subtle.importKey("raw", key, {
273
+ "name": "AES-CTR"
274
+ }, false, ["encrypt", "decrypt"]);
275
+
276
+ case 3:
277
+ this._ctrKey = _context6.sent;
278
+ _context6.next = 6;
279
+ return window.crypto.subtle.importKey("raw", key, {
280
+ "name": "AES-CBC"
281
+ }, false, ["encrypt", "decrypt"]);
282
+
283
+ case 6:
284
+ this._cbcKey = _context6.sent;
285
+ _context6.next = 9;
286
+ return this._initCMAC();
287
+
288
+ case 9:
289
+ case "end":
290
+ return _context6.stop();
291
+ }
292
+ }
293
+ }, _callee6, this);
294
+ }));
295
+
296
+ function setKey(_x8) {
297
+ return _setKey.apply(this, arguments);
298
+ }
299
+
300
+ return setKey;
301
+ }()
302
+ }, {
303
+ key: "encrypt",
304
+ value: function () {
305
+ var _encrypt = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee7(message, associatedData, nonce) {
306
+ var nCMAC, encrypted, adCMAC, mac, i, res;
307
+ return regeneratorRuntime.wrap(function _callee7$(_context7) {
308
+ while (1) {
309
+ switch (_context7.prev = _context7.next) {
310
+ case 0:
311
+ _context7.next = 2;
312
+ return this._computeCMAC(nonce, this._prefixBlock0);
313
+
314
+ case 2:
315
+ nCMAC = _context7.sent;
316
+ _context7.next = 5;
317
+ return this._encryptCTR(message, nCMAC);
318
+
319
+ case 5:
320
+ encrypted = _context7.sent;
321
+ _context7.next = 8;
322
+ return this._computeCMAC(associatedData, this._prefixBlock1);
323
+
324
+ case 8:
325
+ adCMAC = _context7.sent;
326
+ _context7.next = 11;
327
+ return this._computeCMAC(encrypted, this._prefixBlock2);
328
+
329
+ case 11:
330
+ mac = _context7.sent;
331
+
332
+ for (i = 0; i < 16; i++) {
333
+ mac[i] ^= nCMAC[i] ^ adCMAC[i];
334
+ }
335
+
336
+ res = new Uint8Array(16 + encrypted.length);
337
+ res.set(encrypted);
338
+ res.set(mac, encrypted.length);
339
+ return _context7.abrupt("return", res);
340
+
341
+ case 17:
342
+ case "end":
343
+ return _context7.stop();
344
+ }
345
+ }
346
+ }, _callee7, this);
347
+ }));
348
+
349
+ function encrypt(_x9, _x10, _x11) {
350
+ return _encrypt.apply(this, arguments);
351
+ }
352
+
353
+ return encrypt;
354
+ }()
355
+ }, {
356
+ key: "decrypt",
357
+ value: function () {
358
+ var _decrypt = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee8(encrypted, associatedData, nonce, mac) {
359
+ var nCMAC, adCMAC, computedMac, i, _i2, res;
360
+
361
+ return regeneratorRuntime.wrap(function _callee8$(_context8) {
362
+ while (1) {
363
+ switch (_context8.prev = _context8.next) {
364
+ case 0:
365
+ _context8.next = 2;
366
+ return this._computeCMAC(nonce, this._prefixBlock0);
367
+
368
+ case 2:
369
+ nCMAC = _context8.sent;
370
+ _context8.next = 5;
371
+ return this._computeCMAC(associatedData, this._prefixBlock1);
372
+
373
+ case 5:
374
+ adCMAC = _context8.sent;
375
+ _context8.next = 8;
376
+ return this._computeCMAC(encrypted, this._prefixBlock2);
377
+
378
+ case 8:
379
+ computedMac = _context8.sent;
380
+
381
+ for (i = 0; i < 16; i++) {
382
+ computedMac[i] ^= nCMAC[i] ^ adCMAC[i];
383
+ }
384
+
385
+ if (!(computedMac.length !== mac.length)) {
386
+ _context8.next = 12;
387
+ break;
388
+ }
389
+
390
+ return _context8.abrupt("return", null);
391
+
392
+ case 12:
393
+ _i2 = 0;
394
+
395
+ case 13:
396
+ if (!(_i2 < mac.length)) {
397
+ _context8.next = 19;
398
+ break;
399
+ }
400
+
401
+ if (!(computedMac[_i2] !== mac[_i2])) {
402
+ _context8.next = 16;
403
+ break;
404
+ }
405
+
406
+ return _context8.abrupt("return", null);
407
+
408
+ case 16:
409
+ _i2++;
410
+ _context8.next = 13;
411
+ break;
412
+
413
+ case 19:
414
+ _context8.next = 21;
415
+ return this._decryptCTR(encrypted, nCMAC);
416
+
417
+ case 21:
418
+ res = _context8.sent;
419
+ return _context8.abrupt("return", res);
420
+
421
+ case 23:
422
+ case "end":
423
+ return _context8.stop();
424
+ }
425
+ }
426
+ }, _callee8, this);
427
+ }));
428
+
429
+ function decrypt(_x12, _x13, _x14, _x15) {
430
+ return _decrypt.apply(this, arguments);
431
+ }
432
+
433
+ return decrypt;
434
+ }()
435
+ }]);
436
+
437
+ return AESEAXCipher;
438
+ }();
439
+
440
+ exports.AESEAXCipher = AESEAXCipher;
441
+
442
+ var RA2Cipher = /*#__PURE__*/function () {
443
+ function RA2Cipher() {
444
+ _classCallCheck(this, RA2Cipher);
445
+
446
+ this._cipher = new AESEAXCipher();
447
+ this._counter = new Uint8Array(16);
448
+ }
449
+
450
+ _createClass(RA2Cipher, [{
451
+ key: "setKey",
452
+ value: function () {
453
+ var _setKey2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee9(key) {
454
+ return regeneratorRuntime.wrap(function _callee9$(_context9) {
455
+ while (1) {
456
+ switch (_context9.prev = _context9.next) {
457
+ case 0:
458
+ _context9.next = 2;
459
+ return this._cipher.setKey(key);
460
+
461
+ case 2:
462
+ case "end":
463
+ return _context9.stop();
464
+ }
465
+ }
466
+ }, _callee9, this);
467
+ }));
468
+
469
+ function setKey(_x16) {
470
+ return _setKey2.apply(this, arguments);
471
+ }
472
+
473
+ return setKey;
474
+ }()
475
+ }, {
476
+ key: "makeMessage",
477
+ value: function () {
478
+ var _makeMessage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee10(message) {
479
+ var ad, encrypted, i, res;
480
+ return regeneratorRuntime.wrap(function _callee10$(_context10) {
481
+ while (1) {
482
+ switch (_context10.prev = _context10.next) {
483
+ case 0:
484
+ ad = new Uint8Array([(message.length & 0xff00) >>> 8, message.length & 0xff]);
485
+ _context10.next = 3;
486
+ return this._cipher.encrypt(message, ad, this._counter);
487
+
488
+ case 3:
489
+ encrypted = _context10.sent;
490
+
491
+ for (i = 0; i < 16 && this._counter[i]++ === 255; i++) {
492
+ ;
493
+ }
494
+
495
+ res = new Uint8Array(message.length + 2 + 16);
496
+ res.set(ad);
497
+ res.set(encrypted, 2);
498
+ return _context10.abrupt("return", res);
499
+
500
+ case 9:
501
+ case "end":
502
+ return _context10.stop();
503
+ }
504
+ }
505
+ }, _callee10, this);
506
+ }));
507
+
508
+ function makeMessage(_x17) {
509
+ return _makeMessage.apply(this, arguments);
510
+ }
511
+
512
+ return makeMessage;
513
+ }()
514
+ }, {
515
+ key: "receiveMessage",
516
+ value: function () {
517
+ var _receiveMessage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee11(length, encrypted, mac) {
518
+ var ad, res, i;
519
+ return regeneratorRuntime.wrap(function _callee11$(_context11) {
520
+ while (1) {
521
+ switch (_context11.prev = _context11.next) {
522
+ case 0:
523
+ ad = new Uint8Array([(length & 0xff00) >>> 8, length & 0xff]);
524
+ _context11.next = 3;
525
+ return this._cipher.decrypt(encrypted, ad, this._counter, mac);
526
+
527
+ case 3:
528
+ res = _context11.sent;
529
+
530
+ for (i = 0; i < 16 && this._counter[i]++ === 255; i++) {
531
+ ;
532
+ }
533
+
534
+ return _context11.abrupt("return", res);
535
+
536
+ case 6:
537
+ case "end":
538
+ return _context11.stop();
539
+ }
540
+ }
541
+ }, _callee11, this);
542
+ }));
543
+
544
+ function receiveMessage(_x18, _x19, _x20) {
545
+ return _receiveMessage.apply(this, arguments);
546
+ }
547
+
548
+ return receiveMessage;
549
+ }()
550
+ }]);
551
+
552
+ return RA2Cipher;
553
+ }();
554
+
555
+ exports.RA2Cipher = RA2Cipher;
556
+
557
+ var RSACipher = /*#__PURE__*/function () {
558
+ function RSACipher(keyLength) {
559
+ _classCallCheck(this, RSACipher);
560
+
561
+ this._key = null;
562
+ this._keyLength = keyLength;
563
+ this._keyBytes = Math.ceil(keyLength / 8);
564
+ this._n = null;
565
+ this._e = null;
566
+ this._d = null;
567
+ this._nBigInt = null;
568
+ this._eBigInt = null;
569
+ this._dBigInt = null;
570
+ }
571
+
572
+ _createClass(RSACipher, [{
573
+ key: "_base64urlDecode",
574
+ value: function _base64urlDecode(data) {
575
+ data = data.replace(/-/g, "+").replace(/_/g, "/");
576
+ data = data.padEnd(Math.ceil(data.length / 4) * 4, "=");
577
+ return _base["default"].decode(data);
578
+ }
579
+ }, {
580
+ key: "_u8ArrayToBigInt",
581
+ value: function _u8ArrayToBigInt(arr) {
582
+ var hex = '0x';
583
+
584
+ for (var i = 0; i < arr.length; i++) {
585
+ hex += arr[i].toString(16).padStart(2, '0');
586
+ }
587
+
588
+ return BigInt(hex);
589
+ }
590
+ }, {
591
+ key: "_padArray",
592
+ value: function _padArray(arr, length) {
593
+ var res = new Uint8Array(length);
594
+ res.set(arr, length - arr.length);
595
+ return res;
596
+ }
597
+ }, {
598
+ key: "_bigIntToU8Array",
599
+ value: function _bigIntToU8Array(bigint) {
600
+ var padLength = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
601
+ var hex = bigint.toString(16);
602
+
603
+ if (padLength === 0) {
604
+ padLength = Math.ceil(hex.length / 2) * 2;
605
+ }
606
+
607
+ hex = hex.padStart(padLength * 2, '0');
608
+ var length = hex.length / 2;
609
+ var arr = new Uint8Array(length);
610
+
611
+ for (var i = 0; i < length; i++) {
612
+ arr[i] = parseInt(hex.slice(i * 2, i * 2 + 2), 16);
613
+ }
614
+
615
+ return arr;
616
+ }
617
+ }, {
618
+ key: "_modPow",
619
+ value: function _modPow(b, e, m) {
620
+ if (m === 1n) {
621
+ return 0;
622
+ }
623
+
624
+ var r = 1n;
625
+ b = b % m;
626
+
627
+ while (e > 0) {
628
+ if (e % 2n === 1n) {
629
+ r = r * b % m;
630
+ }
631
+
632
+ e = e / 2n;
633
+ b = b * b % m;
634
+ }
635
+
636
+ return r;
637
+ }
638
+ }, {
639
+ key: "generateKey",
640
+ value: function () {
641
+ var _generateKey = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee12() {
642
+ var privateKey;
643
+ return regeneratorRuntime.wrap(function _callee12$(_context12) {
644
+ while (1) {
645
+ switch (_context12.prev = _context12.next) {
646
+ case 0:
647
+ _context12.next = 2;
648
+ return window.crypto.subtle.generateKey({
649
+ name: "RSA-OAEP",
650
+ modulusLength: this._keyLength,
651
+ publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
652
+ hash: {
653
+ name: "SHA-256"
654
+ }
655
+ }, true, ["encrypt", "decrypt"]);
656
+
657
+ case 2:
658
+ this._key = _context12.sent;
659
+ _context12.next = 5;
660
+ return window.crypto.subtle.exportKey("jwk", this._key.privateKey);
661
+
662
+ case 5:
663
+ privateKey = _context12.sent;
664
+ this._n = this._padArray(this._base64urlDecode(privateKey.n), this._keyBytes);
665
+ this._nBigInt = this._u8ArrayToBigInt(this._n);
666
+ this._e = this._padArray(this._base64urlDecode(privateKey.e), this._keyBytes);
667
+ this._eBigInt = this._u8ArrayToBigInt(this._e);
668
+ this._d = this._padArray(this._base64urlDecode(privateKey.d), this._keyBytes);
669
+ this._dBigInt = this._u8ArrayToBigInt(this._d);
670
+
671
+ case 12:
672
+ case "end":
673
+ return _context12.stop();
674
+ }
675
+ }
676
+ }, _callee12, this);
677
+ }));
678
+
679
+ function generateKey() {
680
+ return _generateKey.apply(this, arguments);
681
+ }
682
+
683
+ return generateKey;
684
+ }()
685
+ }, {
686
+ key: "setPublicKey",
687
+ value: function setPublicKey(n, e) {
688
+ if (n.length !== this._keyBytes || e.length !== this._keyBytes) {
689
+ return;
690
+ }
691
+
692
+ this._n = new Uint8Array(this._keyBytes);
693
+ this._e = new Uint8Array(this._keyBytes);
694
+
695
+ this._n.set(n);
696
+
697
+ this._e.set(e);
698
+
699
+ this._nBigInt = this._u8ArrayToBigInt(this._n);
700
+ this._eBigInt = this._u8ArrayToBigInt(this._e);
701
+ }
702
+ }, {
703
+ key: "encrypt",
704
+ value: function encrypt(message) {
705
+ if (message.length > this._keyBytes - 11) {
706
+ return null;
707
+ }
708
+
709
+ var ps = new Uint8Array(this._keyBytes - message.length - 3);
710
+ window.crypto.getRandomValues(ps);
711
+
712
+ for (var i = 0; i < ps.length; i++) {
713
+ ps[i] = Math.floor(ps[i] * 254 / 255 + 1);
714
+ }
715
+
716
+ var em = new Uint8Array(this._keyBytes);
717
+ em[1] = 0x02;
718
+ em.set(ps, 2);
719
+ em.set(message, ps.length + 3);
720
+
721
+ var emBigInt = this._u8ArrayToBigInt(em);
722
+
723
+ var c = this._modPow(emBigInt, this._eBigInt, this._nBigInt);
724
+
725
+ return this._bigIntToU8Array(c, this._keyBytes);
726
+ }
727
+ }, {
728
+ key: "decrypt",
729
+ value: function decrypt(message) {
730
+ if (message.length !== this._keyBytes) {
731
+ return null;
732
+ }
733
+
734
+ var msgBigInt = this._u8ArrayToBigInt(message);
735
+
736
+ var emBigInt = this._modPow(msgBigInt, this._dBigInt, this._nBigInt);
737
+
738
+ var em = this._bigIntToU8Array(emBigInt, this._keyBytes);
739
+
740
+ if (em[0] !== 0x00 || em[1] !== 0x02) {
741
+ return null;
742
+ }
743
+
744
+ var i = 2;
745
+
746
+ for (; i < em.length; i++) {
747
+ if (em[i] === 0x00) {
748
+ break;
749
+ }
750
+ }
751
+
752
+ if (i === em.length) {
753
+ return null;
754
+ }
755
+
756
+ return em.slice(i + 1, em.length);
757
+ }
758
+ }, {
759
+ key: "keyLength",
760
+ get: function get() {
761
+ return this._keyLength;
762
+ }
763
+ }, {
764
+ key: "n",
765
+ get: function get() {
766
+ return this._n;
767
+ }
768
+ }, {
769
+ key: "e",
770
+ get: function get() {
771
+ return this._e;
772
+ }
773
+ }, {
774
+ key: "d",
775
+ get: function get() {
776
+ return this._d;
777
+ }
778
+ }]);
779
+
780
+ return RSACipher;
781
+ }();
782
+
783
+ exports.RSACipher = RSACipher;
784
+
785
+ var RSAAESAuthenticationState = /*#__PURE__*/function (_EventTargetMixin) {
786
+ _inherits(RSAAESAuthenticationState, _EventTargetMixin);
787
+
788
+ var _super = _createSuper(RSAAESAuthenticationState);
789
+
790
+ function RSAAESAuthenticationState(sock, getCredentials) {
791
+ var _this;
792
+
793
+ _classCallCheck(this, RSAAESAuthenticationState);
794
+
795
+ _this = _super.call(this);
796
+ _this._hasStarted = false;
797
+ _this._checkSock = null;
798
+ _this._checkCredentials = null;
799
+ _this._approveServerResolve = null;
800
+ _this._sockReject = null;
801
+ _this._credentialsReject = null;
802
+ _this._approveServerReject = null;
803
+ _this._sock = sock;
804
+ _this._getCredentials = getCredentials;
805
+ return _this;
806
+ }
807
+
808
+ _createClass(RSAAESAuthenticationState, [{
809
+ key: "_waitSockAsync",
810
+ value: function _waitSockAsync(len) {
811
+ var _this2 = this;
812
+
813
+ return new Promise(function (resolve, reject) {
814
+ var hasData = function hasData() {
815
+ return !_this2._sock.rQwait('RA2', len);
816
+ };
817
+
818
+ if (hasData()) {
819
+ resolve();
820
+ } else {
821
+ _this2._checkSock = function () {
822
+ if (hasData()) {
823
+ resolve();
824
+ _this2._checkSock = null;
825
+ _this2._sockReject = null;
826
+ }
827
+ };
828
+
829
+ _this2._sockReject = reject;
830
+ }
831
+ });
832
+ }
833
+ }, {
834
+ key: "_waitApproveKeyAsync",
835
+ value: function _waitApproveKeyAsync() {
836
+ var _this3 = this;
837
+
838
+ return new Promise(function (resolve, reject) {
839
+ _this3._approveServerResolve = resolve;
840
+ _this3._approveServerReject = reject;
841
+ });
842
+ }
843
+ }, {
844
+ key: "_waitCredentialsAsync",
845
+ value: function _waitCredentialsAsync(subtype) {
846
+ var _this4 = this;
847
+
848
+ var hasCredentials = function hasCredentials() {
849
+ if (subtype === 1 && _this4._getCredentials().username !== undefined && _this4._getCredentials().password !== undefined) {
850
+ return true;
851
+ } else if (subtype === 2 && _this4._getCredentials().password !== undefined) {
852
+ return true;
853
+ }
854
+
855
+ return false;
856
+ };
857
+
858
+ return new Promise(function (resolve, reject) {
859
+ if (hasCredentials()) {
860
+ resolve();
861
+ } else {
862
+ _this4._checkCredentials = function () {
863
+ if (hasCredentials()) {
864
+ resolve();
865
+ _this4._checkCredentials = null;
866
+ _this4._credentialsReject = null;
867
+ }
868
+ };
869
+
870
+ _this4._credentialsReject = reject;
871
+ }
872
+ });
873
+ }
874
+ }, {
875
+ key: "checkInternalEvents",
876
+ value: function checkInternalEvents() {
877
+ if (this._checkSock !== null) {
878
+ this._checkSock();
879
+ }
880
+
881
+ if (this._checkCredentials !== null) {
882
+ this._checkCredentials();
883
+ }
884
+ }
885
+ }, {
886
+ key: "approveServer",
887
+ value: function approveServer() {
888
+ if (this._approveServerResolve !== null) {
889
+ this._approveServerResolve();
890
+
891
+ this._approveServerResolve = null;
892
+ }
893
+ }
894
+ }, {
895
+ key: "disconnect",
896
+ value: function disconnect() {
897
+ if (this._sockReject !== null) {
898
+ this._sockReject(new Error("disconnect normally"));
899
+
900
+ this._sockReject = null;
901
+ }
902
+
903
+ if (this._credentialsReject !== null) {
904
+ this._credentialsReject(new Error("disconnect normally"));
905
+
906
+ this._credentialsReject = null;
907
+ }
908
+
909
+ if (this._approveServerReject !== null) {
910
+ this._approveServerReject(new Error("disconnect normally"));
911
+
912
+ this._approveServerReject = null;
913
+ }
914
+ }
915
+ }, {
916
+ key: "negotiateRA2neAuthAsync",
917
+ value: function () {
918
+ var _negotiateRA2neAuthAsync = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee13() {
919
+ var serverKeyLengthBuffer, serverKeyLength, serverKeyBytes, serverN, serverE, serverRSACipher, serverPublickey, clientKeyLength, clientKeyBytes, clientRSACipher, clientN, clientE, clientPublicKey, clientRandom, clientEncryptedRandom, clientRandomMessage, serverEncryptedRandom, serverRandom, clientSessionKey, serverSessionKey, clientCipher, serverCipher, serverHash, clientHash, serverHashReceived, i, subtype, username, password, credentials, _i3, _i4;
920
+
921
+ return regeneratorRuntime.wrap(function _callee13$(_context13) {
922
+ while (1) {
923
+ switch (_context13.prev = _context13.next) {
924
+ case 0:
925
+ this._hasStarted = true; // 1: Receive server public key
926
+
927
+ _context13.next = 3;
928
+ return this._waitSockAsync(4);
929
+
930
+ case 3:
931
+ serverKeyLengthBuffer = this._sock.rQslice(0, 4);
932
+ serverKeyLength = this._sock.rQshift32();
933
+
934
+ if (!(serverKeyLength < 1024)) {
935
+ _context13.next = 9;
936
+ break;
937
+ }
938
+
939
+ throw new Error("RA2: server public key is too short: " + serverKeyLength);
940
+
941
+ case 9:
942
+ if (!(serverKeyLength > 8192)) {
943
+ _context13.next = 11;
944
+ break;
945
+ }
946
+
947
+ throw new Error("RA2: server public key is too long: " + serverKeyLength);
948
+
949
+ case 11:
950
+ serverKeyBytes = Math.ceil(serverKeyLength / 8);
951
+ _context13.next = 14;
952
+ return this._waitSockAsync(serverKeyBytes * 2);
953
+
954
+ case 14:
955
+ serverN = this._sock.rQshiftBytes(serverKeyBytes);
956
+ serverE = this._sock.rQshiftBytes(serverKeyBytes);
957
+ serverRSACipher = new RSACipher(serverKeyLength);
958
+ serverRSACipher.setPublicKey(serverN, serverE);
959
+ serverPublickey = new Uint8Array(4 + serverKeyBytes * 2);
960
+ serverPublickey.set(serverKeyLengthBuffer);
961
+ serverPublickey.set(serverN, 4);
962
+ serverPublickey.set(serverE, 4 + serverKeyBytes); // verify server public key
963
+
964
+ this.dispatchEvent(new CustomEvent("serververification", {
965
+ detail: {
966
+ type: "RSA",
967
+ publickey: serverPublickey
968
+ }
969
+ }));
970
+ _context13.next = 25;
971
+ return this._waitApproveKeyAsync();
972
+
973
+ case 25:
974
+ // 2: Send client public key
975
+ clientKeyLength = 2048;
976
+ clientKeyBytes = Math.ceil(clientKeyLength / 8);
977
+ clientRSACipher = new RSACipher(clientKeyLength);
978
+ _context13.next = 30;
979
+ return clientRSACipher.generateKey();
980
+
981
+ case 30:
982
+ clientN = clientRSACipher.n;
983
+ clientE = clientRSACipher.e;
984
+ clientPublicKey = new Uint8Array(4 + clientKeyBytes * 2);
985
+ clientPublicKey[0] = (clientKeyLength & 0xff000000) >>> 24;
986
+ clientPublicKey[1] = (clientKeyLength & 0xff0000) >>> 16;
987
+ clientPublicKey[2] = (clientKeyLength & 0xff00) >>> 8;
988
+ clientPublicKey[3] = clientKeyLength & 0xff;
989
+ clientPublicKey.set(clientN, 4);
990
+ clientPublicKey.set(clientE, 4 + clientKeyBytes);
991
+
992
+ this._sock.send(clientPublicKey); // 3: Send client random
993
+
994
+
995
+ clientRandom = new Uint8Array(16);
996
+ window.crypto.getRandomValues(clientRandom);
997
+ clientEncryptedRandom = serverRSACipher.encrypt(clientRandom);
998
+ clientRandomMessage = new Uint8Array(2 + serverKeyBytes);
999
+ clientRandomMessage[0] = (serverKeyBytes & 0xff00) >>> 8;
1000
+ clientRandomMessage[1] = serverKeyBytes & 0xff;
1001
+ clientRandomMessage.set(clientEncryptedRandom, 2);
1002
+
1003
+ this._sock.send(clientRandomMessage); // 4: Receive server random
1004
+
1005
+
1006
+ _context13.next = 50;
1007
+ return this._waitSockAsync(2);
1008
+
1009
+ case 50:
1010
+ if (!(this._sock.rQshift16() !== clientKeyBytes)) {
1011
+ _context13.next = 52;
1012
+ break;
1013
+ }
1014
+
1015
+ throw new Error("RA2: wrong encrypted message length");
1016
+
1017
+ case 52:
1018
+ serverEncryptedRandom = this._sock.rQshiftBytes(clientKeyBytes);
1019
+ serverRandom = clientRSACipher.decrypt(serverEncryptedRandom);
1020
+
1021
+ if (!(serverRandom === null || serverRandom.length !== 16)) {
1022
+ _context13.next = 56;
1023
+ break;
1024
+ }
1025
+
1026
+ throw new Error("RA2: corrupted server encrypted random");
1027
+
1028
+ case 56:
1029
+ // 5: Compute session keys and set ciphers
1030
+ clientSessionKey = new Uint8Array(32);
1031
+ serverSessionKey = new Uint8Array(32);
1032
+ clientSessionKey.set(serverRandom);
1033
+ clientSessionKey.set(clientRandom, 16);
1034
+ serverSessionKey.set(clientRandom);
1035
+ serverSessionKey.set(serverRandom, 16);
1036
+ _context13.next = 64;
1037
+ return window.crypto.subtle.digest("SHA-1", clientSessionKey);
1038
+
1039
+ case 64:
1040
+ clientSessionKey = _context13.sent;
1041
+ clientSessionKey = new Uint8Array(clientSessionKey).slice(0, 16);
1042
+ _context13.next = 68;
1043
+ return window.crypto.subtle.digest("SHA-1", serverSessionKey);
1044
+
1045
+ case 68:
1046
+ serverSessionKey = _context13.sent;
1047
+ serverSessionKey = new Uint8Array(serverSessionKey).slice(0, 16);
1048
+ clientCipher = new RA2Cipher();
1049
+ _context13.next = 73;
1050
+ return clientCipher.setKey(clientSessionKey);
1051
+
1052
+ case 73:
1053
+ serverCipher = new RA2Cipher();
1054
+ _context13.next = 76;
1055
+ return serverCipher.setKey(serverSessionKey);
1056
+
1057
+ case 76:
1058
+ // 6: Compute and exchange hashes
1059
+ serverHash = new Uint8Array(8 + serverKeyBytes * 2 + clientKeyBytes * 2);
1060
+ clientHash = new Uint8Array(8 + serverKeyBytes * 2 + clientKeyBytes * 2);
1061
+ serverHash.set(serverPublickey);
1062
+ serverHash.set(clientPublicKey, 4 + serverKeyBytes * 2);
1063
+ clientHash.set(clientPublicKey);
1064
+ clientHash.set(serverPublickey, 4 + clientKeyBytes * 2);
1065
+ _context13.next = 84;
1066
+ return window.crypto.subtle.digest("SHA-1", serverHash);
1067
+
1068
+ case 84:
1069
+ serverHash = _context13.sent;
1070
+ _context13.next = 87;
1071
+ return window.crypto.subtle.digest("SHA-1", clientHash);
1072
+
1073
+ case 87:
1074
+ clientHash = _context13.sent;
1075
+ serverHash = new Uint8Array(serverHash);
1076
+ clientHash = new Uint8Array(clientHash);
1077
+ _context13.t0 = this._sock;
1078
+ _context13.next = 93;
1079
+ return clientCipher.makeMessage(clientHash);
1080
+
1081
+ case 93:
1082
+ _context13.t1 = _context13.sent;
1083
+
1084
+ _context13.t0.send.call(_context13.t0, _context13.t1);
1085
+
1086
+ _context13.next = 97;
1087
+ return this._waitSockAsync(2 + 20 + 16);
1088
+
1089
+ case 97:
1090
+ if (!(this._sock.rQshift16() !== 20)) {
1091
+ _context13.next = 99;
1092
+ break;
1093
+ }
1094
+
1095
+ throw new Error("RA2: wrong server hash");
1096
+
1097
+ case 99:
1098
+ _context13.next = 101;
1099
+ return serverCipher.receiveMessage(20, this._sock.rQshiftBytes(20), this._sock.rQshiftBytes(16));
1100
+
1101
+ case 101:
1102
+ serverHashReceived = _context13.sent;
1103
+
1104
+ if (!(serverHashReceived === null)) {
1105
+ _context13.next = 104;
1106
+ break;
1107
+ }
1108
+
1109
+ throw new Error("RA2: failed to authenticate the message");
1110
+
1111
+ case 104:
1112
+ i = 0;
1113
+
1114
+ case 105:
1115
+ if (!(i < 20)) {
1116
+ _context13.next = 111;
1117
+ break;
1118
+ }
1119
+
1120
+ if (!(serverHashReceived[i] !== serverHash[i])) {
1121
+ _context13.next = 108;
1122
+ break;
1123
+ }
1124
+
1125
+ throw new Error("RA2: wrong server hash");
1126
+
1127
+ case 108:
1128
+ i++;
1129
+ _context13.next = 105;
1130
+ break;
1131
+
1132
+ case 111:
1133
+ _context13.next = 113;
1134
+ return this._waitSockAsync(2 + 1 + 16);
1135
+
1136
+ case 113:
1137
+ if (!(this._sock.rQshift16() !== 1)) {
1138
+ _context13.next = 115;
1139
+ break;
1140
+ }
1141
+
1142
+ throw new Error("RA2: wrong subtype");
1143
+
1144
+ case 115:
1145
+ _context13.next = 117;
1146
+ return serverCipher.receiveMessage(1, this._sock.rQshiftBytes(1), this._sock.rQshiftBytes(16));
1147
+
1148
+ case 117:
1149
+ subtype = _context13.sent;
1150
+
1151
+ if (!(subtype === null)) {
1152
+ _context13.next = 120;
1153
+ break;
1154
+ }
1155
+
1156
+ throw new Error("RA2: failed to authenticate the message");
1157
+
1158
+ case 120:
1159
+ subtype = subtype[0];
1160
+
1161
+ if (!(subtype === 1)) {
1162
+ _context13.next = 125;
1163
+ break;
1164
+ }
1165
+
1166
+ if (this._getCredentials().username === undefined || this._getCredentials().password === undefined) {
1167
+ this.dispatchEvent(new CustomEvent("credentialsrequired", {
1168
+ detail: {
1169
+ types: ["username", "password"]
1170
+ }
1171
+ }));
1172
+ }
1173
+
1174
+ _context13.next = 130;
1175
+ break;
1176
+
1177
+ case 125:
1178
+ if (!(subtype === 2)) {
1179
+ _context13.next = 129;
1180
+ break;
1181
+ }
1182
+
1183
+ if (this._getCredentials().password === undefined) {
1184
+ this.dispatchEvent(new CustomEvent("credentialsrequired", {
1185
+ detail: {
1186
+ types: ["password"]
1187
+ }
1188
+ }));
1189
+ }
1190
+
1191
+ _context13.next = 130;
1192
+ break;
1193
+
1194
+ case 129:
1195
+ throw new Error("RA2: wrong subtype");
1196
+
1197
+ case 130:
1198
+ _context13.next = 132;
1199
+ return this._waitCredentialsAsync(subtype);
1200
+
1201
+ case 132:
1202
+ if (subtype === 1) {
1203
+ username = (0, _strings.encodeUTF8)(this._getCredentials().username).slice(0, 255);
1204
+ } else {
1205
+ username = "";
1206
+ }
1207
+
1208
+ password = (0, _strings.encodeUTF8)(this._getCredentials().password).slice(0, 255);
1209
+ credentials = new Uint8Array(username.length + password.length + 2);
1210
+ credentials[0] = username.length;
1211
+ credentials[username.length + 1] = password.length;
1212
+
1213
+ for (_i3 = 0; _i3 < username.length; _i3++) {
1214
+ credentials[_i3 + 1] = username.charCodeAt(_i3);
1215
+ }
1216
+
1217
+ for (_i4 = 0; _i4 < password.length; _i4++) {
1218
+ credentials[username.length + 2 + _i4] = password.charCodeAt(_i4);
1219
+ }
1220
+
1221
+ _context13.t2 = this._sock;
1222
+ _context13.next = 142;
1223
+ return clientCipher.makeMessage(credentials);
1224
+
1225
+ case 142:
1226
+ _context13.t3 = _context13.sent;
1227
+
1228
+ _context13.t2.send.call(_context13.t2, _context13.t3);
1229
+
1230
+ case 144:
1231
+ case "end":
1232
+ return _context13.stop();
1233
+ }
1234
+ }
1235
+ }, _callee13, this);
1236
+ }));
1237
+
1238
+ function negotiateRA2neAuthAsync() {
1239
+ return _negotiateRA2neAuthAsync.apply(this, arguments);
1240
+ }
1241
+
1242
+ return negotiateRA2neAuthAsync;
1243
+ }()
1244
+ }, {
1245
+ key: "hasStarted",
1246
+ get: function get() {
1247
+ return this._hasStarted;
1248
+ },
1249
+ set: function set(s) {
1250
+ this._hasStarted = s;
1251
+ }
1252
+ }]);
1253
+
1254
+ return RSAAESAuthenticationState;
1255
+ }(_eventtarget["default"]);
1256
+
1257
+ exports["default"] = RSAAESAuthenticationState;