@waves/node-api-js 1.2.5-beta.15 → 1.2.5-beta.18

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 (93) hide show
  1. package/cjs/api-node/activation/index.js +2 -2
  2. package/cjs/api-node/activation/index.js.map +1 -1
  3. package/cjs/api-node/addresses/index.js +54 -45
  4. package/cjs/api-node/addresses/index.js.map +1 -1
  5. package/cjs/api-node/alias/index.js +5 -5
  6. package/cjs/api-node/alias/index.js.map +1 -1
  7. package/cjs/api-node/assets/index.js +118 -63
  8. package/cjs/api-node/assets/index.js.map +1 -1
  9. package/cjs/api-node/blocks/index.js +60 -49
  10. package/cjs/api-node/blocks/index.js.map +1 -1
  11. package/cjs/api-node/consensus/index.js +6 -5
  12. package/cjs/api-node/consensus/index.js.map +1 -1
  13. package/cjs/api-node/debug/index.js +17 -14
  14. package/cjs/api-node/debug/index.js.map +1 -1
  15. package/cjs/api-node/eth/index.js +5 -5
  16. package/cjs/api-node/eth/index.js.map +1 -1
  17. package/cjs/api-node/leasing/index.js +19 -7
  18. package/cjs/api-node/leasing/index.js.map +1 -1
  19. package/cjs/api-node/node/index.js +7 -5
  20. package/cjs/api-node/node/index.js.map +1 -1
  21. package/cjs/api-node/peers/index.js +17 -13
  22. package/cjs/api-node/peers/index.js.map +1 -1
  23. package/cjs/api-node/rewards/index.js +6 -5
  24. package/cjs/api-node/rewards/index.js.map +1 -1
  25. package/cjs/api-node/transactions/index.js +82 -42
  26. package/cjs/api-node/transactions/index.js.map +1 -1
  27. package/cjs/api-node/utils/index.js +22 -22
  28. package/cjs/api-node/utils/index.js.map +1 -1
  29. package/cjs/create.d.ts +6 -31
  30. package/cjs/create.js +59 -59
  31. package/cjs/create.js.map +1 -1
  32. package/cjs/index.js +5 -5
  33. package/cjs/index.js.map +1 -1
  34. package/cjs/interface.js +6 -2
  35. package/cjs/interface.js.map +1 -1
  36. package/cjs/tools/adresses/availableSponsoredBalances.js +9 -9
  37. package/cjs/tools/adresses/availableSponsoredBalances.js.map +1 -1
  38. package/cjs/tools/adresses/ethAddress2waves.js +29 -16
  39. package/cjs/tools/adresses/ethAddress2waves.js.map +1 -1
  40. package/cjs/tools/adresses/getAssetIdListByTx.js +36 -15
  41. package/cjs/tools/adresses/getAssetIdListByTx.js.map +1 -1
  42. package/cjs/tools/adresses/getAssetsByTransaction.js +4 -4
  43. package/cjs/tools/adresses/getAssetsByTransaction.js.map +1 -1
  44. package/cjs/tools/adresses/getTransactionsWithAssets.js +3 -3
  45. package/cjs/tools/adresses/getTransactionsWithAssets.js.map +1 -1
  46. package/cjs/tools/adresses/watch.js +85 -56
  47. package/cjs/tools/adresses/watch.js.map +1 -1
  48. package/cjs/tools/adresses/wavesAddress2eth.js +4 -4
  49. package/cjs/tools/adresses/wavesAddress2eth.js.map +1 -1
  50. package/cjs/tools/assets/wavesAsset2eth.js +4 -4
  51. package/cjs/tools/assets/wavesAsset2eth.js.map +1 -1
  52. package/cjs/tools/blocks/detectInterval.js +4 -4
  53. package/cjs/tools/blocks/detectInterval.js.map +1 -1
  54. package/cjs/tools/blocks/getNetworkByte.js +6 -6
  55. package/cjs/tools/blocks/getNetworkByte.js.map +1 -1
  56. package/cjs/tools/blocks/getNetworkCode.js +2 -2
  57. package/cjs/tools/blocks/getNetworkCode.js.map +1 -1
  58. package/cjs/tools/blocks/waitHeight.js +36 -13
  59. package/cjs/tools/blocks/waitHeight.js.map +1 -1
  60. package/cjs/tools/parse.js +2 -2
  61. package/cjs/tools/parse.js.map +1 -1
  62. package/cjs/tools/query.js +34 -8
  63. package/cjs/tools/query.js.map +1 -1
  64. package/cjs/tools/request.d.ts +1 -1
  65. package/cjs/tools/request.js +19 -7
  66. package/cjs/tools/request.js.map +1 -1
  67. package/cjs/tools/stringify.js +3 -3
  68. package/cjs/tools/stringify.js.map +1 -1
  69. package/cjs/tools/transactions/broadcast.js +29 -18
  70. package/cjs/tools/transactions/broadcast.js.map +1 -1
  71. package/cjs/tools/transactions/ethTxId2waves.js +2 -2
  72. package/cjs/tools/transactions/ethTxId2waves.js.map +1 -1
  73. package/cjs/tools/transactions/transactions.d.ts +2 -2
  74. package/cjs/tools/transactions/transactions.js +66 -52
  75. package/cjs/tools/transactions/transactions.js.map +1 -1
  76. package/cjs/tools/transactions/wait.js +16 -16
  77. package/cjs/tools/transactions/wait.js.map +1 -1
  78. package/cjs/tools/utils.js +63 -30
  79. package/cjs/tools/utils.js.map +1 -1
  80. package/dist/0.node-api.js +467 -0
  81. package/dist/node-api.js +42 -573
  82. package/dist/node-api.min.js +5 -5
  83. package/dist/node-api.min.js.LICENSE.txt +17 -0
  84. package/dist/node_fs-node_path.node-api.js +23 -0
  85. package/dist/vendors-node_modules_node-fetch_src_utils_multipart-parser_js.node-api.js +599 -0
  86. package/es/create.d.ts +6 -31
  87. package/es/tools/request.d.ts +1 -1
  88. package/es/tools/request.js +1 -1
  89. package/es/tools/request.js.map +1 -1
  90. package/es/tools/transactions/transactions.d.ts +2 -2
  91. package/es/tools/transactions/transactions.js +1 -1
  92. package/es/tools/transactions/transactions.js.map +1 -1
  93. package/package.json +4 -4
@@ -0,0 +1,467 @@
1
+ (this["webpackJsonpnodeApi"] = this["webpackJsonpnodeApi"] || []).push([[0],{
2
+
3
+ /***/ "./node_modules/fetch-blob/from.js":
4
+ /*!*****************************************!*\
5
+ !*** ./node_modules/fetch-blob/from.js ***!
6
+ \*****************************************/
7
+ /*! no static exports found */
8
+ /*! exports used: File */
9
+ /***/ (function(module, exports) {
10
+
11
+ throw new Error("Module parse failed: Unexpected character '#' (60:2)\nYou may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders\n| */\n| class BlobDataItem {\n> #path\n| #start\n| ");
12
+
13
+ /***/ }),
14
+
15
+ /***/ "./node_modules/node-fetch/src/utils/multipart-parser.js":
16
+ /*!***************************************************************!*\
17
+ !*** ./node_modules/node-fetch/src/utils/multipart-parser.js ***!
18
+ \***************************************************************/
19
+ /*! exports provided: toFormData */
20
+ /*! all exports used */
21
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
22
+
23
+ "use strict";
24
+ __webpack_require__.r(__webpack_exports__);
25
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toFormData", function() { return toFormData; });
26
+ /* harmony import */ var fetch_blob_from_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! fetch-blob/from.js */ "./node_modules/fetch-blob/from.js");
27
+ /* harmony import */ var fetch_blob_from_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(fetch_blob_from_js__WEBPACK_IMPORTED_MODULE_0__);
28
+ /* harmony import */ var formdata_polyfill_esm_min_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! formdata-polyfill/esm.min.js */ "./node_modules/formdata-polyfill/esm.min.js");
29
+ /* harmony import */ var formdata_polyfill_esm_min_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(formdata_polyfill_esm_min_js__WEBPACK_IMPORTED_MODULE_1__);
30
+
31
+
32
+
33
+ let s = 0;
34
+ const S = {
35
+ START_BOUNDARY: s++,
36
+ HEADER_FIELD_START: s++,
37
+ HEADER_FIELD: s++,
38
+ HEADER_VALUE_START: s++,
39
+ HEADER_VALUE: s++,
40
+ HEADER_VALUE_ALMOST_DONE: s++,
41
+ HEADERS_ALMOST_DONE: s++,
42
+ PART_DATA_START: s++,
43
+ PART_DATA: s++,
44
+ END: s++
45
+ };
46
+
47
+ let f = 1;
48
+ const F = {
49
+ PART_BOUNDARY: f,
50
+ LAST_BOUNDARY: f *= 2
51
+ };
52
+
53
+ const LF = 10;
54
+ const CR = 13;
55
+ const SPACE = 32;
56
+ const HYPHEN = 45;
57
+ const COLON = 58;
58
+ const A = 97;
59
+ const Z = 122;
60
+
61
+ const lower = c => c | 0x20;
62
+
63
+ const noop = () => {};
64
+
65
+ class MultipartParser {
66
+ /**
67
+ * @param {string} boundary
68
+ */
69
+ constructor(boundary) {
70
+ this.index = 0;
71
+ this.flags = 0;
72
+
73
+ this.onHeaderEnd = noop;
74
+ this.onHeaderField = noop;
75
+ this.onHeadersEnd = noop;
76
+ this.onHeaderValue = noop;
77
+ this.onPartBegin = noop;
78
+ this.onPartData = noop;
79
+ this.onPartEnd = noop;
80
+
81
+ this.boundaryChars = {};
82
+
83
+ boundary = '\r\n--' + boundary;
84
+ const ui8a = new Uint8Array(boundary.length);
85
+ for (let i = 0; i < boundary.length; i++) {
86
+ ui8a[i] = boundary.charCodeAt(i);
87
+ this.boundaryChars[ui8a[i]] = true;
88
+ }
89
+
90
+ this.boundary = ui8a;
91
+ this.lookbehind = new Uint8Array(this.boundary.length + 8);
92
+ this.state = S.START_BOUNDARY;
93
+ }
94
+
95
+ /**
96
+ * @param {Uint8Array} data
97
+ */
98
+ write(data) {
99
+ let i = 0;
100
+ const length_ = data.length;
101
+ let previousIndex = this.index;
102
+ let {lookbehind, boundary, boundaryChars, index, state, flags} = this;
103
+ const boundaryLength = this.boundary.length;
104
+ const boundaryEnd = boundaryLength - 1;
105
+ const bufferLength = data.length;
106
+ let c;
107
+ let cl;
108
+
109
+ const mark = name => {
110
+ this[name + 'Mark'] = i;
111
+ };
112
+
113
+ const clear = name => {
114
+ delete this[name + 'Mark'];
115
+ };
116
+
117
+ const callback = (callbackSymbol, start, end, ui8a) => {
118
+ if (start === undefined || start !== end) {
119
+ this[callbackSymbol](ui8a && ui8a.subarray(start, end));
120
+ }
121
+ };
122
+
123
+ const dataCallback = (name, clear) => {
124
+ const markSymbol = name + 'Mark';
125
+ if (!(markSymbol in this)) {
126
+ return;
127
+ }
128
+
129
+ if (clear) {
130
+ callback(name, this[markSymbol], i, data);
131
+ delete this[markSymbol];
132
+ } else {
133
+ callback(name, this[markSymbol], data.length, data);
134
+ this[markSymbol] = 0;
135
+ }
136
+ };
137
+
138
+ for (i = 0; i < length_; i++) {
139
+ c = data[i];
140
+
141
+ switch (state) {
142
+ case S.START_BOUNDARY:
143
+ if (index === boundary.length - 2) {
144
+ if (c === HYPHEN) {
145
+ flags |= F.LAST_BOUNDARY;
146
+ } else if (c !== CR) {
147
+ return;
148
+ }
149
+
150
+ index++;
151
+ break;
152
+ } else if (index - 1 === boundary.length - 2) {
153
+ if (flags & F.LAST_BOUNDARY && c === HYPHEN) {
154
+ state = S.END;
155
+ flags = 0;
156
+ } else if (!(flags & F.LAST_BOUNDARY) && c === LF) {
157
+ index = 0;
158
+ callback('onPartBegin');
159
+ state = S.HEADER_FIELD_START;
160
+ } else {
161
+ return;
162
+ }
163
+
164
+ break;
165
+ }
166
+
167
+ if (c !== boundary[index + 2]) {
168
+ index = -2;
169
+ }
170
+
171
+ if (c === boundary[index + 2]) {
172
+ index++;
173
+ }
174
+
175
+ break;
176
+ case S.HEADER_FIELD_START:
177
+ state = S.HEADER_FIELD;
178
+ mark('onHeaderField');
179
+ index = 0;
180
+ // falls through
181
+ case S.HEADER_FIELD:
182
+ if (c === CR) {
183
+ clear('onHeaderField');
184
+ state = S.HEADERS_ALMOST_DONE;
185
+ break;
186
+ }
187
+
188
+ index++;
189
+ if (c === HYPHEN) {
190
+ break;
191
+ }
192
+
193
+ if (c === COLON) {
194
+ if (index === 1) {
195
+ // empty header field
196
+ return;
197
+ }
198
+
199
+ dataCallback('onHeaderField', true);
200
+ state = S.HEADER_VALUE_START;
201
+ break;
202
+ }
203
+
204
+ cl = lower(c);
205
+ if (cl < A || cl > Z) {
206
+ return;
207
+ }
208
+
209
+ break;
210
+ case S.HEADER_VALUE_START:
211
+ if (c === SPACE) {
212
+ break;
213
+ }
214
+
215
+ mark('onHeaderValue');
216
+ state = S.HEADER_VALUE;
217
+ // falls through
218
+ case S.HEADER_VALUE:
219
+ if (c === CR) {
220
+ dataCallback('onHeaderValue', true);
221
+ callback('onHeaderEnd');
222
+ state = S.HEADER_VALUE_ALMOST_DONE;
223
+ }
224
+
225
+ break;
226
+ case S.HEADER_VALUE_ALMOST_DONE:
227
+ if (c !== LF) {
228
+ return;
229
+ }
230
+
231
+ state = S.HEADER_FIELD_START;
232
+ break;
233
+ case S.HEADERS_ALMOST_DONE:
234
+ if (c !== LF) {
235
+ return;
236
+ }
237
+
238
+ callback('onHeadersEnd');
239
+ state = S.PART_DATA_START;
240
+ break;
241
+ case S.PART_DATA_START:
242
+ state = S.PART_DATA;
243
+ mark('onPartData');
244
+ // falls through
245
+ case S.PART_DATA:
246
+ previousIndex = index;
247
+
248
+ if (index === 0) {
249
+ // boyer-moore derrived algorithm to safely skip non-boundary data
250
+ i += boundaryEnd;
251
+ while (i < bufferLength && !(data[i] in boundaryChars)) {
252
+ i += boundaryLength;
253
+ }
254
+
255
+ i -= boundaryEnd;
256
+ c = data[i];
257
+ }
258
+
259
+ if (index < boundary.length) {
260
+ if (boundary[index] === c) {
261
+ if (index === 0) {
262
+ dataCallback('onPartData', true);
263
+ }
264
+
265
+ index++;
266
+ } else {
267
+ index = 0;
268
+ }
269
+ } else if (index === boundary.length) {
270
+ index++;
271
+ if (c === CR) {
272
+ // CR = part boundary
273
+ flags |= F.PART_BOUNDARY;
274
+ } else if (c === HYPHEN) {
275
+ // HYPHEN = end boundary
276
+ flags |= F.LAST_BOUNDARY;
277
+ } else {
278
+ index = 0;
279
+ }
280
+ } else if (index - 1 === boundary.length) {
281
+ if (flags & F.PART_BOUNDARY) {
282
+ index = 0;
283
+ if (c === LF) {
284
+ // unset the PART_BOUNDARY flag
285
+ flags &= ~F.PART_BOUNDARY;
286
+ callback('onPartEnd');
287
+ callback('onPartBegin');
288
+ state = S.HEADER_FIELD_START;
289
+ break;
290
+ }
291
+ } else if (flags & F.LAST_BOUNDARY) {
292
+ if (c === HYPHEN) {
293
+ callback('onPartEnd');
294
+ state = S.END;
295
+ flags = 0;
296
+ } else {
297
+ index = 0;
298
+ }
299
+ } else {
300
+ index = 0;
301
+ }
302
+ }
303
+
304
+ if (index > 0) {
305
+ // when matching a possible boundary, keep a lookbehind reference
306
+ // in case it turns out to be a false lead
307
+ lookbehind[index - 1] = c;
308
+ } else if (previousIndex > 0) {
309
+ // if our boundary turned out to be rubbish, the captured lookbehind
310
+ // belongs to partData
311
+ const _lookbehind = new Uint8Array(lookbehind.buffer, lookbehind.byteOffset, lookbehind.byteLength);
312
+ callback('onPartData', 0, previousIndex, _lookbehind);
313
+ previousIndex = 0;
314
+ mark('onPartData');
315
+
316
+ // reconsider the current character even so it interrupted the sequence
317
+ // it could be the beginning of a new sequence
318
+ i--;
319
+ }
320
+
321
+ break;
322
+ case S.END:
323
+ break;
324
+ default:
325
+ throw new Error(`Unexpected state entered: ${state}`);
326
+ }
327
+ }
328
+
329
+ dataCallback('onHeaderField');
330
+ dataCallback('onHeaderValue');
331
+ dataCallback('onPartData');
332
+
333
+ // Update properties for the next call
334
+ this.index = index;
335
+ this.state = state;
336
+ this.flags = flags;
337
+ }
338
+
339
+ end() {
340
+ if ((this.state === S.HEADER_FIELD_START && this.index === 0) ||
341
+ (this.state === S.PART_DATA && this.index === this.boundary.length)) {
342
+ this.onPartEnd();
343
+ } else if (this.state !== S.END) {
344
+ throw new Error('MultipartParser.end(): stream ended unexpectedly');
345
+ }
346
+ }
347
+ }
348
+
349
+ function _fileName(headerValue) {
350
+ // matches either a quoted-string or a token (RFC 2616 section 19.5.1)
351
+ const m = headerValue.match(/\bfilename=("(.*?)"|([^()<>@,;:\\"/[\]?={}\s\t]+))($|;\s)/i);
352
+ if (!m) {
353
+ return;
354
+ }
355
+
356
+ const match = m[2] || m[3] || '';
357
+ let filename = match.slice(match.lastIndexOf('\\') + 1);
358
+ filename = filename.replace(/%22/g, '"');
359
+ filename = filename.replace(/&#(\d{4});/g, (m, code) => {
360
+ return String.fromCharCode(code);
361
+ });
362
+ return filename;
363
+ }
364
+
365
+ async function toFormData(Body, ct) {
366
+ if (!/multipart/i.test(ct)) {
367
+ throw new TypeError('Failed to fetch');
368
+ }
369
+
370
+ const m = ct.match(/boundary=(?:"([^"]+)"|([^;]+))/i);
371
+
372
+ if (!m) {
373
+ throw new TypeError('no or bad content-type header, no multipart boundary');
374
+ }
375
+
376
+ const parser = new MultipartParser(m[1] || m[2]);
377
+
378
+ let headerField;
379
+ let headerValue;
380
+ let entryValue;
381
+ let entryName;
382
+ let contentType;
383
+ let filename;
384
+ const entryChunks = [];
385
+ const formData = new formdata_polyfill_esm_min_js__WEBPACK_IMPORTED_MODULE_1__["FormData"]();
386
+
387
+ const onPartData = ui8a => {
388
+ entryValue += decoder.decode(ui8a, {stream: true});
389
+ };
390
+
391
+ const appendToFile = ui8a => {
392
+ entryChunks.push(ui8a);
393
+ };
394
+
395
+ const appendFileToFormData = () => {
396
+ const file = new fetch_blob_from_js__WEBPACK_IMPORTED_MODULE_0__["File"](entryChunks, filename, {type: contentType});
397
+ formData.append(entryName, file);
398
+ };
399
+
400
+ const appendEntryToFormData = () => {
401
+ formData.append(entryName, entryValue);
402
+ };
403
+
404
+ const decoder = new TextDecoder('utf-8');
405
+ decoder.decode();
406
+
407
+ parser.onPartBegin = function () {
408
+ parser.onPartData = onPartData;
409
+ parser.onPartEnd = appendEntryToFormData;
410
+
411
+ headerField = '';
412
+ headerValue = '';
413
+ entryValue = '';
414
+ entryName = '';
415
+ contentType = '';
416
+ filename = null;
417
+ entryChunks.length = 0;
418
+ };
419
+
420
+ parser.onHeaderField = function (ui8a) {
421
+ headerField += decoder.decode(ui8a, {stream: true});
422
+ };
423
+
424
+ parser.onHeaderValue = function (ui8a) {
425
+ headerValue += decoder.decode(ui8a, {stream: true});
426
+ };
427
+
428
+ parser.onHeaderEnd = function () {
429
+ headerValue += decoder.decode();
430
+ headerField = headerField.toLowerCase();
431
+
432
+ if (headerField === 'content-disposition') {
433
+ // matches either a quoted-string or a token (RFC 2616 section 19.5.1)
434
+ const m = headerValue.match(/\bname=("([^"]*)"|([^()<>@,;:\\"/[\]?={}\s\t]+))/i);
435
+
436
+ if (m) {
437
+ entryName = m[2] || m[3] || '';
438
+ }
439
+
440
+ filename = _fileName(headerValue);
441
+
442
+ if (filename) {
443
+ parser.onPartData = appendToFile;
444
+ parser.onPartEnd = appendFileToFormData;
445
+ }
446
+ } else if (headerField === 'content-type') {
447
+ contentType = headerValue;
448
+ }
449
+
450
+ headerValue = '';
451
+ headerField = '';
452
+ };
453
+
454
+ for await (const chunk of Body) {
455
+ parser.write(chunk);
456
+ }
457
+
458
+ parser.end();
459
+
460
+ return formData;
461
+ }
462
+
463
+
464
+ /***/ })
465
+
466
+ }]);
467
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ub2RlQXBpLy4vbm9kZV9tb2R1bGVzL25vZGUtZmV0Y2gvc3JjL3V0aWxzL211bHRpcGFydC1wYXJzZXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBd0M7QUFDYzs7QUFFdEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EsWUFBWSxPQUFPO0FBQ25CO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQSxpQkFBaUIscUJBQXFCO0FBQ3RDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFlBQVksV0FBVztBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyx5REFBeUQ7QUFDaEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsYUFBYSxhQUFhO0FBQzFCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrREFBa0QsTUFBTTtBQUN4RDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSw0REFBNEQsWUFBWSxZQUFZO0FBQ3BGO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxvQ0FBb0MsRUFBRSxFQUFFO0FBQ3hDO0FBQ0EsRUFBRTtBQUNGO0FBQ0E7O0FBRU87QUFDUDtBQUNBO0FBQ0E7O0FBRUEsK0NBQStDOztBQUUvQztBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxzQkFBc0IscUVBQVE7O0FBRTlCO0FBQ0Esc0NBQXNDLGFBQWE7QUFDbkQ7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsbUJBQW1CLHVEQUFJLHlCQUF5QixrQkFBa0I7QUFDbEU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLHVDQUF1QyxhQUFhO0FBQ3BEOztBQUVBO0FBQ0EsdUNBQXVDLGFBQWE7QUFDcEQ7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSw0REFBNEQsWUFBWTs7QUFFeEU7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBIiwiZmlsZSI6IjAubm9kZS1hcGkuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0ZpbGV9IGZyb20gJ2ZldGNoLWJsb2IvZnJvbS5qcyc7XG5pbXBvcnQge0Zvcm1EYXRhfSBmcm9tICdmb3JtZGF0YS1wb2x5ZmlsbC9lc20ubWluLmpzJztcblxubGV0IHMgPSAwO1xuY29uc3QgUyA9IHtcblx0U1RBUlRfQk9VTkRBUlk6IHMrKyxcblx0SEVBREVSX0ZJRUxEX1NUQVJUOiBzKyssXG5cdEhFQURFUl9GSUVMRDogcysrLFxuXHRIRUFERVJfVkFMVUVfU1RBUlQ6IHMrKyxcblx0SEVBREVSX1ZBTFVFOiBzKyssXG5cdEhFQURFUl9WQUxVRV9BTE1PU1RfRE9ORTogcysrLFxuXHRIRUFERVJTX0FMTU9TVF9ET05FOiBzKyssXG5cdFBBUlRfREFUQV9TVEFSVDogcysrLFxuXHRQQVJUX0RBVEE6IHMrKyxcblx0RU5EOiBzKytcbn07XG5cbmxldCBmID0gMTtcbmNvbnN0IEYgPSB7XG5cdFBBUlRfQk9VTkRBUlk6IGYsXG5cdExBU1RfQk9VTkRBUlk6IGYgKj0gMlxufTtcblxuY29uc3QgTEYgPSAxMDtcbmNvbnN0IENSID0gMTM7XG5jb25zdCBTUEFDRSA9IDMyO1xuY29uc3QgSFlQSEVOID0gNDU7XG5jb25zdCBDT0xPTiA9IDU4O1xuY29uc3QgQSA9IDk3O1xuY29uc3QgWiA9IDEyMjtcblxuY29uc3QgbG93ZXIgPSBjID0+IGMgfCAweDIwO1xuXG5jb25zdCBub29wID0gKCkgPT4ge307XG5cbmNsYXNzIE11bHRpcGFydFBhcnNlciB7XG5cdC8qKlxuXHQgKiBAcGFyYW0ge3N0cmluZ30gYm91bmRhcnlcblx0ICovXG5cdGNvbnN0cnVjdG9yKGJvdW5kYXJ5KSB7XG5cdFx0dGhpcy5pbmRleCA9IDA7XG5cdFx0dGhpcy5mbGFncyA9IDA7XG5cblx0XHR0aGlzLm9uSGVhZGVyRW5kID0gbm9vcDtcblx0XHR0aGlzLm9uSGVhZGVyRmllbGQgPSBub29wO1xuXHRcdHRoaXMub25IZWFkZXJzRW5kID0gbm9vcDtcblx0XHR0aGlzLm9uSGVhZGVyVmFsdWUgPSBub29wO1xuXHRcdHRoaXMub25QYXJ0QmVnaW4gPSBub29wO1xuXHRcdHRoaXMub25QYXJ0RGF0YSA9IG5vb3A7XG5cdFx0dGhpcy5vblBhcnRFbmQgPSBub29wO1xuXG5cdFx0dGhpcy5ib3VuZGFyeUNoYXJzID0ge307XG5cblx0XHRib3VuZGFyeSA9ICdcXHJcXG4tLScgKyBib3VuZGFyeTtcblx0XHRjb25zdCB1aThhID0gbmV3IFVpbnQ4QXJyYXkoYm91bmRhcnkubGVuZ3RoKTtcblx0XHRmb3IgKGxldCBpID0gMDsgaSA8IGJvdW5kYXJ5Lmxlbmd0aDsgaSsrKSB7XG5cdFx0XHR1aThhW2ldID0gYm91bmRhcnkuY2hhckNvZGVBdChpKTtcblx0XHRcdHRoaXMuYm91bmRhcnlDaGFyc1t1aThhW2ldXSA9IHRydWU7XG5cdFx0fVxuXG5cdFx0dGhpcy5ib3VuZGFyeSA9IHVpOGE7XG5cdFx0dGhpcy5sb29rYmVoaW5kID0gbmV3IFVpbnQ4QXJyYXkodGhpcy5ib3VuZGFyeS5sZW5ndGggKyA4KTtcblx0XHR0aGlzLnN0YXRlID0gUy5TVEFSVF9CT1VOREFSWTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAcGFyYW0ge1VpbnQ4QXJyYXl9IGRhdGFcblx0ICovXG5cdHdyaXRlKGRhdGEpIHtcblx0XHRsZXQgaSA9IDA7XG5cdFx0Y29uc3QgbGVuZ3RoXyA9IGRhdGEubGVuZ3RoO1xuXHRcdGxldCBwcmV2aW91c0luZGV4ID0gdGhpcy5pbmRleDtcblx0XHRsZXQge2xvb2tiZWhpbmQsIGJvdW5kYXJ5LCBib3VuZGFyeUNoYXJzLCBpbmRleCwgc3RhdGUsIGZsYWdzfSA9IHRoaXM7XG5cdFx0Y29uc3QgYm91bmRhcnlMZW5ndGggPSB0aGlzLmJvdW5kYXJ5Lmxlbmd0aDtcblx0XHRjb25zdCBib3VuZGFyeUVuZCA9IGJvdW5kYXJ5TGVuZ3RoIC0gMTtcblx0XHRjb25zdCBidWZmZXJMZW5ndGggPSBkYXRhLmxlbmd0aDtcblx0XHRsZXQgYztcblx0XHRsZXQgY2w7XG5cblx0XHRjb25zdCBtYXJrID0gbmFtZSA9PiB7XG5cdFx0XHR0aGlzW25hbWUgKyAnTWFyayddID0gaTtcblx0XHR9O1xuXG5cdFx0Y29uc3QgY2xlYXIgPSBuYW1lID0+IHtcblx0XHRcdGRlbGV0ZSB0aGlzW25hbWUgKyAnTWFyayddO1xuXHRcdH07XG5cblx0XHRjb25zdCBjYWxsYmFjayA9IChjYWxsYmFja1N5bWJvbCwgc3RhcnQsIGVuZCwgdWk4YSkgPT4ge1xuXHRcdFx0aWYgKHN0YXJ0ID09PSB1bmRlZmluZWQgfHwgc3RhcnQgIT09IGVuZCkge1xuXHRcdFx0XHR0aGlzW2NhbGxiYWNrU3ltYm9sXSh1aThhICYmIHVpOGEuc3ViYXJyYXkoc3RhcnQsIGVuZCkpO1xuXHRcdFx0fVxuXHRcdH07XG5cblx0XHRjb25zdCBkYXRhQ2FsbGJhY2sgPSAobmFtZSwgY2xlYXIpID0+IHtcblx0XHRcdGNvbnN0IG1hcmtTeW1ib2wgPSBuYW1lICsgJ01hcmsnO1xuXHRcdFx0aWYgKCEobWFya1N5bWJvbCBpbiB0aGlzKSkge1xuXHRcdFx0XHRyZXR1cm47XG5cdFx0XHR9XG5cblx0XHRcdGlmIChjbGVhcikge1xuXHRcdFx0XHRjYWxsYmFjayhuYW1lLCB0aGlzW21hcmtTeW1ib2xdLCBpLCBkYXRhKTtcblx0XHRcdFx0ZGVsZXRlIHRoaXNbbWFya1N5bWJvbF07XG5cdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRjYWxsYmFjayhuYW1lLCB0aGlzW21hcmtTeW1ib2xdLCBkYXRhLmxlbmd0aCwgZGF0YSk7XG5cdFx0XHRcdHRoaXNbbWFya1N5bWJvbF0gPSAwO1xuXHRcdFx0fVxuXHRcdH07XG5cblx0XHRmb3IgKGkgPSAwOyBpIDwgbGVuZ3RoXzsgaSsrKSB7XG5cdFx0XHRjID0gZGF0YVtpXTtcblxuXHRcdFx0c3dpdGNoIChzdGF0ZSkge1xuXHRcdFx0XHRjYXNlIFMuU1RBUlRfQk9VTkRBUlk6XG5cdFx0XHRcdFx0aWYgKGluZGV4ID09PSBib3VuZGFyeS5sZW5ndGggLSAyKSB7XG5cdFx0XHRcdFx0XHRpZiAoYyA9PT0gSFlQSEVOKSB7XG5cdFx0XHRcdFx0XHRcdGZsYWdzIHw9IEYuTEFTVF9CT1VOREFSWTtcblx0XHRcdFx0XHRcdH0gZWxzZSBpZiAoYyAhPT0gQ1IpIHtcblx0XHRcdFx0XHRcdFx0cmV0dXJuO1xuXHRcdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0XHRpbmRleCsrO1xuXHRcdFx0XHRcdFx0YnJlYWs7XG5cdFx0XHRcdFx0fSBlbHNlIGlmIChpbmRleCAtIDEgPT09IGJvdW5kYXJ5Lmxlbmd0aCAtIDIpIHtcblx0XHRcdFx0XHRcdGlmIChmbGFncyAmIEYuTEFTVF9CT1VOREFSWSAmJiBjID09PSBIWVBIRU4pIHtcblx0XHRcdFx0XHRcdFx0c3RhdGUgPSBTLkVORDtcblx0XHRcdFx0XHRcdFx0ZmxhZ3MgPSAwO1xuXHRcdFx0XHRcdFx0fSBlbHNlIGlmICghKGZsYWdzICYgRi5MQVNUX0JPVU5EQVJZKSAmJiBjID09PSBMRikge1xuXHRcdFx0XHRcdFx0XHRpbmRleCA9IDA7XG5cdFx0XHRcdFx0XHRcdGNhbGxiYWNrKCdvblBhcnRCZWdpbicpO1xuXHRcdFx0XHRcdFx0XHRzdGF0ZSA9IFMuSEVBREVSX0ZJRUxEX1NUQVJUO1xuXHRcdFx0XHRcdFx0fSBlbHNlIHtcblx0XHRcdFx0XHRcdFx0cmV0dXJuO1xuXHRcdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRpZiAoYyAhPT0gYm91bmRhcnlbaW5kZXggKyAyXSkge1xuXHRcdFx0XHRcdFx0aW5kZXggPSAtMjtcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRpZiAoYyA9PT0gYm91bmRhcnlbaW5kZXggKyAyXSkge1xuXHRcdFx0XHRcdFx0aW5kZXgrKztcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0Y2FzZSBTLkhFQURFUl9GSUVMRF9TVEFSVDpcblx0XHRcdFx0XHRzdGF0ZSA9IFMuSEVBREVSX0ZJRUxEO1xuXHRcdFx0XHRcdG1hcmsoJ29uSGVhZGVyRmllbGQnKTtcblx0XHRcdFx0XHRpbmRleCA9IDA7XG5cdFx0XHRcdFx0Ly8gZmFsbHMgdGhyb3VnaFxuXHRcdFx0XHRjYXNlIFMuSEVBREVSX0ZJRUxEOlxuXHRcdFx0XHRcdGlmIChjID09PSBDUikge1xuXHRcdFx0XHRcdFx0Y2xlYXIoJ29uSGVhZGVyRmllbGQnKTtcblx0XHRcdFx0XHRcdHN0YXRlID0gUy5IRUFERVJTX0FMTU9TVF9ET05FO1xuXHRcdFx0XHRcdFx0YnJlYWs7XG5cdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0aW5kZXgrKztcblx0XHRcdFx0XHRpZiAoYyA9PT0gSFlQSEVOKSB7XG5cdFx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRpZiAoYyA9PT0gQ09MT04pIHtcblx0XHRcdFx0XHRcdGlmIChpbmRleCA9PT0gMSkge1xuXHRcdFx0XHRcdFx0XHQvLyBlbXB0eSBoZWFkZXIgZmllbGRcblx0XHRcdFx0XHRcdFx0cmV0dXJuO1xuXHRcdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0XHRkYXRhQ2FsbGJhY2soJ29uSGVhZGVyRmllbGQnLCB0cnVlKTtcblx0XHRcdFx0XHRcdHN0YXRlID0gUy5IRUFERVJfVkFMVUVfU1RBUlQ7XG5cdFx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRjbCA9IGxvd2VyKGMpO1xuXHRcdFx0XHRcdGlmIChjbCA8IEEgfHwgY2wgPiBaKSB7XG5cdFx0XHRcdFx0XHRyZXR1cm47XG5cdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0YnJlYWs7XG5cdFx0XHRcdGNhc2UgUy5IRUFERVJfVkFMVUVfU1RBUlQ6XG5cdFx0XHRcdFx0aWYgKGMgPT09IFNQQUNFKSB7XG5cdFx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRtYXJrKCdvbkhlYWRlclZhbHVlJyk7XG5cdFx0XHRcdFx0c3RhdGUgPSBTLkhFQURFUl9WQUxVRTtcblx0XHRcdFx0XHQvLyBmYWxscyB0aHJvdWdoXG5cdFx0XHRcdGNhc2UgUy5IRUFERVJfVkFMVUU6XG5cdFx0XHRcdFx0aWYgKGMgPT09IENSKSB7XG5cdFx0XHRcdFx0XHRkYXRhQ2FsbGJhY2soJ29uSGVhZGVyVmFsdWUnLCB0cnVlKTtcblx0XHRcdFx0XHRcdGNhbGxiYWNrKCdvbkhlYWRlckVuZCcpO1xuXHRcdFx0XHRcdFx0c3RhdGUgPSBTLkhFQURFUl9WQUxVRV9BTE1PU1RfRE9ORTtcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0Y2FzZSBTLkhFQURFUl9WQUxVRV9BTE1PU1RfRE9ORTpcblx0XHRcdFx0XHRpZiAoYyAhPT0gTEYpIHtcblx0XHRcdFx0XHRcdHJldHVybjtcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRzdGF0ZSA9IFMuSEVBREVSX0ZJRUxEX1NUQVJUO1xuXHRcdFx0XHRcdGJyZWFrO1xuXHRcdFx0XHRjYXNlIFMuSEVBREVSU19BTE1PU1RfRE9ORTpcblx0XHRcdFx0XHRpZiAoYyAhPT0gTEYpIHtcblx0XHRcdFx0XHRcdHJldHVybjtcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRjYWxsYmFjaygnb25IZWFkZXJzRW5kJyk7XG5cdFx0XHRcdFx0c3RhdGUgPSBTLlBBUlRfREFUQV9TVEFSVDtcblx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0Y2FzZSBTLlBBUlRfREFUQV9TVEFSVDpcblx0XHRcdFx0XHRzdGF0ZSA9IFMuUEFSVF9EQVRBO1xuXHRcdFx0XHRcdG1hcmsoJ29uUGFydERhdGEnKTtcblx0XHRcdFx0XHQvLyBmYWxscyB0aHJvdWdoXG5cdFx0XHRcdGNhc2UgUy5QQVJUX0RBVEE6XG5cdFx0XHRcdFx0cHJldmlvdXNJbmRleCA9IGluZGV4O1xuXG5cdFx0XHRcdFx0aWYgKGluZGV4ID09PSAwKSB7XG5cdFx0XHRcdFx0XHQvLyBib3llci1tb29yZSBkZXJyaXZlZCBhbGdvcml0aG0gdG8gc2FmZWx5IHNraXAgbm9uLWJvdW5kYXJ5IGRhdGFcblx0XHRcdFx0XHRcdGkgKz0gYm91bmRhcnlFbmQ7XG5cdFx0XHRcdFx0XHR3aGlsZSAoaSA8IGJ1ZmZlckxlbmd0aCAmJiAhKGRhdGFbaV0gaW4gYm91bmRhcnlDaGFycykpIHtcblx0XHRcdFx0XHRcdFx0aSArPSBib3VuZGFyeUxlbmd0aDtcblx0XHRcdFx0XHRcdH1cblxuXHRcdFx0XHRcdFx0aSAtPSBib3VuZGFyeUVuZDtcblx0XHRcdFx0XHRcdGMgPSBkYXRhW2ldO1xuXHRcdFx0XHRcdH1cblxuXHRcdFx0XHRcdGlmIChpbmRleCA8IGJvdW5kYXJ5Lmxlbmd0aCkge1xuXHRcdFx0XHRcdFx0aWYgKGJvdW5kYXJ5W2luZGV4XSA9PT0gYykge1xuXHRcdFx0XHRcdFx0XHRpZiAoaW5kZXggPT09IDApIHtcblx0XHRcdFx0XHRcdFx0XHRkYXRhQ2FsbGJhY2soJ29uUGFydERhdGEnLCB0cnVlKTtcblx0XHRcdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0XHRcdGluZGV4Kys7XG5cdFx0XHRcdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRcdFx0XHRpbmRleCA9IDA7XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0fSBlbHNlIGlmIChpbmRleCA9PT0gYm91bmRhcnkubGVuZ3RoKSB7XG5cdFx0XHRcdFx0XHRpbmRleCsrO1xuXHRcdFx0XHRcdFx0aWYgKGMgPT09IENSKSB7XG5cdFx0XHRcdFx0XHRcdC8vIENSID0gcGFydCBib3VuZGFyeVxuXHRcdFx0XHRcdFx0XHRmbGFncyB8PSBGLlBBUlRfQk9VTkRBUlk7XG5cdFx0XHRcdFx0XHR9IGVsc2UgaWYgKGMgPT09IEhZUEhFTikge1xuXHRcdFx0XHRcdFx0XHQvLyBIWVBIRU4gPSBlbmQgYm91bmRhcnlcblx0XHRcdFx0XHRcdFx0ZmxhZ3MgfD0gRi5MQVNUX0JPVU5EQVJZO1xuXHRcdFx0XHRcdFx0fSBlbHNlIHtcblx0XHRcdFx0XHRcdFx0aW5kZXggPSAwO1xuXHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdH0gZWxzZSBpZiAoaW5kZXggLSAxID09PSBib3VuZGFyeS5sZW5ndGgpIHtcblx0XHRcdFx0XHRcdGlmIChmbGFncyAmIEYuUEFSVF9CT1VOREFSWSkge1xuXHRcdFx0XHRcdFx0XHRpbmRleCA9IDA7XG5cdFx0XHRcdFx0XHRcdGlmIChjID09PSBMRikge1xuXHRcdFx0XHRcdFx0XHRcdC8vIHVuc2V0IHRoZSBQQVJUX0JPVU5EQVJZIGZsYWdcblx0XHRcdFx0XHRcdFx0XHRmbGFncyAmPSB+Ri5QQVJUX0JPVU5EQVJZO1xuXHRcdFx0XHRcdFx0XHRcdGNhbGxiYWNrKCdvblBhcnRFbmQnKTtcblx0XHRcdFx0XHRcdFx0XHRjYWxsYmFjaygnb25QYXJ0QmVnaW4nKTtcblx0XHRcdFx0XHRcdFx0XHRzdGF0ZSA9IFMuSEVBREVSX0ZJRUxEX1NUQVJUO1xuXHRcdFx0XHRcdFx0XHRcdGJyZWFrO1xuXHRcdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0XHR9IGVsc2UgaWYgKGZsYWdzICYgRi5MQVNUX0JPVU5EQVJZKSB7XG5cdFx0XHRcdFx0XHRcdGlmIChjID09PSBIWVBIRU4pIHtcblx0XHRcdFx0XHRcdFx0XHRjYWxsYmFjaygnb25QYXJ0RW5kJyk7XG5cdFx0XHRcdFx0XHRcdFx0c3RhdGUgPSBTLkVORDtcblx0XHRcdFx0XHRcdFx0XHRmbGFncyA9IDA7XG5cdFx0XHRcdFx0XHRcdH0gZWxzZSB7XG5cdFx0XHRcdFx0XHRcdFx0aW5kZXggPSAwO1xuXHRcdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRcdFx0XHRpbmRleCA9IDA7XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0aWYgKGluZGV4ID4gMCkge1xuXHRcdFx0XHRcdFx0Ly8gd2hlbiBtYXRjaGluZyBhIHBvc3NpYmxlIGJvdW5kYXJ5LCBrZWVwIGEgbG9va2JlaGluZCByZWZlcmVuY2Vcblx0XHRcdFx0XHRcdC8vIGluIGNhc2UgaXQgdHVybnMgb3V0IHRvIGJlIGEgZmFsc2UgbGVhZFxuXHRcdFx0XHRcdFx0bG9va2JlaGluZFtpbmRleCAtIDFdID0gYztcblx0XHRcdFx0XHR9IGVsc2UgaWYgKHByZXZpb3VzSW5kZXggPiAwKSB7XG5cdFx0XHRcdFx0XHQvLyBpZiBvdXIgYm91bmRhcnkgdHVybmVkIG91dCB0byBiZSBydWJiaXNoLCB0aGUgY2FwdHVyZWQgbG9va2JlaGluZFxuXHRcdFx0XHRcdFx0Ly8gYmVsb25ncyB0byBwYXJ0RGF0YVxuXHRcdFx0XHRcdFx0Y29uc3QgX2xvb2tiZWhpbmQgPSBuZXcgVWludDhBcnJheShsb29rYmVoaW5kLmJ1ZmZlciwgbG9va2JlaGluZC5ieXRlT2Zmc2V0LCBsb29rYmVoaW5kLmJ5dGVMZW5ndGgpO1xuXHRcdFx0XHRcdFx0Y2FsbGJhY2soJ29uUGFydERhdGEnLCAwLCBwcmV2aW91c0luZGV4LCBfbG9va2JlaGluZCk7XG5cdFx0XHRcdFx0XHRwcmV2aW91c0luZGV4ID0gMDtcblx0XHRcdFx0XHRcdG1hcmsoJ29uUGFydERhdGEnKTtcblxuXHRcdFx0XHRcdFx0Ly8gcmVjb25zaWRlciB0aGUgY3VycmVudCBjaGFyYWN0ZXIgZXZlbiBzbyBpdCBpbnRlcnJ1cHRlZCB0aGUgc2VxdWVuY2Vcblx0XHRcdFx0XHRcdC8vIGl0IGNvdWxkIGJlIHRoZSBiZWdpbm5pbmcgb2YgYSBuZXcgc2VxdWVuY2Vcblx0XHRcdFx0XHRcdGktLTtcblx0XHRcdFx0XHR9XG5cblx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0Y2FzZSBTLkVORDpcblx0XHRcdFx0XHRicmVhaztcblx0XHRcdFx0ZGVmYXVsdDpcblx0XHRcdFx0XHR0aHJvdyBuZXcgRXJyb3IoYFVuZXhwZWN0ZWQgc3RhdGUgZW50ZXJlZDogJHtzdGF0ZX1gKTtcblx0XHRcdH1cblx0XHR9XG5cblx0XHRkYXRhQ2FsbGJhY2soJ29uSGVhZGVyRmllbGQnKTtcblx0XHRkYXRhQ2FsbGJhY2soJ29uSGVhZGVyVmFsdWUnKTtcblx0XHRkYXRhQ2FsbGJhY2soJ29uUGFydERhdGEnKTtcblxuXHRcdC8vIFVwZGF0ZSBwcm9wZXJ0aWVzIGZvciB0aGUgbmV4dCBjYWxsXG5cdFx0dGhpcy5pbmRleCA9IGluZGV4O1xuXHRcdHRoaXMuc3RhdGUgPSBzdGF0ZTtcblx0XHR0aGlzLmZsYWdzID0gZmxhZ3M7XG5cdH1cblxuXHRlbmQoKSB7XG5cdFx0aWYgKCh0aGlzLnN0YXRlID09PSBTLkhFQURFUl9GSUVMRF9TVEFSVCAmJiB0aGlzLmluZGV4ID09PSAwKSB8fFxuXHRcdFx0KHRoaXMuc3RhdGUgPT09IFMuUEFSVF9EQVRBICYmIHRoaXMuaW5kZXggPT09IHRoaXMuYm91bmRhcnkubGVuZ3RoKSkge1xuXHRcdFx0dGhpcy5vblBhcnRFbmQoKTtcblx0XHR9IGVsc2UgaWYgKHRoaXMuc3RhdGUgIT09IFMuRU5EKSB7XG5cdFx0XHR0aHJvdyBuZXcgRXJyb3IoJ011bHRpcGFydFBhcnNlci5lbmQoKTogc3RyZWFtIGVuZGVkIHVuZXhwZWN0ZWRseScpO1xuXHRcdH1cblx0fVxufVxuXG5mdW5jdGlvbiBfZmlsZU5hbWUoaGVhZGVyVmFsdWUpIHtcblx0Ly8gbWF0Y2hlcyBlaXRoZXIgYSBxdW90ZWQtc3RyaW5nIG9yIGEgdG9rZW4gKFJGQyAyNjE2IHNlY3Rpb24gMTkuNS4xKVxuXHRjb25zdCBtID0gaGVhZGVyVmFsdWUubWF0Y2goL1xcYmZpbGVuYW1lPShcIiguKj8pXCJ8KFteKCk8PkAsOzpcXFxcXCIvW1xcXT89e31cXHNcXHRdKykpKCR8O1xccykvaSk7XG5cdGlmICghbSkge1xuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IG1hdGNoID0gbVsyXSB8fCBtWzNdIHx8ICcnO1xuXHRsZXQgZmlsZW5hbWUgPSBtYXRjaC5zbGljZShtYXRjaC5sYXN0SW5kZXhPZignXFxcXCcpICsgMSk7XG5cdGZpbGVuYW1lID0gZmlsZW5hbWUucmVwbGFjZSgvJTIyL2csICdcIicpO1xuXHRmaWxlbmFtZSA9IGZpbGVuYW1lLnJlcGxhY2UoLyYjKFxcZHs0fSk7L2csIChtLCBjb2RlKSA9PiB7XG5cdFx0cmV0dXJuIFN0cmluZy5mcm9tQ2hhckNvZGUoY29kZSk7XG5cdH0pO1xuXHRyZXR1cm4gZmlsZW5hbWU7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0b0Zvcm1EYXRhKEJvZHksIGN0KSB7XG5cdGlmICghL211bHRpcGFydC9pLnRlc3QoY3QpKSB7XG5cdFx0dGhyb3cgbmV3IFR5cGVFcnJvcignRmFpbGVkIHRvIGZldGNoJyk7XG5cdH1cblxuXHRjb25zdCBtID0gY3QubWF0Y2goL2JvdW5kYXJ5PSg/OlwiKFteXCJdKylcInwoW147XSspKS9pKTtcblxuXHRpZiAoIW0pIHtcblx0XHR0aHJvdyBuZXcgVHlwZUVycm9yKCdubyBvciBiYWQgY29udGVudC10eXBlIGhlYWRlciwgbm8gbXVsdGlwYXJ0IGJvdW5kYXJ5Jyk7XG5cdH1cblxuXHRjb25zdCBwYXJzZXIgPSBuZXcgTXVsdGlwYXJ0UGFyc2VyKG1bMV0gfHwgbVsyXSk7XG5cblx0bGV0IGhlYWRlckZpZWxkO1xuXHRsZXQgaGVhZGVyVmFsdWU7XG5cdGxldCBlbnRyeVZhbHVlO1xuXHRsZXQgZW50cnlOYW1lO1xuXHRsZXQgY29udGVudFR5cGU7XG5cdGxldCBmaWxlbmFtZTtcblx0Y29uc3QgZW50cnlDaHVua3MgPSBbXTtcblx0Y29uc3QgZm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcblxuXHRjb25zdCBvblBhcnREYXRhID0gdWk4YSA9PiB7XG5cdFx0ZW50cnlWYWx1ZSArPSBkZWNvZGVyLmRlY29kZSh1aThhLCB7c3RyZWFtOiB0cnVlfSk7XG5cdH07XG5cblx0Y29uc3QgYXBwZW5kVG9GaWxlID0gdWk4YSA9PiB7XG5cdFx0ZW50cnlDaHVua3MucHVzaCh1aThhKTtcblx0fTtcblxuXHRjb25zdCBhcHBlbmRGaWxlVG9Gb3JtRGF0YSA9ICgpID0+IHtcblx0XHRjb25zdCBmaWxlID0gbmV3IEZpbGUoZW50cnlDaHVua3MsIGZpbGVuYW1lLCB7dHlwZTogY29udGVudFR5cGV9KTtcblx0XHRmb3JtRGF0YS5hcHBlbmQoZW50cnlOYW1lLCBmaWxlKTtcblx0fTtcblxuXHRjb25zdCBhcHBlbmRFbnRyeVRvRm9ybURhdGEgPSAoKSA9PiB7XG5cdFx0Zm9ybURhdGEuYXBwZW5kKGVudHJ5TmFtZSwgZW50cnlWYWx1ZSk7XG5cdH07XG5cblx0Y29uc3QgZGVjb2RlciA9IG5ldyBUZXh0RGVjb2RlcigndXRmLTgnKTtcblx0ZGVjb2Rlci5kZWNvZGUoKTtcblxuXHRwYXJzZXIub25QYXJ0QmVnaW4gPSBmdW5jdGlvbiAoKSB7XG5cdFx0cGFyc2VyLm9uUGFydERhdGEgPSBvblBhcnREYXRhO1xuXHRcdHBhcnNlci5vblBhcnRFbmQgPSBhcHBlbmRFbnRyeVRvRm9ybURhdGE7XG5cblx0XHRoZWFkZXJGaWVsZCA9ICcnO1xuXHRcdGhlYWRlclZhbHVlID0gJyc7XG5cdFx0ZW50cnlWYWx1ZSA9ICcnO1xuXHRcdGVudHJ5TmFtZSA9ICcnO1xuXHRcdGNvbnRlbnRUeXBlID0gJyc7XG5cdFx0ZmlsZW5hbWUgPSBudWxsO1xuXHRcdGVudHJ5Q2h1bmtzLmxlbmd0aCA9IDA7XG5cdH07XG5cblx0cGFyc2VyLm9uSGVhZGVyRmllbGQgPSBmdW5jdGlvbiAodWk4YSkge1xuXHRcdGhlYWRlckZpZWxkICs9IGRlY29kZXIuZGVjb2RlKHVpOGEsIHtzdHJlYW06IHRydWV9KTtcblx0fTtcblxuXHRwYXJzZXIub25IZWFkZXJWYWx1ZSA9IGZ1bmN0aW9uICh1aThhKSB7XG5cdFx0aGVhZGVyVmFsdWUgKz0gZGVjb2Rlci5kZWNvZGUodWk4YSwge3N0cmVhbTogdHJ1ZX0pO1xuXHR9O1xuXG5cdHBhcnNlci5vbkhlYWRlckVuZCA9IGZ1bmN0aW9uICgpIHtcblx0XHRoZWFkZXJWYWx1ZSArPSBkZWNvZGVyLmRlY29kZSgpO1xuXHRcdGhlYWRlckZpZWxkID0gaGVhZGVyRmllbGQudG9Mb3dlckNhc2UoKTtcblxuXHRcdGlmIChoZWFkZXJGaWVsZCA9PT0gJ2NvbnRlbnQtZGlzcG9zaXRpb24nKSB7XG5cdFx0XHQvLyBtYXRjaGVzIGVpdGhlciBhIHF1b3RlZC1zdHJpbmcgb3IgYSB0b2tlbiAoUkZDIDI2MTYgc2VjdGlvbiAxOS41LjEpXG5cdFx0XHRjb25zdCBtID0gaGVhZGVyVmFsdWUubWF0Y2goL1xcYm5hbWU9KFwiKFteXCJdKilcInwoW14oKTw+QCw7OlxcXFxcIi9bXFxdPz17fVxcc1xcdF0rKSkvaSk7XG5cblx0XHRcdGlmIChtKSB7XG5cdFx0XHRcdGVudHJ5TmFtZSA9IG1bMl0gfHwgbVszXSB8fCAnJztcblx0XHRcdH1cblxuXHRcdFx0ZmlsZW5hbWUgPSBfZmlsZU5hbWUoaGVhZGVyVmFsdWUpO1xuXG5cdFx0XHRpZiAoZmlsZW5hbWUpIHtcblx0XHRcdFx0cGFyc2VyLm9uUGFydERhdGEgPSBhcHBlbmRUb0ZpbGU7XG5cdFx0XHRcdHBhcnNlci5vblBhcnRFbmQgPSBhcHBlbmRGaWxlVG9Gb3JtRGF0YTtcblx0XHRcdH1cblx0XHR9IGVsc2UgaWYgKGhlYWRlckZpZWxkID09PSAnY29udGVudC10eXBlJykge1xuXHRcdFx0Y29udGVudFR5cGUgPSBoZWFkZXJWYWx1ZTtcblx0XHR9XG5cblx0XHRoZWFkZXJWYWx1ZSA9ICcnO1xuXHRcdGhlYWRlckZpZWxkID0gJyc7XG5cdH07XG5cblx0Zm9yIGF3YWl0IChjb25zdCBjaHVuayBvZiBCb2R5KSB7XG5cdFx0cGFyc2VyLndyaXRlKGNodW5rKTtcblx0fVxuXG5cdHBhcnNlci5lbmQoKTtcblxuXHRyZXR1cm4gZm9ybURhdGE7XG59XG4iXSwic291cmNlUm9vdCI6IiJ9