@bitgo-beta/sdk-coin-stx 1.4.3-alpha.41 → 1.4.3-alpha.411

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 (74) hide show
  1. package/dist/src/index.d.ts +1 -0
  2. package/dist/src/index.d.ts.map +1 -1
  3. package/dist/src/index.js +24 -9
  4. package/dist/src/lib/abstractContractBuilder.js +2 -2
  5. package/dist/src/lib/constants.d.ts +2 -1
  6. package/dist/src/lib/constants.d.ts.map +1 -1
  7. package/dist/src/lib/constants.js +5 -3
  8. package/dist/src/lib/contractBuilder.js +10 -10
  9. package/dist/src/lib/fungibleTokenTransferBuilder.d.ts +62 -0
  10. package/dist/src/lib/fungibleTokenTransferBuilder.d.ts.map +1 -0
  11. package/dist/src/lib/fungibleTokenTransferBuilder.js +131 -0
  12. package/dist/src/lib/iface.d.ts +56 -0
  13. package/dist/src/lib/iface.d.ts.map +1 -1
  14. package/dist/src/lib/iface.js +1 -1
  15. package/dist/src/lib/index.js +23 -9
  16. package/dist/src/lib/keyPair.js +18 -19
  17. package/dist/src/lib/sendmanyBuilder.js +11 -11
  18. package/dist/src/lib/transaction.d.ts.map +1 -1
  19. package/dist/src/lib/transaction.js +31 -15
  20. package/dist/src/lib/transactionBuilder.js +12 -12
  21. package/dist/src/lib/transactionBuilderFactory.d.ts +2 -0
  22. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  23. package/dist/src/lib/transactionBuilderFactory.js +9 -2
  24. package/dist/src/lib/transferBuilder.js +4 -4
  25. package/dist/src/lib/utils.d.ts +25 -2
  26. package/dist/src/lib/utils.d.ts.map +1 -1
  27. package/dist/src/lib/utils.js +141 -62
  28. package/dist/src/register.d.ts.map +1 -1
  29. package/dist/src/register.js +5 -1
  30. package/dist/src/sip10Token.d.ts +22 -0
  31. package/dist/src/sip10Token.d.ts.map +1 -0
  32. package/dist/src/sip10Token.js +128 -0
  33. package/dist/src/stx.d.ts +146 -2
  34. package/dist/src/stx.d.ts.map +1 -1
  35. package/dist/src/stx.js +420 -11
  36. package/dist/src/tstx.js +1 -1
  37. package/dist/test/fixtures.d.ts +119 -0
  38. package/dist/test/fixtures.d.ts.map +1 -0
  39. package/dist/test/fixtures.js +147 -0
  40. package/dist/test/unit/keyPair.d.ts +2 -0
  41. package/dist/test/unit/keyPair.d.ts.map +1 -0
  42. package/dist/test/unit/keyPair.js +144 -0
  43. package/dist/test/unit/resources.d.ts +97 -0
  44. package/dist/test/unit/resources.d.ts.map +1 -0
  45. package/dist/test/unit/resources.js +144 -0
  46. package/dist/test/unit/sip10Token.d.ts +2 -0
  47. package/dist/test/unit/sip10Token.d.ts.map +1 -0
  48. package/dist/test/unit/sip10Token.js +374 -0
  49. package/dist/test/unit/stx.d.ts +2 -0
  50. package/dist/test/unit/stx.d.ts.map +1 -0
  51. package/dist/test/unit/stx.js +470 -0
  52. package/dist/test/unit/transaction.d.ts +2 -0
  53. package/dist/test/unit/transaction.d.ts.map +1 -0
  54. package/dist/test/unit/transaction.js +83 -0
  55. package/dist/test/unit/transactionBuilder/contractBuilder.d.ts +2 -0
  56. package/dist/test/unit/transactionBuilder/contractBuilder.d.ts.map +1 -0
  57. package/dist/test/unit/transactionBuilder/contractBuilder.js +421 -0
  58. package/dist/test/unit/transactionBuilder/fungibleTokenTransferBuilder.d.ts +2 -0
  59. package/dist/test/unit/transactionBuilder/fungibleTokenTransferBuilder.d.ts.map +1 -0
  60. package/dist/test/unit/transactionBuilder/fungibleTokenTransferBuilder.js +187 -0
  61. package/dist/test/unit/transactionBuilder/sendmanyBuilder.d.ts +2 -0
  62. package/dist/test/unit/transactionBuilder/sendmanyBuilder.d.ts.map +1 -0
  63. package/dist/test/unit/transactionBuilder/sendmanyBuilder.js +140 -0
  64. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
  65. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  66. package/dist/test/unit/transactionBuilder/transferBuilder.js +347 -0
  67. package/dist/test/unit/util.d.ts +2 -0
  68. package/dist/test/unit/util.d.ts.map +1 -0
  69. package/dist/test/unit/util.js +326 -0
  70. package/dist/tsconfig.tsbuildinfo +1 -0
  71. package/package.json +13 -11
  72. package/.eslintignore +0 -5
  73. package/.mocharc.yml +0 -8
  74. package/CHANGELOG.md +0 -107
package/dist/src/stx.js CHANGED
@@ -1,9 +1,17 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.Stx = void 0;
4
7
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
8
  const statics_1 = require("@bitgo-beta/statics");
9
+ const transactions_1 = require("@stacks/transactions");
10
+ const payload_1 = require("@stacks/transactions/dist/payload");
11
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
6
12
  const _1 = require(".");
13
+ const lib_1 = require("./lib");
14
+ const utils_1 = require("./lib/utils");
7
15
  class Stx extends sdk_core_1.BaseCoin {
8
16
  constructor(bitgo, staticsCoin) {
9
17
  super(bitgo);
@@ -27,8 +35,18 @@ class Stx extends sdk_core_1.BaseCoin {
27
35
  getBaseFactor() {
28
36
  return Math.pow(10, this._staticsCoin.decimalPlaces);
29
37
  }
38
+ getTransaction(coinConfig) {
39
+ return new lib_1.TransactionBuilderFactory(coinConfig).getTransferBuilder();
40
+ }
41
+ /** inherited doc */
42
+ getDefaultMultisigType() {
43
+ return sdk_core_1.multisigTypes.onchain;
44
+ }
30
45
  async verifyTransaction(params) {
31
- // TODO: Implement when available on the SDK.
46
+ const { txParams } = params;
47
+ if (Array.isArray(txParams.recipients) && txParams.recipients.length > 1) {
48
+ throw new Error(`${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`);
49
+ }
32
50
  return true;
33
51
  }
34
52
  /**
@@ -117,9 +135,10 @@ class Stx extends sdk_core_1.BaseCoin {
117
135
  if (!transaction) {
118
136
  throw new Error('Invalid message passed to signMessage');
119
137
  }
120
- return {
138
+ const txHex = {
121
139
  txHex: transaction.toBroadcastFormat(),
122
140
  };
141
+ return transaction.signature.length >= 2 ? txHex : { halfSigned: txHex };
123
142
  }
124
143
  async parseTransaction(params) {
125
144
  return {};
@@ -145,23 +164,43 @@ class Stx extends sdk_core_1.BaseCoin {
145
164
  const tx = await txBuilder.build();
146
165
  const txJson = tx.toJson();
147
166
  if (tx.type === sdk_core_1.TransactionType.Send) {
148
- const outputs = [
149
- {
167
+ // check if it is a token transaction or native coin transaction
168
+ let transactionRecipient;
169
+ let outputAmount;
170
+ let memo;
171
+ if (txJson.payload.contractAddress && txJson.payload.functionArgs.length >= 3) {
172
+ outputAmount = (0, transactions_1.cvToValue)(txJson.payload.functionArgs[0]).toString();
173
+ transactionRecipient = {
174
+ address: (0, transactions_1.cvToString)(txJson.payload.functionArgs[2]),
175
+ amount: outputAmount,
176
+ tokenName: (0, utils_1.findTokenNameByContract)(txJson.payload.contractAddress, txJson.payload.contractName),
177
+ };
178
+ if (txJson.payload.functionArgs.length === 4 &&
179
+ txJson.payload.functionArgs[3].type === transactions_1.ClarityType.OptionalSome) {
180
+ memo = Buffer.from(txJson.payload.functionArgs[3].value.buffer).toString();
181
+ transactionRecipient['memo'] = memo;
182
+ }
183
+ }
184
+ else {
185
+ outputAmount = txJson.payload.amount;
186
+ memo = txJson.payload.memo;
187
+ transactionRecipient = {
150
188
  address: txJson.payload.to,
151
- amount: txJson.payload.amount,
152
- memo: txJson.payload.memo,
153
- },
154
- ];
189
+ amount: outputAmount,
190
+ memo: memo,
191
+ };
192
+ }
193
+ const outputs = [transactionRecipient];
155
194
  const displayOrder = ['id', 'outputAmount', 'changeAmount', 'outputs', 'changeOutputs', 'fee', 'memo', 'type'];
156
195
  return {
157
196
  displayOrder,
158
197
  id: txJson.id,
159
- outputAmount: txJson.payload.amount.toString(),
198
+ outputAmount: outputAmount.toString(),
160
199
  changeAmount: '0',
161
200
  outputs,
162
201
  changeOutputs: [],
163
202
  fee: txJson.fee,
164
- memo: txJson.payload.memo,
203
+ memo: memo,
165
204
  type: tx.type,
166
205
  };
167
206
  }
@@ -191,6 +230,376 @@ class Stx extends sdk_core_1.BaseCoin {
191
230
  };
192
231
  }
193
232
  }
233
+ /**
234
+ * Get URLs of some active public nodes
235
+ * @returns {String} node url
236
+ */
237
+ getPublicNodeUrl() {
238
+ return sdk_core_1.Environments[this.bitgo.getEnv()].stxNodeUrl;
239
+ }
240
+ /**
241
+ * Get native stacks balance for an account
242
+ * @param {String} address - stacks address
243
+ * @returns {Promise<NativeStxBalance>}
244
+ */
245
+ async getNativeStxBalanceFromNode({ address }) {
246
+ const endpoint = `${this.getPublicNodeUrl()}/extended/v2/addresses/${address}/balances/stx`;
247
+ try {
248
+ const response = await this.bitgo.get(endpoint);
249
+ if (response.statusCode !== 200) {
250
+ throw new Error(`request failed with status ${response.statusCode}`);
251
+ }
252
+ const body = response.body;
253
+ return body;
254
+ }
255
+ catch (e) {
256
+ throw new Error(`unable to get native stx balance from node: ${e.message}`);
257
+ }
258
+ }
259
+ /**
260
+ * Get single fungible token balance for an account
261
+ * @param {String} address - stacks address
262
+ * @param {String} assetId - fungible token asset id
263
+ * @returns {Promise<SingleFungibleTokenBalance>}
264
+ */
265
+ async getSingleFungibleTokenBalanceFromNode({ address, assetId, }) {
266
+ const endpoint = `${this.getPublicNodeUrl()}/extended/v2/addresses/${address}/balances/ft/${assetId}`;
267
+ try {
268
+ const response = await this.bitgo.get(endpoint);
269
+ if (response.statusCode !== 200) {
270
+ throw new Error(`request failed with status ${response.statusCode}`);
271
+ }
272
+ const body = response.body;
273
+ return body;
274
+ }
275
+ catch (e) {
276
+ throw new Error(`unable to get native stx balance from node: ${e.message}`);
277
+ }
278
+ }
279
+ /**
280
+ * Get nonce data specific to an account from a public node
281
+ * @param {String} address - stacks address
282
+ * @returns {Promise<StxNonceResponse>}
283
+ */
284
+ async getAccountNonceFromNode({ address }) {
285
+ const endpoint = `${this.getPublicNodeUrl()}/extended/v1/address/${address}/nonces`;
286
+ try {
287
+ const response = await this.bitgo.get(endpoint);
288
+ if (response.statusCode !== 200) {
289
+ throw new Error(`request failed with status ${response.statusCode}`);
290
+ }
291
+ const body = response.body;
292
+ return body;
293
+ }
294
+ catch (e) {
295
+ throw new Error(`unable to get account nonce from node: ${e.message}`);
296
+ }
297
+ }
298
+ /**
299
+ * Get stacks transaction estimated fee
300
+ * @param {String} txHex - hex of stacks transaction payload
301
+ * @param {Number} txHexLength - length of built serialized transaction
302
+ * @returns {Promise<Number>} - fee estimate (taking the lowest)
303
+ */
304
+ async getTransactionFeeEstimation({ txHex, txHexLength, }) {
305
+ const endpoint = `${this.getPublicNodeUrl()}/v2/fees/transaction`;
306
+ const requestBody = {
307
+ transaction_payload: txHex,
308
+ estimated_len: txHexLength,
309
+ };
310
+ try {
311
+ const response = await this.bitgo.post(endpoint).send(requestBody);
312
+ if (response.statusCode !== 200) {
313
+ throw new Error(`request failed with status ${response.statusCode}`);
314
+ }
315
+ const body = response.body;
316
+ if (body.estimations.length !== 3) {
317
+ throw new Error('Invalid response estimation length');
318
+ }
319
+ return body.estimations[0].fee;
320
+ }
321
+ catch (e) {
322
+ throw new Error(`unable to get transaction fee estimation: ${e.message}`);
323
+ }
324
+ }
325
+ /**
326
+ * Format for offline vault signing
327
+ * @param {BaseTransaction} tx - base transaction
328
+ * @returns {Promise<RecoveryInfo>}
329
+ */
330
+ async formatForOfflineVault(tx) {
331
+ const txJson = tx.toJson();
332
+ const transactionExplanation = (await this.explainTransaction({
333
+ txHex: tx.toBroadcastFormat(),
334
+ feeInfo: { fee: txJson.fee },
335
+ }));
336
+ transactionExplanation.coin = this.getChain();
337
+ transactionExplanation.feeInfo = { fee: txJson.fee };
338
+ transactionExplanation.txHex = tx.toBroadcastFormat();
339
+ return transactionExplanation;
340
+ }
341
+ /**
342
+ * Get the recoverable amount & fee after subtracting the txn fee
343
+ * @param {String} serializedHex - serialized txn hex
344
+ * @param {Number} txHexLength - deserialized txn length
345
+ * @param {String} balance - total account balance
346
+ * @param {String} tokenBalance - total token balance
347
+ * @returns {Promise<Record<string, string>>}
348
+ */
349
+ async getRecoverableAmountAndFee(serializedHex, txHexLength, balance, tokenBalance) {
350
+ const estimatedFee = await this.getTransactionFeeEstimation({
351
+ txHex: serializedHex,
352
+ txHexLength: txHexLength,
353
+ });
354
+ const balanceBN = new bignumber_js_1.default(balance);
355
+ const feeBN = new bignumber_js_1.default(estimatedFee);
356
+ if (balanceBN.isLessThan(feeBN)) {
357
+ throw new Error('insufficient balance to build the transaction');
358
+ }
359
+ return {
360
+ recoverableAmount: tokenBalance ?? balanceBN.minus(feeBN).toString(),
361
+ fee: feeBN.toString(),
362
+ };
363
+ }
364
+ /**
365
+ * Method to find the right builder for token or native coin transfer
366
+ * @param {String} contractAddress - token contract address
367
+ * @param {String} contractName - token contract name
368
+ * @returns {TransferBuilder|FungibleTokenTransferBuilder}
369
+ */
370
+ getTokenOrNativeTransferBuilder(contractAddress, contractName) {
371
+ const isToken = !!contractAddress && !!contractName;
372
+ let factory;
373
+ if (isToken) {
374
+ const tokenName = (0, utils_1.findTokenNameByContract)(contractAddress, contractName);
375
+ if (!tokenName) {
376
+ throw new Error('invalid contract address or contract name, not supported');
377
+ }
378
+ factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get(tokenName));
379
+ }
380
+ else {
381
+ factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
382
+ }
383
+ let builder;
384
+ if (isToken) {
385
+ builder = factory.getFungibleTokenTransferBuilder();
386
+ }
387
+ else {
388
+ builder = factory.getTransferBuilder();
389
+ }
390
+ return builder;
391
+ }
392
+ /**
393
+ * Method to build fungible token transfer transaction
394
+ * @param {FungibleTokenTransferBuilder} builder - fungible token transfer builder
395
+ * @param {String} contractAddress - token contract address
396
+ * @param {String} contractName - token contract name
397
+ * @param {String[]} pubs - account public keys
398
+ * @param {Number} nonce - account nonce
399
+ * @param {AddressDetails} rootAddressDetails - root address details
400
+ * @param {AddressDetails} destinationAddressDetails - receive address details
401
+ * @param {String} stxBalance - native stx balance
402
+ * @returns {Promise<BaseTransaction>} - built transaction
403
+ */
404
+ async buildTokenTransferTransaction({ builder, contractAddress, contractName, pubs, nonce, rootAddressDetails, destinationAddressDetails, stxBalance, }) {
405
+ const txBuilder = builder;
406
+ const contractTokenName = (0, utils_1.findContractTokenNameUsingContract)(contractAddress, contractName);
407
+ if (!contractTokenName) {
408
+ throw new Error('invalid contract address or contract name, not supported');
409
+ }
410
+ const assetId = `${contractAddress}.${contractName}::${contractTokenName}`;
411
+ // fetch the token balance
412
+ const tokenBalanceData = await this.getSingleFungibleTokenBalanceFromNode({
413
+ address: rootAddressDetails.address,
414
+ assetId,
415
+ });
416
+ const tokenBalance = tokenBalanceData?.balance;
417
+ if (!Number(tokenBalance) || isNaN(Number(tokenBalance))) {
418
+ throw new Error(`no token balance found to recover for address: ${rootAddressDetails.address}, token: ${assetId}`);
419
+ }
420
+ txBuilder.fee({ fee: '200' });
421
+ txBuilder.numberSignatures(2);
422
+ txBuilder.fromPubKey(pubs);
423
+ txBuilder.nonce(nonce);
424
+ txBuilder.contractAddress(contractAddress);
425
+ txBuilder.contractName(contractName);
426
+ if (contractTokenName) {
427
+ txBuilder.tokenName(contractTokenName);
428
+ }
429
+ txBuilder.functionName('transfer');
430
+ const functionArgs = [
431
+ (0, transactions_1.uintCV)(tokenBalance),
432
+ (0, transactions_1.standardPrincipalCV)(rootAddressDetails.address),
433
+ (0, transactions_1.standardPrincipalCV)(destinationAddressDetails.address),
434
+ ];
435
+ if (destinationAddressDetails.memoId) {
436
+ functionArgs.push((0, transactions_1.someCV)((0, transactions_1.bufferCVFromString)(destinationAddressDetails.memoId)));
437
+ }
438
+ else {
439
+ functionArgs.push((0, transactions_1.noneCV)());
440
+ }
441
+ txBuilder.functionArgs(functionArgs);
442
+ const baseTxn = await txBuilder.build();
443
+ const txBroadcastFormat = baseTxn.toBroadcastFormat();
444
+ const txDeserialized = (0, transactions_1.deserializeTransaction)(txBroadcastFormat);
445
+ const serializedHex = (0, payload_1.serializePayload)(txDeserialized.payload).toString('hex');
446
+ const { recoverableAmount, fee } = await this.getRecoverableAmountAndFee(serializedHex, txBroadcastFormat.length, stxBalance, tokenBalance);
447
+ functionArgs[0] = (0, transactions_1.uintCV)(recoverableAmount);
448
+ txBuilder.functionArgs(functionArgs);
449
+ txBuilder.fee({ fee: fee });
450
+ return await txBuilder.build();
451
+ }
452
+ /**
453
+ * Method to build native transfer transaction
454
+ * @param {TransferBuilder} builder - transfer builder
455
+ * @param {String[]} pubs - account public keys
456
+ * @param {Number} nonce - account nonce
457
+ * @param {AddressDetails} destinationAddressDetails - receive address details
458
+ * @param {String} stxBalance - native stx balance
459
+ * @returns {Promise<BaseTransaction>} - built transaction
460
+ */
461
+ async buildNativeTransferTransaction({ builder, pubs, nonce, destinationAddressDetails, stxBalance, }) {
462
+ const txBuilder = builder;
463
+ txBuilder.fee({ fee: '200' });
464
+ txBuilder.numberSignatures(2);
465
+ txBuilder.fromPubKey(pubs);
466
+ txBuilder.nonce(nonce);
467
+ txBuilder.to(destinationAddressDetails.address);
468
+ txBuilder.amount(stxBalance);
469
+ if (destinationAddressDetails.memoId) {
470
+ txBuilder.memo(destinationAddressDetails.memoId);
471
+ }
472
+ const baseTxn = await txBuilder.build();
473
+ const txBroadcastFormat = baseTxn.toBroadcastFormat();
474
+ const txDeserialized = (0, transactions_1.deserializeTransaction)(txBroadcastFormat);
475
+ const serializedHex = (0, payload_1.serializePayload)(txDeserialized.payload).toString('hex');
476
+ const { recoverableAmount, fee } = await this.getRecoverableAmountAndFee(serializedHex, txBroadcastFormat.length, stxBalance);
477
+ txBuilder.amount(recoverableAmount);
478
+ txBuilder.fee({ fee: fee });
479
+ return await txBuilder.build();
480
+ }
481
+ /**
482
+ * Method that uses appropriate builder and builds transaction depending on token or native coin
483
+ * @param {String[]} pubs - public keys
484
+ * @param {AddressDetails} rootAddressDetails - sender address detail
485
+ * @param {AddressDetails} destinationAddressDetails - receiver address detail
486
+ * @param {Number} nonce - wallet nonce
487
+ * @param {String} balance - wallet balance
488
+ * @param {String | undefined} contractAddress - token contract address
489
+ * @param {String | undefined} contractName - token contract name
490
+ * @returns {Promise<BaseTransaction>} built transaction
491
+ */
492
+ async getNativeOrTokenTransaction({ pubs, rootAddressDetails, destinationAddressDetails, nonce, stxBalance, contractAddressInput, contractName, }) {
493
+ const builder = this.getTokenOrNativeTransferBuilder(contractAddressInput, contractName);
494
+ const contractAddress = contractAddressInput?.toUpperCase();
495
+ const isToken = !!contractAddress && !!contractName;
496
+ let finalTx;
497
+ if (isToken) {
498
+ finalTx = await this.buildTokenTransferTransaction({
499
+ builder: builder,
500
+ contractAddress,
501
+ contractName,
502
+ pubs,
503
+ nonce,
504
+ rootAddressDetails,
505
+ destinationAddressDetails,
506
+ stxBalance,
507
+ });
508
+ }
509
+ else {
510
+ finalTx = await this.buildNativeTransferTransaction({
511
+ builder: builder,
512
+ pubs,
513
+ nonce,
514
+ destinationAddressDetails,
515
+ stxBalance,
516
+ });
517
+ }
518
+ return {
519
+ tx: finalTx,
520
+ builder: builder,
521
+ };
522
+ }
523
+ /**
524
+ * Method to recover native stx or sip10 tokens from bitgo hot & cold wallets
525
+ * @param {String} params.backupKey - encrypted wallet backup key (public or private)
526
+ * @param {String} params.userKey - encrypted wallet user key (public or private)
527
+ * @param {String} params.rootAddress - wallet root address
528
+ * @param {String} params.recoveryDestination - receive address
529
+ * @param {String} params.bitgoKey - encrypted bitgo public key
530
+ * @param {String} params.walletPassphrase - wallet password
531
+ * @param {String} params.contractId - contract id of the token (mandatory for token recovery)
532
+ * @returns {Promise<RecoveryInfo|RecoveryTransaction>} RecoveryTransaction.txHex - hex of serialized transaction (signed or unsigned)
533
+ */
534
+ async recover(params) {
535
+ if (!this.isValidAddress(params.rootAddress)) {
536
+ throw new Error('invalid root address!');
537
+ }
538
+ if (!this.isValidAddress(params.recoveryDestination)) {
539
+ throw new Error('invalid destination address!');
540
+ }
541
+ let contractAddress;
542
+ let contractName;
543
+ if (params.contractId) {
544
+ [contractAddress, contractName] = params.contractId.split('.');
545
+ if ((contractAddress && !contractName) || (contractName && !contractAddress)) {
546
+ throw new Error('invalid contract id, please provide it in the form (contractAddress.contractName)');
547
+ }
548
+ }
549
+ const isUnsignedSweep = (0, sdk_core_1.getIsUnsignedSweep)(params);
550
+ const keys = (0, sdk_core_1.getBip32Keys)(this.bitgo, params, { requireBitGoXpub: true });
551
+ const rootAddressDetails = (0, utils_1.getAddressDetails)(params.rootAddress);
552
+ const [accountBalanceData, accountNonceData] = await Promise.all([
553
+ this.getNativeStxBalanceFromNode({ address: rootAddressDetails.address }),
554
+ this.getAccountNonceFromNode({ address: rootAddressDetails.address }),
555
+ ]);
556
+ const balance = Number(accountBalanceData.balance);
557
+ if (!balance || isNaN(balance)) {
558
+ throw new Error('could not find any balance to recover for ' + params.rootAddress);
559
+ }
560
+ const userPub = (0, transactions_1.publicKeyFromBuffer)(keys[0].publicKey);
561
+ const backupPub = (0, transactions_1.publicKeyFromBuffer)(keys[1].publicKey);
562
+ const bitgoPubKey = (0, transactions_1.publicKeyFromBuffer)(keys[2].publicKey);
563
+ const pubs = [(0, transactions_1.publicKeyToString)(userPub), (0, transactions_1.publicKeyToString)(backupPub), (0, transactions_1.publicKeyToString)(bitgoPubKey)];
564
+ const destinationAddressDetails = (0, utils_1.getAddressDetails)(params.recoveryDestination);
565
+ const nonce = typeof accountNonceData?.last_executed_tx_nonce === 'number' ? accountNonceData.last_executed_tx_nonce + 1 : 0;
566
+ const { tx, builder } = await this.getNativeOrTokenTransaction({
567
+ pubs,
568
+ rootAddressDetails,
569
+ destinationAddressDetails,
570
+ nonce,
571
+ stxBalance: accountBalanceData.balance,
572
+ contractAddressInput: contractAddress,
573
+ contractName: contractName,
574
+ });
575
+ if (isUnsignedSweep) {
576
+ return await this.formatForOfflineVault(tx);
577
+ }
578
+ // check the private key & sign
579
+ if (!keys[0].privateKey) {
580
+ throw new Error(`userKey is not a private key`);
581
+ }
582
+ const userKey = (0, transactions_1.createStacksPrivateKey)(keys[0].privateKey);
583
+ builder.sign({ key: (0, transactions_1.privateKeyToString)(userKey) });
584
+ const halfSignedTx = await builder.build();
585
+ const txHexHalfSigned = halfSignedTx.toBroadcastFormat();
586
+ const builder2 = this.getTokenOrNativeTransferBuilder(contractAddress, contractName);
587
+ builder2.from(txHexHalfSigned);
588
+ if (!keys[1].privateKey) {
589
+ throw new Error(`backupKey is not a private key`);
590
+ }
591
+ const backupKey = (0, transactions_1.createStacksPrivateKey)(keys[1].privateKey);
592
+ builder2.sign({ key: (0, transactions_1.privateKeyToString)(backupKey) });
593
+ const fullySignedTx = await builder2.build();
594
+ const fullySignedTxHex = fullySignedTx.toBroadcastFormat();
595
+ return {
596
+ txHex: fullySignedTxHex,
597
+ };
598
+ }
599
+ /** @inheritDoc */
600
+ auditDecryptedKey(params) {
601
+ throw new sdk_core_1.MethodNotImplementedError();
602
+ }
194
603
  }
195
604
  exports.Stx = Stx;
196
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N0eC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtREFTOEI7QUFDOUIsaURBQXFGO0FBRXJGLHdCQUEyQjtBQUUzQixNQUFhLEdBQUksU0FBUSxtQkFBUTtJQUcvQixZQUFZLEtBQWdCLEVBQUUsV0FBdUM7UUFDbkUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWIsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLG9EQUFvRCxDQUFDLENBQUM7U0FDdkU7UUFFRCxJQUFJLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQztJQUNsQyxDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxLQUFnQixFQUFFLFdBQXVDO1FBQzdFLE9BQU8sSUFBSSxHQUFHLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQztJQUNoQyxDQUFDO0lBRUQsU0FBUztRQUNQLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUM7SUFDbEMsQ0FBQztJQUVELFdBQVc7UUFDVCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRCxLQUFLLENBQUMsaUJBQWlCLENBQUMsTUFBZ0M7UUFDdEQsNkNBQTZDO1FBQzdDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILEtBQUssQ0FBQyxlQUFlLENBQUMsTUFBNEI7UUFDaEQsTUFBTSxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsR0FBRyxNQUFNLENB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O2dCQUNsQixzQkFBc0I7YUFDdkIsQ0FBQztZQUNGLE9BQU87Z0JBQ0wsWUFBWTtnQkFDWixFQUFFLEVBQUUsTUFBTSxDQUFDLEVBQUU7Z0JBQ2IsWUFBWSxFQUFFLEdBQUc7Z0JBQ2pCLFlBQVksRUFBRSxFQUFFO2dCQUNoQixPQUFPLEVBQUUsRUFBRTtnQkFDWCxhQUFhLEVBQUUsRUFBRTtnQkFDakIsR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHO2dCQUNmLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSTtnQkFDYixlQUFlLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxlQUFlO2dCQUMvQyxZQUFZLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxZQUFZO2dCQUN6QyxnQkFBZ0IsRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFlBQVk7Z0JBQzdDLG9CQUFvQixFQUFFLE1BQU0sQ0FBQyxPQUFPLENBQUMsWUFBWTthQUNsRCxDQUFDO1NBQ0g7SUFDSCxDQUFDO0NBQ0Y7QUFuTkQsa0JBbU5DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQmFzZUNvaW4sXG4gIEJpdEdvQmFzZSxcbiAgS2V5UGFpcixcbiAgU2lnbmVkVHJhbnNhY3Rpb24sXG4gIFRyYW5zYWN0aW9uUmVjaXBpZW50LFxuICBUcmFuc2FjdGlvblR5cGUsXG4gIFZlcmlmeUFkZHJlc3NPcHRpb25zLFxuICBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnMsXG59IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IEJhc2VDb2luIGFzIFN0YXRpY3NCYXNlQ29pbiwgQ29pbkZhbWlseSwgY29pbnMgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7IEV4cGxhaW5UcmFuc2FjdGlvbk9wdGlvbnMsIFN0eFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMsIFN0eFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IFN0eExpYiB9IGZyb20gJy4nO1xuXG5leHBvcnQgY2xhc3MgU3R4IGV4dGVuZHMgQmFzZUNvaW4ge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgX3N0YXRpY3NDb2luOiBSZWFkb25seTxTdGF0aWNzQmFzZUNvaW4+O1xuXG4gIGNvbnN0cnVjdG9yKGJpdGdvOiBCaXRHb0Jhc2UsIHN0YXRpY3NDb2luPzogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPikge1xuICAgIHN1cGVyKGJpdGdvKTtcblxuICAgIGlmICghc3RhdGljc0NvaW4pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignbWlzc2luZyByZXF1aXJlZCBjb25zdHJ1Y3RvciBwYXJhbWV0ZXIgc3RhdGljc0NvaW4nKTtcbiAgICB9XG5cbiAgICB0aGlzLl9zdGF0aWNzQ29pbiA9IHN0YXRpY3NDb2luO1xuICB9XG5cbiAgc3RhdGljIGNyZWF0ZUluc3RhbmNlKGJpdGdvOiBCaXRHb0Jhc2UsIHN0YXRpY3NDb2luPzogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPik6IEJhc2VDb2luIHtcbiAgICByZXR1cm4gbmV3IFN0eChiaXRnbywgc3RhdGljc0NvaW4pO1xuICB9XG5cbiAgZ2V0Q2hhaW4oKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fc3RhdGljc0NvaW4ubmFtZTtcbiAgfVxuXG4gIGdldEZhbWlseSgpOiBDb2luRmFtaWx5IHtcbiAgICByZXR1cm4gdGhpcy5fc3RhdGljc0NvaW4uZmFtaWx5O1xuICB9XG5cbiAgZ2V0RnVsbE5hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fc3RhdGljc0NvaW4uZnVsbE5hbWU7XG4gIH1cblxuICBnZXRCYXNlRmFjdG9yKCk6IHN0cmluZyB8IG51bWJlciB7XG4gICAgcmV0dXJuIE1hdGgucG93KDEwLCB0aGlzLl9zdGF0aWNzQ29pbi5kZWNpbWFsUGxhY2VzKTtcbiAgfVxuXG4gIGFzeW5jIHZlcmlmeVRyYW5zYWN0aW9uKHBhcmFtczogVmVyaWZ5VHJhbnNhY3Rpb25PcHRpb25zKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgLy8gVE9ETzogSW1wbGVtZW50IHdoZW4gYXZhaWxhYmxlIG9uIHRoZSBTREsuXG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgYWRkcmVzcyBpcyB2YWxpZCwgdGhlbiBtYWtlIHN1cmUgaXQgbWF0Y2hlcyB0aGUgYmFzZSBhZGRyZXNzLlxuICAgKlxuICAgKiBAcGFyYW0ge1ZlcmlmeUFkZHJlc3NPcHRpb25zfSBwYXJhbXNcbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5hZGRyZXNzIC0gdGhlIGFkZHJlc3MgdG8gdmVyaWZ5XG4gICAqIEBwYXJhbSB7U3RyaW5nfSBwYXJhbXMuYmFzZUFkZHJlc3MgLSB0aGUgYmFzZSBhZGRyZXNzIGZyb20gdGhlIHdhbGxldFxuICAgKi9cbiAgYXN5bmMgaXNXYWxsZXRBZGRyZXNzKHBhcmFtczogVmVyaWZ5QWRkcmVzc09wdGlvbnMpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICBjb25zdCB7IGFkZHJlc3MsIGtleWNoYWlucyB9ID0gcGFyYW1zO1xuICAgIGlmICgha2V5Y2hhaW5zIHx8IGtleWNoYWlucy5sZW5ndGggIT09IDMpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBrZXljaGFpbnMnKTtcbiAgICB9XG4gICAgY29uc3QgcHVicyA9IGtleWNoYWlucy5tYXAoKGtleWNoYWluKSA9PiBTdHhMaWIuVXRpbHMueHB1YlRvU1RYUHVia2V5KGtleWNoYWluLnB1YikpO1xuICAgIGNvbnN0IGFkZHJlc3NWZXJzaW9uID0gU3R4TGliLlV0aWxzLmdldEFkZHJlc3NWZXJzaW9uKGFkZHJlc3MpO1xuICAgIGNvbnN0IGJhc2VBZGRyZXNzID0gU3R4TGliLlV0aWxzLmdldFNUWEFkZHJlc3NGcm9tUHViS2V5cyhwdWJzLCBhZGRyZXNzVmVyc2lvbikuYWRkcmVzcztcbiAgICByZXR1cm4gU3R4TGliLlV0aWxzLmlzU2FtZUJhc2VBZGRyZXNzKGFkZHJlc3MsIGJhc2VBZGRyZXNzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZW5lcmF0ZSBTdGFja3Mga2V5IHBhaXJcbiAgICpcbiAgICogQHBhcmFtIHtCdWZmZXJ9IHNlZWQgLSBTZWVkIGZyb20gd2hpY2ggdGhlIG5ldyBrZXlwYWlyIHNob3VsZCBiZSBnZW5lcmF0ZWQsIG90aGVyd2lzZSBhIHJhbmRvbSBzZWVkIGlzIHVzZWRcbiAgICogQHJldHVybnMge09iamVjdH0gb2JqZWN0IHdpdGggZ2VuZXJhdGVkIHB1YiBhbmQgcHJ2XG4gICAqL1xuICBnZW5lcmF0ZUtleVBhaXIoc2VlZD86IEJ1ZmZlcik6IEtleVBhaXIge1xuICAgIGNvbnN0IGtleVBhaXIgPSBzZWVkID8gbmV3IFN0eExpYi5LZXlQYWlyKHsgc2VlZCB9KSA6IG5ldyBTdHhMaWIuS2V5UGFpcigpO1xuICAgIGNvbnN0IGtleXMgPSBrZXlQYWlyLmdldEV4dGVuZGVkS2V5cygpO1xuXG4gICAgaWYgKCFrZXlzLnhwcnYpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTWlzc2luZyB4cHJ2IGluIGtleSBnZW5lcmF0aW9uLicpO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBwdWI6IGtleXMueHB1YixcbiAgICAgIHBydjoga2V5cy54cHJ2LFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJuIGJvb2xlYW4gaW5kaWNhdGluZyB3aGV0aGVyIGlucHV0IGlzIHZhbGlkIHB1YmxpYyBrZXkgZm9yIHRoZSBjb2luXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwdWIgdGhlIHBydiB0byBiZSBjaGVja2VkXG4gICAqIEByZXR1cm5zIGlzIGl0IHZhbGlkP1xuICAgKi9cbiAgaXNWYWxpZFB1YihwdWI6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4gU3R4TGliLlV0aWxzLmlzVmFsaWRQdWJsaWNLZXkocHViKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybiBib29sZWFuIGluZGljYXRpbmcgd2hldGhlciBpbnB1dCBpcyB2YWxpZCBwcml2YXRlIGtleSBmb3IgdGhlIGNvaW5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHBydiB0aGUgcHJ2IHRvIGJlIGNoZWNrZWRcbiAgICogQHJldHVybnMgaXMgaXQgdmFsaWQ/XG4gICAqL1xuICBpc1ZhbGlkUHJ2KHBydjogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBTdHhMaWIuVXRpbHMuaXNWYWxpZFByaXZhdGVLZXkocHJ2KTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgaXNWYWxpZEFkZHJlc3MoYWRkcmVzczogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBTdHhMaWIuVXRpbHMuaXNWYWxpZEFkZHJlc3NXaXRoUGF5bWVudElkKGFkZHJlc3MpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2lnbnMgc3RhY2tzIHRyYW5zYWN0aW9uXG4gICAqIEBwYXJhbSBwYXJhbXNcbiAgICovXG4gIGFzeW5jIHNpZ25UcmFuc2FjdGlvbihwYXJhbXM6IFN0eFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMpOiBQcm9taXNlPFNpZ25lZFRyYW5zYWN0aW9uPiB7XG4gICAgY29uc3QgZmFjdG9yeSA9IG5ldyBTdHhMaWIuVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeShjb2lucy5nZXQodGhpcy5nZXRDaGFpbigpKSk7XG4gICAgY29uc3QgdHhCdWlsZGVyID0gZmFjdG9yeS5mcm9tKHBhcmFtcy50eFByZWJ1aWxkLnR4SGV4KTtcbiAgICBjb25zdCBwcnZLZXlzID0gcGFyYW1zLnBydiBpbnN0YW5jZW9mIEFycmF5ID8gcGFyYW1zLnBydiA6IFtwYXJhbXMucHJ2XTtcbiAgICBwcnZLZXlzLmZvckVhY2goKHBydikgPT4gdHhCdWlsZGVyLnNpZ24oeyBrZXk6IHBydiB9KSk7XG4gICAgaWYgKHBhcmFtcy5wdWJLZXlzKSB0eEJ1aWxkZXIuZnJvbVB1YktleShwYXJhbXMucHViS2V5cyk7XG4gICAgLy8gaWYgKHBhcmFtcy5udW1iZXJTaWduYXR1cmUpIHR4QnVpbGRlci5udW1iZXJTaWduYXR1cmVzKHBhcmFtcy5udW1iZXJTaWduYXR1cmUpO1xuICAgIGNvbnN0IHRyYW5zYWN0aW9uID0gYXdhaXQgdHhCdWlsZGVyLmJ1aWxkKCk7XG5cbiAgICBpZiAoIXRyYW5zYWN0aW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgbWVzc2FnZSBwYXNzZWQgdG8gc2lnbk1lc3NhZ2UnKTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgdHhIZXg6IHRyYW5zYWN0aW9uLnRvQnJvYWRjYXN0Rm9ybWF0KCksXG4gICAgfTtcbiAgfVxuXG4gIGFzeW5jIHBhcnNlVHJhbnNhY3Rpb24ocGFyYW1zOiBhbnkpOiBQcm9taXNlPGFueT4ge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFeHBsYWluIGEgU3RhY2tzIHRyYW5zYWN0aW9uIGZyb20gdHhIZXhcbiAgICogQHBhcmFtIHBhcmFtc1xuICAgKi9cbiAgYXN5bmMgZXhwbGFpblRyYW5zYWN0aW9uKHBhcmFtczogRXhwbGFpblRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8U3R4VHJhbnNhY3Rpb25FeHBsYW5hdGlvbiB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IHR4SGV4ID0gcGFyYW1zLnR4SGV4IHx8IChwYXJhbXMuaGFsZlNpZ25lZCAmJiBwYXJhbXMuaGFsZlNpZ25lZC50eEhleCk7XG4gICAgaWYgKCF0eEhleCB8fCAhcGFyYW1zLmZlZUluZm8pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignbWlzc2luZyBleHBsYWluIHR4IHBhcmFtZXRlcnMnKTtcbiAgICB9XG5cbiAgICBjb25zdCBmYWN0b3J5ID0gbmV3IFN0eExpYi5UcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5KGNvaW5zLmdldCh0aGlzLmdldENoYWluKCkpKTtcbiAgICBjb25zdCB0eEJ1aWxkZXIgPSBmYWN0b3J5LmZyb20odHhIZXgpO1xuXG4gICAgaWYgKHBhcmFtcy5wdWJsaWNLZXlzICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHR4QnVpbGRlci5mcm9tUHViS2V5KHBhcmFtcy5wdWJsaWNLZXlzKTtcbiAgICAgIGlmIChwYXJhbXMucHVibGljS2V5cy5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgLy8gZGVmaW5pdGVseSBhIHNpbmdsZSBzaWcgdHhcbiAgICAgICAgdHhCdWlsZGVyLm51bWJlclNpZ25hdHVyZXMoMSk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgdHggPSBhd2FpdCB0eEJ1aWxkZXIuYnVpbGQoKTtcbiAgICBjb25zdCB0eEpzb24gPSB0eC50b0pzb24oKTtcblxuICAgIGlmICh0eC50eXBlID09PSBUcmFuc2FjdGlvblR5cGUuU2VuZCkge1xuICAgICAgY29uc3Qgb3V0cHV0czogVHJhbnNhY3Rpb25SZWNpcGllbnRbXSA9IFtcbiAgICAgICAge1xuICAgICAgICAgIGFkZHJlc3M6IHR4SnNvbi5wYXlsb2FkLnRvLFxuICAgICAgICAgIGFtb3VudDogdHhKc29uLnBheWxvYWQuYW1vdW50LFxuICAgICAgICAgIG1lbW86IHR4SnNvbi5wYXlsb2FkLm1lbW8sXG4gICAgICAgIH0sXG4gICAgICBdO1xuXG4gICAgICBjb25zdCBkaXNwbGF5T3JkZXIgPSBbJ2lkJywgJ291dHB1dEFtb3VudCcsICdjaGFuZ2VBbW91bnQnLCAnb3V0cHV0cycsICdjaGFuZ2VPdXRwdXRzJywgJ2ZlZScsICdtZW1vJywgJ3R5cGUnXTtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGRpc3BsYXlPcmRlcixcbiAgICAgICAgaWQ6IHR4SnNvbi5pZCxcbiAgICAgICAgb3V0cHV0QW1vdW50OiB0eEpzb24ucGF5bG9hZC5hbW91bnQudG9TdHJpbmcoKSxcbiAgICAgICAgY2hhbmdlQW1vdW50OiAnMCcsXG4gICAgICAgIG91dHB1dHMsXG4gICAgICAgIGNoYW5nZU91dHB1dHM6IFtdLFxuICAgICAgICBmZWU6IHR4SnNvbi5mZWUsXG4gICAgICAgIG1lbW86IHR4SnNvbi5wYXlsb2FkLm1lbW8sXG4gICAgICAgIHR5cGU6IHR4LnR5cGUsXG4gICAgICB9O1xuICAgIH1cblxuICAgIGlmICh0eC50eXBlID09PSBUcmFuc2FjdGlvblR5cGUuQ29udHJhY3RDYWxsKSB7XG4gICAgICBjb25zdCBkaXNwbGF5T3JkZXIgPSBbXG4gICAgICAgICdpZCcsXG4gICAgICAgICdmZWUnLFxuICAgICAgICAndHlwZScsXG4gICAgICAgICdjb250cmFjdEFkZHJlc3MnLFxuICAgICAgICAnY29udHJhY3ROYW1lJyxcbiAgICAgICAgJ2NvbnRyYWN0RnVuY3Rpb24nLFxuICAgICAgICAnY29udHJhY3RGdW5jdGlvbkFyZ3MnLFxuICAgICAgXTtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGRpc3BsYXlPcmRlcixcbiAgICAgICAgaWQ6IHR4SnNvbi5pZCxcbiAgICAgICAgY2hhbmdlQW1vdW50OiAnMCcsXG4gICAgICAgIG91dHB1dEFtb3VudDogJycsXG4gICAgICAgIG91dHB1dHM6IFtdLFxuICAgICAgICBjaGFuZ2VPdXRwdXRzOiBbXSxcbiAgICAgICAgZmVlOiB0eEpzb24uZmVlLFxuICAgICAgICB0eXBlOiB0eC50eXBlLFxuICAgICAgICBjb250cmFjdEFkZHJlc3M6IHR4SnNvbi5wYXlsb2FkLmNvbnRyYWN0QWRkcmVzcyxcbiAgICAgICAgY29udHJhY3ROYW1lOiB0eEpzb24ucGF5bG9hZC5jb250cmFjdE5hbWUsXG4gICAgICAgIGNvbnRyYWN0RnVuY3Rpb246IHR4SnNvbi5wYXlsb2FkLmZ1bmN0aW9uTmFtZSxcbiAgICAgICAgY29udHJhY3RGdW5jdGlvbkFyZ3M6IHR4SnNvbi5wYXlsb2FkLmZ1bmN0aW9uQXJncyxcbiAgICAgIH07XG4gICAgfVxuICB9XG59XG4iXX0=
605
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N0eC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxtREFpQjhCO0FBQzlCLGlEQUFxRjtBQUNyRix1REFlOEI7QUFDOUIsK0RBQXFFO0FBQ3JFLGdFQUFxQztBQUdyQyx3QkFBMkI7QUFDM0IsK0JBQWtEO0FBRWxELHVDQUE2RztBQWU3RyxNQUFhLEdBQUksU0FBUSxtQkFBUTtJQUcvQixZQUFZLEtBQWdCLEVBQUUsV0FBdUM7UUFDbkUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0RBQW9ELENBQUMsQ0FBQztRQUN4RSxDQUFDO1FBRUQsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7SUFDbEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBZ0IsRUFBRSxXQUF1QztRQUM3RSxPQUFPLElBQUksR0FBRyxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNOLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUM7SUFDaEMsQ0FBQztJQUVELFNBQVM7UUFDUCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDO0lBQ2xDLENBQUM7SUFFRCxXQUFXO1FBQ1QsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQztJQUNwQyxDQUFDO0lBRUQsYUFBYTtRQUNYLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsY0FBYyxDQUFDLFVBQXFDO1FBQ2xELE9BQU8sSUFBSSwrQkFBeUIsQ0FBQyxVQUFVLENBQUMsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQ3hFLENBQUM7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QWUsQ0FBQyxDQUFDO1FBRS9CLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO1FBQ3BELENBQUM7UUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFBLHFDQUFzQixFQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM3RCxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLElBQUEsaUNBQWtCLEVBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRXRELE1BQU0sYUFBYSxHQUFHLE1BQU0sUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdDLE1BQU0sZ0JBQWdCLEdBQUcsYUFBYSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFFM0QsT0FBTztZQUNMLEtBQUssRUFBRSxnQkFBZ0I7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsaUJBQWlCLENBQUMsTUFBK0I7UUFDL0MsTUFBTSxJQUFJLG9DQUF5QixFQUFFLENBQUM7SUFDeEMsQ0FBQztDQUNGO0FBcHNCRCxrQkFvc0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQXVkaXREZWNyeXB0ZWRLZXlQYXJhbXMsXG4gIEJhc2VDb2luLFxuICBCYXNlVHJhbnNhY3Rpb24sXG4gIEJpdEdvQmFzZSxcbiAgRW52aXJvbm1lbnRzLFxuICBnZXRCaXAzMktleXMsXG4gIGdldElzVW5zaWduZWRTd2VlcCxcbiAgS2V5UGFpcixcbiAgTWV0aG9kTm90SW1wbGVtZW50ZWRFcnJvcixcbiAgTXVsdGlzaWdUeXBlLFxuICBtdWx0aXNpZ1R5cGVzLFxuICBTaWduZWRUcmFuc2FjdGlvbixcbiAgVHJhbnNhY3Rpb25SZWNpcGllbnQsXG4gIFRyYW5zYWN0aW9uVHlwZSxcbiAgVmVyaWZ5QWRkcmVzc09wdGlvbnMsXG4gIFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyxcbn0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgU3RhdGljc0Jhc2VDb2luLCBDb2luRmFtaWx5LCBjb2lucyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHtcbiAgYnVmZmVyQ1ZGcm9tU3RyaW5nLFxuICBDbGFyaXR5VHlwZSxcbiAgQ2xhcml0eVZhbHVlLFxuICBjcmVhdGVTdGFja3NQcml2YXRlS2V5LFxuICBjdlRvU3RyaW5nLFxuICBjdlRvVmFsdWUsXG4gIGRlc2VyaWFsaXplVHJhbnNhY3Rpb24sXG4gIG5vbmVDVixcbiAgcHJpdmF0ZUtleVRvU3RyaW5nLFxuICBwdWJsaWNLZXlGcm9tQnVmZmVyLFxuICBwdWJsaWNLZXlUb1N0cmluZyxcbiAgc29tZUNWLFxuICBzdGFuZGFyZFByaW5jaXBhbENWLFxuICB1aW50Q1YsXG59IGZyb20gJ0BzdGFja3MvdHJhbnNhY3Rpb25zJztcbmltcG9ydCB7IHNlcmlhbGl6ZVBheWxvYWQgfSBmcm9tICdAc3RhY2tzL3RyYW5zYWN0aW9ucy9kaXN0L3BheWxvYWQnO1xuaW1wb3J0IEJpZ051bWJlciBmcm9tICdiaWdudW1iZXIuanMnO1xuXG5pbXBvcnQgeyBFeHBsYWluVHJhbnNhY3Rpb25PcHRpb25zLCBTdHhTaWduVHJhbnNhY3Rpb25PcHRpb25zLCBTdHhUcmFuc2FjdGlvbkV4cGxhbmF0aW9uIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBTdHhMaWIgfSBmcm9tICcuJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkgfSBmcm9tICcuL2xpYic7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL2xpYi90cmFuc2FjdGlvbkJ1aWxkZXInO1xuaW1wb3J0IHsgZmluZENvbnRyYWN0VG9rZW5OYW1lVXNpbmdDb250cmFjdCwgZmluZFRva2VuTmFtZUJ5Q29udHJhY3QsIGdldEFkZHJlc3NEZXRhaWxzIH0gZnJvbSAnLi9saWIvdXRpbHMnO1xuaW1wb3J0IHtcbiAgQWRkcmVzc0RldGFpbHMsXG4gIE5hdGl2ZVN0eEJhbGFuY2UsXG4gIFJlY292ZXJ5SW5mbyxcbiAgUmVjb3ZlcnlPcHRpb25zLFxuICBSZWNvdmVyeVRyYW5zYWN0aW9uLFxuICBTaW5nbGVGdW5naWJsZVRva2VuQmFsYW5jZSxcbiAgU3R4Tm9uY2VSZXNwb25zZSxcbiAgU3R4VHhuRmVlRXN0aW1hdGlvblJlc3BvbnNlLFxuICBUeERhdGEsXG59IGZyb20gJy4vbGliL2lmYWNlJztcbmltcG9ydCB7IFRyYW5zZmVyQnVpbGRlciB9IGZyb20gJy4vbGliL3RyYW5zZmVyQnVpbGRlcic7XG5pbXBvcnQgeyBGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyIH0gZnJvbSAnLi9saWIvZnVuZ2libGVUb2tlblRyYW5zZmVyQnVpbGRlcic7XG5cbmV4cG9ydCBjbGFzcyBTdHggZXh0ZW5kcyBCYXNlQ29pbiB7XG4gIHByb3RlY3RlZCByZWFkb25seSBfc3RhdGljc0NvaW46IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj47XG5cbiAgY29uc3RydWN0b3IoYml0Z286IEJpdEdvQmFzZSwgc3RhdGljc0NvaW4/OiBSZWFkb25seTxTdGF0aWNzQmFzZUNvaW4+KSB7XG4gICAgc3VwZXIoYml0Z28pO1xuXG4gICAgaWYgKCFzdGF0aWNzQ29pbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHJlcXVpcmVkIGNvbnN0cnVjdG9yIHBhcmFtZXRlciBzdGF0aWNzQ29pbicpO1xuICAgIH1cblxuICAgIHRoaXMuX3N0YXRpY3NDb2luID0gc3RhdGljc0NvaW47XG4gIH1cblxuICBzdGF0aWMgY3JlYXRlSW5zdGFuY2UoYml0Z286IEJpdEdvQmFzZSwgc3RhdGljc0NvaW4/OiBSZWFkb25seTxTdGF0aWNzQmFzZUNvaW4+KTogQmFzZUNvaW4ge1xuICAgIHJldHVybiBuZXcgU3R4KGJpdGdvLCBzdGF0aWNzQ29pbik7XG4gIH1cblxuICBnZXRDaGFpbigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLl9zdGF0aWNzQ29pbi5uYW1lO1xuICB9XG5cbiAgZ2V0RmFtaWx5KCk6IENvaW5GYW1pbHkge1xuICAgIHJldHVybiB0aGlzLl9zdGF0aWNzQ29pbi5mYW1pbHk7XG4gIH1cblxuICBnZXRGdWxsTmFtZSgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLl9zdGF0aWNzQ29pbi5mdWxsTmFtZTtcbiAgfVxuXG4gIGdldEJhc2VGYWN0b3IoKTogc3RyaW5nIHwgbnVtYmVyIHtcbiAgICByZXR1cm4gTWF0aC5wb3coMTAsIHRoaXMuX3N0YXRpY3NDb2luLmRlY2ltYWxQbGFjZXMpO1xuICB9XG5cbiAgZ2V0VHJhbnNhY3Rpb24oY29pbkNvbmZpZzogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPik6IFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gICAgcmV0dXJuIG5ldyBUcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5KGNvaW5Db25maWcpLmdldFRyYW5zZmVyQnVpbGRlcigpO1xuICB9XG5cbiAgLyoqIGluaGVyaXRlZCBkb2MgKi9cbiAgZ2V0RGVmYXVsdE11bHRpc2lnVHlwZSgpOiBNdWx0aXNpZ1R5cGUge1xuICAgIHJldHVybiBtdWx0aXNpZ1R5cGVzLm9uY2hhaW47XG4gIH1cblxuICBhc3luYyB2ZXJpZnlUcmFuc2FjdGlvbihwYXJhbXM6IFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IHsgdHhQYXJhbXMgfSA9IHBhcmFtcztcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh0eFBhcmFtcy5yZWNpcGllbnRzKSAmJiB0eFBhcmFtcy5yZWNpcGllbnRzLmxlbmd0aCA+IDEpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYCR7dGhpcy5nZXRDaGFpbigpfSBkb2Vzbid0IHN1cHBvcnQgc2VuZGluZyB0byBtb3JlIHRoYW4gMSBkZXN0aW5hdGlvbiBhZGRyZXNzIHdpdGhpbiBhIHNpbmdsZSB0cmFuc2FjdGlvbi4gVHJ5IGFnYWluLCB1c2luZyBvbmx5IGEgc2luZ2xlIHJlY2lwaWVudC5gXG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVjayBpZiBhZGRyZXNzIGlzIHZhbGlkLCB0aGVuIG1ha2Ugc3VyZSBpdCBtYXRjaGVzIHRoZSBiYXNlIGFkZHJlc3MuXG4gICAqXG4gICAqIEBwYXJhbSB7VmVyaWZ5QWRkcmVzc09wdGlvbnN9IHBhcmFtc1xuICAgKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLmFkZHJlc3MgLSB0aGUgYWRkcmVzcyB0byB2ZXJpZnlcbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5iYXNlQWRkcmVzcyAtIHRoZSBiYXNlIGFkZHJlc3MgZnJvbSB0aGUgd2FsbGV0XG4gICAqL1xuICBhc3luYyBpc1dhbGxldEFkZHJlc3MocGFyYW1zOiBWZXJpZnlBZGRyZXNzT3B0aW9ucyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IHsgYWRkcmVzcywga2V5Y2hhaW5zIH0gPSBwYXJhbXM7XG4gICAgaWYgKCFrZXljaGFpbnMgfHwga2V5Y2hhaW5zLmxlbmd0aCAhPT0gMykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGtleWNoYWlucycpO1xuICAgIH1cbiAgICBjb25zdCBwdWJzID0ga2V5Y2hhaW5zLm1hcCgoa2V5Y2hhaW4pID0+IFN0eExpYi5VdGlscy54cHViVG9TVFhQdWJrZXkoa2V5Y2hhaW4ucHViKSk7XG4gICAgY29uc3QgYWRkcmVzc1ZlcnNpb24gPSBTdHhMaWIuVXRpbHMuZ2V0QWRkcmVzc1ZlcnNpb24oYWRkcmVzcyk7XG4gICAgY29uc3QgYmFzZUFkZHJlc3MgPSBTdHhMaWIuVXRpbHMuZ2V0U1RYQWRkcmVzc0Zyb21QdWJLZXlzKHB1YnMsIGFkZHJlc3NWZXJzaW9uKS5hZGRyZXNzO1xuICAgIHJldHVybiBTdHhMaWIuVXRpbHMuaXNTYW1lQmFzZUFkZHJlc3MoYWRkcmVzcywgYmFzZUFkZHJlc3MpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlIFN0YWNrcyBrZXkgcGFpclxuICAgKlxuICAgKiBAcGFyYW0ge0J1ZmZlcn0gc2VlZCAtIFNlZWQgZnJvbSB3aGljaCB0aGUgbmV3IGtleXBhaXIgc2hvdWxkIGJlIGdlbmVyYXRlZCwgb3RoZXJ3aXNlIGEgcmFuZG9tIHNlZWQgaXMgdXNlZFxuICAgKiBAcmV0dXJucyB7T2JqZWN0fSBvYmplY3Qgd2l0aCBnZW5lcmF0ZWQgcHViIGFuZCBwcnZcbiAgICovXG4gIGdlbmVyYXRlS2V5UGFpcihzZWVkPzogQnVmZmVyKTogS2V5UGFpciB7XG4gICAgY29uc3Qga2V5UGFpciA9IHNlZWQgPyBuZXcgU3R4TGliLktleVBhaXIoeyBzZWVkIH0pIDogbmV3IFN0eExpYi5LZXlQYWlyKCk7XG4gICAgY29uc3Qga2V5cyA9IGtleVBhaXIuZ2V0RXh0ZW5kZWRLZXlzKCk7XG5cbiAgICBpZiAoIWtleXMueHBydikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHhwcnYgaW4ga2V5IGdlbmVyYXRpb24uJyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIHB1Yjoga2V5cy54cHViLFxuICAgICAgcHJ2OiBrZXlzLnhwcnYsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm4gYm9vbGVhbiBpbmRpY2F0aW5nIHdoZXRoZXIgaW5wdXQgaXMgdmFsaWQgcHVibGljIGtleSBmb3IgdGhlIGNvaW5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHB1YiB0aGUgcHJ2IHRvIGJlIGNoZWNrZWRcbiAgICogQHJldHVybnMgaXMgaXQgdmFsaWQ/XG4gICAqL1xuICBpc1ZhbGlkUHViKHB1Yjogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBTdHhMaWIuVXRpbHMuaXNWYWxpZFB1YmxpY0tleShwdWIpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJuIGJvb2xlYW4gaW5kaWNhdGluZyB3aGV0aGVyIGlucHV0IGlzIHZhbGlkIHByaXZhdGUga2V5IGZvciB0aGUgY29pblxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gcHJ2IHRoZSBwcnYgdG8gYmUgY2hlY2tlZFxuICAgKiBAcmV0dXJucyBpcyBpdCB2YWxpZD9cbiAgICovXG4gIGlzVmFsaWRQcnYocHJ2OiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIFN0eExpYi5VdGlscy5pc1ZhbGlkUHJpdmF0ZUtleShwcnYpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICBpc1ZhbGlkQWRkcmVzcyhhZGRyZXNzOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIFN0eExpYi5VdGlscy5pc1ZhbGlkQWRkcmVzc1dpdGhQYXltZW50SWQoYWRkcmVzcyk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTaWducyBzdGFja3MgdHJhbnNhY3Rpb25cbiAgICogQHBhcmFtIHBhcmFtc1xuICAgKi9cbiAgYXN5bmMgc2lnblRyYW5zYWN0aW9uKHBhcmFtczogU3R4U2lnblRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8U2lnbmVkVHJhbnNhY3Rpb24+IHtcbiAgICBjb25zdCBmYWN0b3J5ID0gbmV3IFN0eExpYi5UcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5KGNvaW5zLmdldCh0aGlzLmdldENoYWluKCkpKTtcbiAgICBjb25zdCB0eEJ1aWxkZXIgPSBmYWN0b3J5LmZyb20ocGFyYW1zLnR4UHJlYnVpbGQudHhIZXgpO1xuICAgIGNvbnN0IHBydktleXMgPSBwYXJhbXMucHJ2IGluc3RhbmNlb2YgQXJyYXkgPyBwYXJhbXMucHJ2IDogW3BhcmFtcy5wcnZdO1xuICAgIHBydktleXMuZm9yRWFjaCgocHJ2KSA9PiB0eEJ1aWxkZXIuc2lnbih7IGtleTogcHJ2IH0pKTtcbiAgICBpZiAocGFyYW1zLnB1YktleXMpIHR4QnVpbGRlci5mcm9tUHViS2V5KHBhcmFtcy5wdWJLZXlzKTtcbiAgICAvLyBpZiAocGFyYW1zLm51bWJlclNpZ25hdHVyZSkgdHhCdWlsZGVyLm51bWJlclNpZ25hdHVyZXMocGFyYW1zLm51bWJlclNpZ25hdHVyZSk7XG4gICAgY29uc3QgdHJhbnNhY3Rpb24gPSBhd2FpdCB0eEJ1aWxkZXIuYnVpbGQoKTtcblxuICAgIGlmICghdHJhbnNhY3Rpb24pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBtZXNzYWdlIHBhc3NlZCB0byBzaWduTWVzc2FnZScpO1xuICAgIH1cblxuICAgIGNvbnN0IHR4SGV4ID0ge1xuICAgICAgdHhIZXg6IHRyYW5zYWN0aW9uLnRvQnJvYWRjYXN0Rm9ybWF0KCksXG4gICAgfTtcblxuICAgIHJldHVybiB0cmFuc2FjdGlvbi5zaWduYXR1cmUubGVuZ3RoID49IDIgPyB0eEhleCA6IHsgaGFsZlNpZ25lZDogdHhIZXggfTtcbiAgfVxuXG4gIGFzeW5jIHBhcnNlVHJhbnNhY3Rpb24ocGFyYW1zOiBhbnkpOiBQcm9taXNlPGFueT4ge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFeHBsYWluIGEgU3RhY2tzIHRyYW5zYWN0aW9uIGZyb20gdHhIZXhcbiAgICogQHBhcmFtIHBhcmFtc1xuICAgKi9cbiAgYXN5bmMgZXhwbGFpblRyYW5zYWN0aW9uKHBhcmFtczogRXhwbGFpblRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8U3R4VHJhbnNhY3Rpb25FeHBsYW5hdGlvbiB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IHR4SGV4ID0gcGFyYW1zLnR4SGV4IHx8IChwYXJhbXMuaGFsZlNpZ25lZCAmJiBwYXJhbXMuaGFsZlNpZ25lZC50eEhleCk7XG4gICAgaWYgKCF0eEhleCB8fCAhcGFyYW1zLmZlZUluZm8pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignbWlzc2luZyBleHBsYWluIHR4IHBhcmFtZXRlcnMnKTtcbiAgICB9XG5cbiAgICBjb25zdCBmYWN0b3J5ID0gbmV3IFN0eExpYi5UcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5KGNvaW5zLmdldCh0aGlzLmdldENoYWluKCkpKTtcbiAgICBjb25zdCB0eEJ1aWxkZXIgPSBmYWN0b3J5LmZyb20odHhIZXgpO1xuXG4gICAgaWYgKHBhcmFtcy5wdWJsaWNLZXlzICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHR4QnVpbGRlci5mcm9tUHViS2V5KHBhcmFtcy5wdWJsaWNLZXlzKTtcbiAgICAgIGlmIChwYXJhbXMucHVibGljS2V5cy5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgLy8gZGVmaW5pdGVseSBhIHNpbmdsZSBzaWcgdHhcbiAgICAgICAgdHhCdWlsZGVyLm51bWJlclNpZ25hdHVyZXMoMSk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgdHggPSBhd2FpdCB0eEJ1aWxkZXIuYnVpbGQoKTtcbiAgICBjb25zdCB0eEpzb24gPSB0eC50b0pzb24oKTtcblxuICAgIGlmICh0eC50eXBlID09PSBUcmFuc2FjdGlvblR5cGUuU2VuZCkge1xuICAgICAgLy8gY2hlY2sgaWYgaXQgaXMgYSB0b2tlbiB0cmFuc2FjdGlvbiBvciBuYXRpdmUgY29pbiB0cmFuc2FjdGlvblxuICAgICAgbGV0IHRyYW5zYWN0aW9uUmVjaXBpZW50OiBUcmFuc2FjdGlvblJlY2lwaWVudDtcbiAgICAgIGxldCBvdXRwdXRBbW91bnQ6IHN0cmluZztcbiAgICAgIGxldCBtZW1vOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgICBpZiAodHhKc29uLnBheWxvYWQuY29udHJhY3RBZGRyZXNzICYmIHR4SnNvbi5wYXlsb2FkLmZ1bmN0aW9uQXJncy5sZW5ndGggPj0gMykge1xuICAgICAgICBvdXRwdXRBbW91bnQgPSBjdlRvVmFsdWUodHhKc29uLnBheWxvYWQuZnVuY3Rpb25BcmdzWzBdKS50b1N0cmluZygpO1xuICAgICAgICB0cmFuc2FjdGlvblJlY2lwaWVudCA9IHtcbiAgICAgICAgICBhZGRyZXNzOiBjdlRvU3RyaW5nKHR4SnNvbi5wYXlsb2FkLmZ1bmN0aW9uQXJnc1syXSksXG4gICAgICAgICAgYW1vdW50OiBvdXRwdXRBbW91bnQsXG4gICAgICAgICAgdG9rZW5OYW1lOiBmaW5kVG9rZW5OYW1lQnlDb250cmFjdCh0eEpzb24ucGF5bG9hZC5jb250cmFjdEFkZHJlc3MsIHR4SnNvbi5wYXlsb2FkLmNvbnRyYWN0TmFtZSksXG4gICAgICAgIH07XG4gICAgICAgIGlmIChcbiAgICAgICAgICB0eEpzb24ucGF5bG9hZC5mdW5jdGlvbkFyZ3MubGVuZ3RoID09PSA0ICYmXG4gICAgICAgICAgdHhKc29uLnBheWxvYWQuZnVuY3Rpb25BcmdzWzNdLnR5cGUgPT09IENsYXJpdHlUeXBlLk9wdGlvbmFsU29tZVxuICAgICAgICApIHtcbiAgICAgICAgICBtZW1vID0gQnVmZmVyLmZyb20odHhKc29uLnBheWxvYWQuZnVuY3Rpb25BcmdzWzNdLnZhbHVlLmJ1ZmZlcikudG9TdHJpbmcoKTtcbiAgICAgICAgICB0cmFuc2FjdGlvblJlY2lwaWVudFsnbWVtbyddID0gbWVtbztcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb3V0cHV0QW1vdW50ID0gdHhKc29uLnBheWxvYWQuYW1vdW50O1xuICAgICAgICBtZW1vID0gdHhKc29uLnBheWxvYWQubWVtbztcbiAgICAgICAgdHJhbnNhY3Rpb25SZWNpcGllbnQgPSB7XG4gICAgICAgICAgYWRkcmVzczogdHhKc29uLnBheWxvYWQudG8sXG4gICAgICAgICAgYW1vdW50OiBvdXRwdXRBbW91bnQsXG4gICAgICAgICAgbWVtbzogbWVtbyxcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IG91dHB1dHM6IFRyYW5zYWN0aW9uUmVjaXBpZW50W10gPSBbdHJhbnNhY3Rpb25SZWNpcGllbnRdO1xuXG4gICAgICBjb25zdCBkaXNwbGF5T3JkZXIgPSBbJ2lkJywgJ291dHB1dEFtb3VudCcsICdjaGFuZ2VBbW91bnQnLCAnb3V0cHV0cycsICdjaGFuZ2VPdXRwdXRzJywgJ2ZlZScsICdtZW1vJywgJ3R5cGUnXTtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGRpc3BsYXlPcmRlcixcbiAgICAgICAgaWQ6IHR4SnNvbi5pZCxcbiAgICAgICAgb3V0cHV0QW1vdW50OiBvdXRwdXRBbW91bnQudG9TdHJpbmcoKSxcbiAgICAgICAgY2hhbmdlQW1vdW50OiAnMCcsXG4gICAgICAgIG91dHB1dHMsXG4gICAgICAgIGNoYW5nZU91dHB1dHM6IFtdLFxuICAgICAgICBmZWU6IHR4SnNvbi5mZWUsXG4gICAgICAgIG1lbW86IG1lbW8sXG4gICAgICAgIHR5cGU6IHR4LnR5cGUsXG4gICAgICB9O1xuICAgIH1cblxuICAgIGlmICh0eC50eXBlID09PSBUcmFuc2FjdGlvblR5cGUuQ29udHJhY3RDYWxsKSB7XG4gICAgICBjb25zdCBkaXNwbGF5T3JkZXIgPSBbXG4gICAgICAgICdpZCcsXG4gICAgICAgICdmZWUnLFxuICAgICAgICAndHlwZScsXG4gICAgICAgICdjb250cmFjdEFkZHJlc3MnLFxuICAgICAgICAnY29udHJhY3ROYW1lJyxcbiAgICAgICAgJ2NvbnRyYWN0RnVuY3Rpb24nLFxuICAgICAgICAnY29udHJhY3RGdW5jdGlvbkFyZ3MnLFxuICAgICAgXTtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGRpc3BsYXlPcmRlcixcbiAgICAgICAgaWQ6IHR4SnNvbi5pZCxcbiAgICAgICAgY2hhbmdlQW1vdW50OiAnMCcsXG4gICAgICAgIG91dHB1dEFtb3VudDogJycsXG4gICAgICAgIG91dHB1dHM6IFtdLFxuICAgICAgICBjaGFuZ2VPdXRwdXRzOiBbXSxcbiAgICAgICAgZmVlOiB0eEpzb24uZmVlLFxuICAgICAgICB0eXBlOiB0eC50eXBlLFxuICAgICAgICBjb250cmFjdEFkZHJlc3M6IHR4SnNvbi5wYXlsb2FkLmNvbnRyYWN0QWRkcmVzcyxcbiAgICAgICAgY29udHJhY3ROYW1lOiB0eEpzb24ucGF5bG9hZC5jb250cmFjdE5hbWUsXG4gICAgICAgIGNvbnRyYWN0RnVuY3Rpb246IHR4SnNvbi5wYXlsb2FkLmZ1bmN0aW9uTmFtZSxcbiAgICAgICAgY29udHJhY3RGdW5jdGlvbkFyZ3M6IHR4SnNvbi5wYXlsb2FkLmZ1bmN0aW9uQXJncyxcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldCBVUkxzIG9mIHNvbWUgYWN0aXZlIHB1YmxpYyBub2Rlc1xuICAgKiBAcmV0dXJucyB7U3RyaW5nfSBub2RlIHVybFxuICAgKi9cbiAgZ2V0UHVibGljTm9kZVVybCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBFbnZpcm9ubWVudHNbdGhpcy5iaXRnby5nZXRFbnYoKV0uc3R4Tm9kZVVybDtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgbmF0aXZlIHN0YWNrcyBiYWxhbmNlIGZvciBhbiBhY2NvdW50XG4gICAqIEBwYXJhbSB7U3RyaW5nfSBhZGRyZXNzIC0gc3RhY2tzIGFkZHJlc3NcbiAgICogQHJldHVybnMge1Byb21pc2U8TmF0aXZlU3R4QmFsYW5jZT59XG4gICAqL1xuICBwcm90ZWN0ZWQgYXN5bmMgZ2V0TmF0aXZlU3R4QmFsYW5jZUZyb21Ob2RlKHsgYWRkcmVzcyB9OiB7IGFkZHJlc3M6IHN0cmluZyB9KTogUHJvbWlzZTxOYXRpdmVTdHhCYWxhbmNlPiB7XG4gICAgY29uc3QgZW5kcG9pbnQgPSBgJHt0aGlzLmdldFB1YmxpY05vZGVVcmwoKX0vZXh0ZW5kZWQvdjIvYWRkcmVzc2VzLyR7YWRkcmVzc30vYmFsYW5jZXMvc3R4YDtcbiAgICB0cnkge1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCB0aGlzLmJpdGdvLmdldChlbmRwb2ludCk7XG4gICAgICBpZiAocmVzcG9uc2Uuc3RhdHVzQ29kZSAhPT0gMjAwKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgcmVxdWVzdCBmYWlsZWQgd2l0aCBzdGF0dXMgJHtyZXNwb25zZS5zdGF0dXNDb2RlfWApO1xuICAgICAgfVxuICAgICAgY29uc3QgYm9keTogTmF0aXZlU3R4QmFsYW5jZSA9IHJlc3BvbnNlLmJvZHk7XG4gICAgICByZXR1cm4gYm9keTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVuYWJsZSB0byBnZXQgbmF0aXZlIHN0eCBiYWxhbmNlIGZyb20gbm9kZTogJHtlLm1lc3NhZ2V9YCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldCBzaW5nbGUgZnVuZ2libGUgdG9rZW4gYmFsYW5jZSBmb3IgYW4gYWNjb3VudFxuICAgKiBAcGFyYW0ge1N0cmluZ30gYWRkcmVzcyAtIHN0YWNrcyBhZGRyZXNzXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBhc3NldElkIC0gZnVuZ2libGUgdG9rZW4gYXNzZXQgaWRcbiAgICogQHJldHVybnMge1Byb21pc2U8U2luZ2xlRnVuZ2libGVUb2tlbkJhbGFuY2U+fVxuICAgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGdldFNpbmdsZUZ1bmdpYmxlVG9rZW5CYWxhbmNlRnJvbU5vZGUoe1xuICAgIGFkZHJlc3MsXG4gICAgYXNzZXRJZCxcbiAgfToge1xuICAgIGFkZHJlc3M6IHN0cmluZztcbiAgICBhc3NldElkOiBzdHJpbmc7XG4gIH0pOiBQcm9taXNlPFNpbmdsZUZ1bmdpYmxlVG9rZW5CYWxhbmNlPiB7XG4gICAgY29uc3QgZW5kcG9pbnQgPSBgJHt0aGlzLmdldFB1YmxpY05vZGVVcmwoKX0vZXh0ZW5kZWQvdjIvYWRkcmVzc2VzLyR7YWRkcmVzc30vYmFsYW5jZXMvZnQvJHthc3NldElkfWA7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgdGhpcy5iaXRnby5nZXQoZW5kcG9pbnQpO1xuICAgICAgaWYgKHJlc3BvbnNlLnN0YXR1c0NvZGUgIT09IDIwMCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHJlcXVlc3QgZmFpbGVkIHdpdGggc3RhdHVzICR7cmVzcG9uc2Uuc3RhdHVzQ29kZX1gKTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IGJvZHk6IFNpbmdsZUZ1bmdpYmxlVG9rZW5CYWxhbmNlID0gcmVzcG9uc2UuYm9keTtcbiAgICAgIHJldHVybiBib2R5O1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdW5hYmxlIHRvIGdldCBuYXRpdmUgc3R4IGJhbGFuY2UgZnJvbSBub2RlOiAke2UubWVzc2FnZX1gKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogR2V0IG5vbmNlIGRhdGEgc3BlY2lmaWMgdG8gYW4gYWNjb3VudCBmcm9tIGEgcHVibGljIG5vZGVcbiAgICogQHBhcmFtIHtTdHJpbmd9IGFkZHJlc3MgLSBzdGFja3MgYWRkcmVzc1xuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxTdHhOb25jZVJlc3BvbnNlPn1cbiAgICovXG4gIHByb3RlY3RlZCBhc3luYyBnZXRBY2NvdW50Tm9uY2VGcm9tTm9kZSh7IGFkZHJlc3MgfTogeyBhZGRyZXNzOiBzdHJpbmcgfSk6IFByb21pc2U8U3R4Tm9uY2VSZXNwb25zZT4ge1xuICAgIGNvbnN0IGVuZHBvaW50ID0gYCR7dGhpcy5nZXRQdWJsaWNOb2RlVXJsKCl9L2V4dGVuZGVkL3YxL2FkZHJlc3MvJHthZGRyZXNzfS9ub25jZXNgO1xuICAgIHRyeSB7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuYml0Z28uZ2V0KGVuZHBvaW50KTtcbiAgICAgIGlmIChyZXNwb25zZS5zdGF0dXNDb2RlICE9PSAyMDApIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGByZXF1ZXN0IGZhaWxlZCB3aXRoIHN0YXR1cyAke3Jlc3BvbnNlLnN0YXR1c0NvZGV9YCk7XG4gICAgICB9XG4gICAgICBjb25zdCBib2R5OiBTdHhOb25jZVJlc3BvbnNlID0gcmVzcG9uc2UuYm9keTtcbiAgICAgIHJldHVybiBib2R5O1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdW5hYmxlIHRvIGdldCBhY2NvdW50IG5vbmNlIGZyb20gbm9kZTogJHtlLm1lc3NhZ2V9YCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldCBzdGFja3MgdHJhbnNhY3Rpb24gZXN0aW1hdGVkIGZlZVxuICAgKiBAcGFyYW0ge1N0cmluZ30gdHhIZXggLSBoZXggb2Ygc3RhY2tzIHRyYW5zYWN0aW9uIHBheWxvYWRcbiAgICogQHBhcmFtIHtOdW1iZXJ9IHR4SGV4TGVuZ3RoIC0gbGVuZ3RoIG9mIGJ1aWx0IHNlcmlhbGl6ZWQgdHJhbnNhY3Rpb25cbiAgICogQHJldHVybnMge1Byb21pc2U8TnVtYmVyPn0gLSBmZWUgZXN0aW1hdGUgKHRha2luZyB0aGUgbG93ZXN0KVxuICAgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGdldFRyYW5zYWN0aW9uRmVlRXN0aW1hdGlvbih7XG4gICAgdHhIZXgsXG4gICAgdHhIZXhMZW5ndGgsXG4gIH06IHtcbiAgICB0eEhleDogc3RyaW5nO1xuICAgIHR4SGV4TGVuZ3RoOiBudW1iZXI7XG4gIH0pOiBQcm9taXNlPG51bWJlcj4ge1xuICAgIGNvbnN0IGVuZHBvaW50ID0gYCR7dGhpcy5nZXRQdWJsaWNOb2RlVXJsKCl9L3YyL2ZlZXMvdHJhbnNhY3Rpb25gO1xuICAgIGNvbnN0IHJlcXVlc3RCb2R5ID0ge1xuICAgICAgdHJhbnNhY3Rpb25fcGF5bG9hZDogdHhIZXgsXG4gICAgICBlc3RpbWF0ZWRfbGVuOiB0eEhleExlbmd0aCxcbiAgICB9O1xuICAgIHRyeSB7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuYml0Z28ucG9zdChlbmRwb2ludCkuc2VuZChyZXF1ZXN0Qm9keSk7XG4gICAgICBpZiAocmVzcG9uc2Uuc3RhdHVzQ29kZSAhPT0gMjAwKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgcmVxdWVzdCBmYWlsZWQgd2l0aCBzdGF0dXMgJHtyZXNwb25zZS5zdGF0dXNDb2RlfWApO1xuICAgICAgfVxuICAgICAgY29uc3QgYm9keTogU3R4VHhuRmVlRXN0aW1hdGlvblJlc3BvbnNlID0gcmVzcG9uc2UuYm9keTtcbiAgICAgIGlmIChib2R5LmVzdGltYXRpb25zLmxlbmd0aCAhPT0gMykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgcmVzcG9uc2UgZXN0aW1hdGlvbiBsZW5ndGgnKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBib2R5LmVzdGltYXRpb25zWzBdLmZlZTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVuYWJsZSB0byBnZXQgdHJhbnNhY3Rpb24gZmVlIGVzdGltYXRpb246ICR7ZS5tZXNzYWdlfWApO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBGb3JtYXQgZm9yIG9mZmxpbmUgdmF1bHQgc2lnbmluZ1xuICAgKiBAcGFyYW0ge0Jhc2VUcmFuc2FjdGlvbn0gdHggLSBiYXNlIHRyYW5zYWN0aW9uXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPFJlY292ZXJ5SW5mbz59XG4gICAqL1xuICBwcm90ZWN0ZWQgYXN5bmMgZm9ybWF0Rm9yT2ZmbGluZVZhdWx0KHR4OiBCYXNlVHJhbnNhY3Rpb24pOiBQcm9taXNlPFJlY292ZXJ5SW5mbz4ge1xuICAgIGNvbnN0IHR4SnNvbjogVHhEYXRhID0gdHgudG9Kc29uKCk7XG4gICAgY29uc3QgdHJhbnNhY3Rpb25FeHBsYW5hdGlvbjogUmVjb3ZlcnlJbmZvID0gKGF3YWl0IHRoaXMuZXhwbGFpblRyYW5zYWN0aW9uKHtcbiAgICAgIHR4SGV4OiB0eC50b0Jyb2FkY2FzdEZvcm1hdCgpLFxuICAgICAgZmVlSW5mbzogeyBmZWU6IHR4SnNvbi5mZWUgfSxcbiAgICB9KSkgYXMgUmVjb3ZlcnlJbmZvO1xuICAgIHRyYW5zYWN0aW9uRXhwbGFuYXRpb24uY29pbiA9IHRoaXMuZ2V0Q2hhaW4oKTtcbiAgICB0cmFuc2FjdGlvbkV4cGxhbmF0aW9uLmZlZUluZm8gPSB7IGZlZTogdHhKc29uLmZlZSB9O1xuICAgIHRyYW5zYWN0aW9uRXhwbGFuYXRpb24udHhIZXggPSB0eC50b0Jyb2FkY2FzdEZvcm1hdCgpO1xuICAgIHJldHVybiB0cmFuc2FjdGlvbkV4cGxhbmF0aW9uO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgcmVjb3ZlcmFibGUgYW1vdW50ICYgZmVlIGFmdGVyIHN1YnRyYWN0aW5nIHRoZSB0eG4gZmVlXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBzZXJpYWxpemVkSGV4IC0gc2VyaWFsaXplZCB0eG4gaGV4XG4gICAqIEBwYXJhbSB7TnVtYmVyfSB0eEhleExlbmd0aCAtIGRlc2VyaWFsaXplZCB0eG4gbGVuZ3RoXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBiYWxhbmNlIC0gdG90YWwgYWNjb3VudCBiYWxhbmNlXG4gICAqIEBwYXJhbSB7U3RyaW5nfSB0b2tlbkJhbGFuY2UgLSB0b3RhbCB0b2tlbiBiYWxhbmNlXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPFJlY29yZDxzdHJpbmcsIHN0cmluZz4+fVxuICAgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGdldFJlY292ZXJhYmxlQW1vdW50QW5kRmVlKFxuICAgIHNlcmlhbGl6ZWRIZXg6IHN0cmluZyxcbiAgICB0eEhleExlbmd0aDogbnVtYmVyLFxuICAgIGJhbGFuY2U6IHN0cmluZyxcbiAgICB0b2tlbkJhbGFuY2U/OiBzdHJpbmdcbiAgKTogUHJvbWlzZTxSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+PiB7XG4gICAgY29uc3QgZXN0aW1hdGVkRmVlID0gYXdhaXQgdGhpcy5nZXRUcmFuc2FjdGlvbkZlZUVzdGltYXRpb24oe1xuICAgICAgdHhIZXg6IHNlcmlhbGl6ZWRIZXgsXG4gICAgICB0eEhleExlbmd0aDogdHhIZXhMZW5ndGgsXG4gICAgfSk7XG4gICAgY29uc3QgYmFsYW5jZUJOID0gbmV3IEJpZ051bWJlcihiYWxhbmNlKTtcbiAgICBjb25zdCBmZWVCTiA9IG5ldyBCaWdOdW1iZXIoZXN0aW1hdGVkRmVlKTtcbiAgICBpZiAoYmFsYW5jZUJOLmlzTGVzc1RoYW4oZmVlQk4pKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2luc3VmZmljaWVudCBiYWxhbmNlIHRvIGJ1aWxkIHRoZSB0cmFuc2FjdGlvbicpO1xuICAgIH1cbiAgICByZXR1cm4ge1xuICAgICAgcmVjb3ZlcmFibGVBbW91bnQ6IHRva2VuQmFsYW5jZSA/PyBiYWxhbmNlQk4ubWludXMoZmVlQk4pLnRvU3RyaW5nKCksXG4gICAgICBmZWU6IGZlZUJOLnRvU3RyaW5nKCksXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBNZXRob2QgdG8gZmluZCB0aGUgcmlnaHQgYnVpbGRlciBmb3IgdG9rZW4gb3IgbmF0aXZlIGNvaW4gdHJhbnNmZXJcbiAgICogQHBhcmFtIHtTdHJpbmd9IGNvbnRyYWN0QWRkcmVzcyAtIHRva2VuIGNvbnRyYWN0IGFkZHJlc3NcbiAgICogQHBhcmFtIHtTdHJpbmd9IGNvbnRyYWN0TmFtZSAtIHRva2VuIGNvbnRyYWN0IG5hbWVcbiAgICogQHJldHVybnMge1RyYW5zZmVyQnVpbGRlcnxGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyfVxuICAgKi9cbiAgcHJvdGVjdGVkIGdldFRva2VuT3JOYXRpdmVUcmFuc2ZlckJ1aWxkZXIoXG4gICAgY29udHJhY3RBZGRyZXNzPzogc3RyaW5nLFxuICAgIGNvbnRyYWN0TmFtZT86IHN0cmluZ1xuICApOiBUcmFuc2ZlckJ1aWxkZXIgfCBGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyIHtcbiAgICBjb25zdCBpc1Rva2VuID0gISFjb250cmFjdEFkZHJlc3MgJiYgISFjb250cmFjdE5hbWU7XG4gICAgbGV0IGZhY3Rvcnk6IFRyYW5zYWN0aW9uQnVpbGRlckZhY3Rvcnk7XG4gICAgaWYgKGlzVG9rZW4pIHtcbiAgICAgIGNvbnN0IHRva2VuTmFtZSA9IGZpbmRUb2tlbk5hbWVCeUNvbnRyYWN0KGNvbnRyYWN0QWRkcmVzcywgY29udHJhY3ROYW1lKTtcbiAgICAgIGlmICghdG9rZW5OYW1lKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignaW52YWxpZCBjb250cmFjdCBhZGRyZXNzIG9yIGNvbnRyYWN0IG5hbWUsIG5vdCBzdXBwb3J0ZWQnKTtcbiAgICAgIH1cbiAgICAgIGZhY3RvcnkgPSBuZXcgVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeShjb2lucy5nZXQodG9rZW5OYW1lKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGZhY3RvcnkgPSBuZXcgVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeShjb2lucy5nZXQodGhpcy5nZXRDaGFpbigpKSk7XG4gICAgfVxuICAgIGxldCBidWlsZGVyOiBUcmFuc2ZlckJ1aWxkZXIgfCBGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyO1xuICAgIGlmIChpc1Rva2VuKSB7XG4gICAgICBidWlsZGVyID0gZmFjdG9yeS5nZXRGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGJ1aWxkZXIgPSBmYWN0b3J5LmdldFRyYW5zZmVyQnVpbGRlcigpO1xuICAgIH1cbiAgICByZXR1cm4gYnVpbGRlcjtcbiAgfVxuXG4gIC8qKlxuICAgKiBNZXRob2QgdG8gYnVpbGQgZnVuZ2libGUgdG9rZW4gdHJhbnNmZXIgdHJhbnNhY3Rpb25cbiAgICogQHBhcmFtIHtGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyfSBidWlsZGVyIC0gZnVuZ2libGUgdG9rZW4gdHJhbnNmZXIgYnVpbGRlclxuICAgKiBAcGFyYW0ge1N0cmluZ30gY29udHJhY3RBZGRyZXNzIC0gdG9rZW4gY29udHJhY3QgYWRkcmVzc1xuICAgKiBAcGFyYW0ge1N0cmluZ30gY29udHJhY3ROYW1lIC0gdG9rZW4gY29udHJhY3QgbmFtZVxuICAgKiBAcGFyYW0ge1N0cmluZ1tdfSBwdWJzIC0gYWNjb3VudCBwdWJsaWMga2V5c1xuICAgKiBAcGFyYW0ge051bWJlcn0gbm9uY2UgLSBhY2NvdW50IG5vbmNlXG4gICAqIEBwYXJhbSB7QWRkcmVzc0RldGFpbHN9IHJvb3RBZGRyZXNzRGV0YWlscyAtIHJvb3QgYWRkcmVzcyBkZXRhaWxzXG4gICAqIEBwYXJhbSB7QWRkcmVzc0RldGFpbHN9IGRlc3RpbmF0aW9uQWRkcmVzc0RldGFpbHMgLSByZWNlaXZlIGFkZHJlc3MgZGV0YWlsc1xuICAgKiBAcGFyYW0ge1N0cmluZ30gc3R4QmFsYW5jZSAtIG5hdGl2ZSBzdHggYmFsYW5jZVxuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxCYXNlVHJhbnNhY3Rpb24+fSAtIGJ1aWx0IHRyYW5zYWN0aW9uXG4gICAqL1xuICBwcm90ZWN0ZWQgYXN5bmMgYnVpbGRUb2tlblRyYW5zZmVyVHJhbnNhY3Rpb24oe1xuICAgIGJ1aWxkZXIsXG4gICAgY29udHJhY3RBZGRyZXNzLFxuICAgIGNvbnRyYWN0TmFtZSxcbiAgICBwdWJzLFxuICAgIG5vbmNlLFxuICAgIHJvb3RBZGRyZXNzRGV0YWlscyxcbiAgICBkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzLFxuICAgIHN0eEJhbGFuY2UsXG4gIH06IHtcbiAgICBidWlsZGVyOiBGdW5naWJsZVRva2VuVHJhbnNmZXJCdWlsZGVyO1xuICAgIGNvbnRyYWN0QWRkcmVzczogc3RyaW5nO1xuICAgIGNvbnRyYWN0TmFtZTogc3RyaW5nO1xuICAgIHB1YnM6IHN0cmluZ1tdO1xuICAgIG5vbmNlOiBudW1iZXI7XG4gICAgcm9vdEFkZHJlc3NEZXRhaWxzOiBBZGRyZXNzRGV0YWlscztcbiAgICBkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzOiBBZGRyZXNzRGV0YWlscztcbiAgICBzdHhCYWxhbmNlOiBzdHJpbmc7XG4gIH0pOiBQcm9taXNlPEJhc2VUcmFuc2FjdGlvbj4ge1xuICAgIGNvbnN0IHR4QnVpbGRlciA9IGJ1aWxkZXIgYXMgRnVuZ2libGVUb2tlblRyYW5zZmVyQnVpbGRlcjtcbiAgICBjb25zdCBjb250cmFjdFRva2VuTmFtZSA9IGZpbmRDb250cmFjdFRva2VuTmFtZVVzaW5nQ29udHJhY3QoY29udHJhY3RBZGRyZXNzLCBjb250cmFjdE5hbWUpO1xuICAgIGlmICghY29udHJhY3RUb2tlbk5hbWUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignaW52YWxpZCBjb250cmFjdCBhZGRyZXNzIG9yIGNvbnRyYWN0IG5hbWUsIG5vdCBzdXBwb3J0ZWQnKTtcbiAgICB9XG4gICAgY29uc3QgYXNzZXRJZCA9IGAke2NvbnRyYWN0QWRkcmVzc30uJHtjb250cmFjdE5hbWV9Ojoke2NvbnRyYWN0VG9rZW5OYW1lfWA7XG4gICAgLy8gZmV0Y2ggdGhlIHRva2VuIGJhbGFuY2VcbiAgICBjb25zdCB0b2tlbkJhbGFuY2VEYXRhID0gYXdhaXQgdGhpcy5nZXRTaW5nbGVGdW5naWJsZVRva2VuQmFsYW5jZUZyb21Ob2RlKHtcbiAgICAgIGFkZHJlc3M6IHJvb3RBZGRyZXNzRGV0YWlscy5hZGRyZXNzLFxuICAgICAgYXNzZXRJZCxcbiAgICB9KTtcbiAgICBjb25zdCB0b2tlbkJhbGFuY2UgPSB0b2tlbkJhbGFuY2VEYXRhPy5iYWxhbmNlO1xuICAgIGlmICghTnVtYmVyKHRva2VuQmFsYW5jZSkgfHwgaXNOYU4oTnVtYmVyKHRva2VuQmFsYW5jZSkpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBubyB0b2tlbiBiYWxhbmNlIGZvdW5kIHRvIHJlY292ZXIgZm9yIGFkZHJlc3M6ICR7cm9vdEFkZHJlc3NEZXRhaWxzLmFkZHJlc3N9LCB0b2tlbjogJHthc3NldElkfWBcbiAgICAgICk7XG4gICAgfVxuICAgIHR4QnVpbGRlci5mZWUoeyBmZWU6ICcyMDAnIH0pO1xuICAgIHR4QnVpbGRlci5udW1iZXJTaWduYXR1cmVzKDIpO1xuICAgIHR4QnVpbGRlci5mcm9tUHViS2V5KHB1YnMpO1xuICAgIHR4QnVpbGRlci5ub25jZShub25jZSk7XG4gICAgdHhCdWlsZGVyLmNvbnRyYWN0QWRkcmVzcyhjb250cmFjdEFkZHJlc3MpO1xuICAgIHR4QnVpbGRlci5jb250cmFjdE5hbWUoY29udHJhY3ROYW1lKTtcbiAgICBpZiAoY29udHJhY3RUb2tlbk5hbWUpIHtcbiAgICAgIHR4QnVpbGRlci50b2tlbk5hbWUoY29udHJhY3RUb2tlbk5hbWUpO1xuICAgIH1cbiAgICB0eEJ1aWxkZXIuZnVuY3Rpb25OYW1lKCd0cmFuc2ZlcicpO1xuICAgIGNvbnN0IGZ1bmN0aW9uQXJnczogQ2xhcml0eVZhbHVlW10gPSBbXG4gICAgICB1aW50Q1YodG9rZW5CYWxhbmNlKSxcbiAgICAgIHN0YW5kYXJkUHJpbmNpcGFsQ1Yocm9vdEFkZHJlc3NEZXRhaWxzLmFkZHJlc3MpLFxuICAgICAgc3RhbmRhcmRQcmluY2lwYWxDVihkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzLmFkZHJlc3MpLFxuICAgIF07XG4gICAgaWYgKGRlc3RpbmF0aW9uQWRkcmVzc0RldGFpbHMubWVtb0lkKSB7XG4gICAgICBmdW5jdGlvbkFyZ3MucHVzaChzb21lQ1YoYnVmZmVyQ1ZGcm9tU3RyaW5nKGRlc3RpbmF0aW9uQWRkcmVzc0RldGFpbHMubWVtb0lkKSkpO1xuICAgIH0gZWxzZSB7XG4gICAgICBmdW5jdGlvbkFyZ3MucHVzaChub25lQ1YoKSk7XG4gICAgfVxuICAgIHR4QnVpbGRlci5mdW5jdGlvbkFyZ3MoZnVuY3Rpb25BcmdzKTtcbiAgICBjb25zdCBiYXNlVHhuID0gYXdhaXQgdHhCdWlsZGVyLmJ1aWxkKCk7XG4gICAgY29uc3QgdHhCcm9hZGNhc3RGb3JtYXQgPSBiYXNlVHhuLnRvQnJvYWRjYXN0Rm9ybWF0KCk7XG4gICAgY29uc3QgdHhEZXNlcmlhbGl6ZWQgPSBkZXNlcmlhbGl6ZVRyYW5zYWN0aW9uKHR4QnJvYWRjYXN0Rm9ybWF0KTtcbiAgICBjb25zdCBzZXJpYWxpemVkSGV4ID0gc2VyaWFsaXplUGF5bG9hZCh0eERlc2VyaWFsaXplZC5wYXlsb2FkKS50b1N0cmluZygnaGV4Jyk7XG4gICAgY29uc3QgeyByZWNvdmVyYWJsZUFtb3VudCwgZmVlIH0gPSBhd2FpdCB0aGlzLmdldFJlY292ZXJhYmxlQW1vdW50QW5kRmVlKFxuICAgICAgc2VyaWFsaXplZEhleCxcbiAgICAgIHR4QnJvYWRjYXN0Rm9ybWF0Lmxlbmd0aCxcbiAgICAgIHN0eEJhbGFuY2UsXG4gICAgICB0b2tlbkJhbGFuY2VcbiAgICApO1xuICAgIGZ1bmN0aW9uQXJnc1swXSA9IHVpbnRDVihyZWNvdmVyYWJsZUFtb3VudCk7XG4gICAgdHhCdWlsZGVyLmZ1bmN0aW9uQXJncyhmdW5jdGlvbkFyZ3MpO1xuICAgIHR4QnVpbGRlci5mZWUoeyBmZWU6IGZlZSB9KTtcbiAgICByZXR1cm4gYXdhaXQgdHhCdWlsZGVyLmJ1aWxkKCk7XG4gIH1cblxuICAvKipcbiAgICogTWV0aG9kIHRvIGJ1aWxkIG5hdGl2ZSB0cmFuc2ZlciB0cmFuc2FjdGlvblxuICAgKiBAcGFyYW0ge1RyYW5zZmVyQnVpbGRlcn0gYnVpbGRlciAtIHRyYW5zZmVyIGJ1aWxkZXJcbiAgICogQHBhcmFtIHtTdHJpbmdbXX0gcHVicyAtIGFjY291bnQgcHVibGljIGtleXNcbiAgICogQHBhcmFtIHtOdW1iZXJ9IG5vbmNlIC0gYWNjb3VudCBub25jZVxuICAgKiBAcGFyYW0ge0FkZHJlc3NEZXRhaWxzfSBkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzIC0gcmVjZWl2ZSBhZGRyZXNzIGRldGFpbHNcbiAgICogQHBhcmFtIHtTdHJpbmd9IHN0eEJhbGFuY2UgLSBuYXRpdmUgc3R4IGJhbGFuY2VcbiAgICogQHJldHVybnMge1Byb21pc2U8QmFzZVRyYW5zYWN0aW9uPn0gLSBidWlsdCB0cmFuc2FjdGlvblxuICAgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGJ1aWxkTmF0aXZlVHJhbnNmZXJUcmFuc2FjdGlvbih7XG4gICAgYnVpbGRlcixcbiAgICBwdWJzLFxuICAgIG5vbmNlLFxuICAgIGRlc3RpbmF0aW9uQWRkcmVzc0RldGFpbHMsXG4gICAgc3R4QmFsYW5jZSxcbiAgfToge1xuICAgIGJ1aWxkZXI6IFRyYW5zZmVyQnVpbGRlcjtcbiAgICBwdWJzOiBzdHJpbmdbXTtcbiAgICBub25jZTogbnVtYmVyO1xuICAgIGRlc3RpbmF0aW9uQWRkcmVzc0RldGFpbHM6IEFkZHJlc3NEZXRhaWxzO1xuICAgIHN0eEJhbGFuY2U6IHN0cmluZztcbiAgfSk6IFByb21pc2U8QmFzZVRyYW5zYWN0aW9uPiB7XG4gICAgY29uc3QgdHhCdWlsZGVyID0gYnVpbGRlciBhcyBUcmFuc2ZlckJ1aWxkZXI7XG4gICAgdHhCdWlsZGVyLmZlZSh7IGZlZTogJzIwMCcgfSk7XG4gICAgdHhCdWlsZGVyLm51bWJlclNpZ25hdHVyZXMoMik7XG4gICAgdHhCdWlsZGVyLmZyb21QdWJLZXkocHVicyk7XG4gICAgdHhCdWlsZGVyLm5vbmNlKG5vbmNlKTtcbiAgICB0eEJ1aWxkZXIudG8oZGVzdGluYXRpb25BZGRyZXNzRGV0YWlscy5hZGRyZXNzKTtcbiAgICB0eEJ1aWxkZXIuYW1vdW50KHN0eEJhbGFuY2UpO1xuICAgIGlmIChkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzLm1lbW9JZCkge1xuICAgICAgdHhCdWlsZGVyLm1lbW8oZGVzdGluYXRpb25BZGRyZXNzRGV0YWlscy5tZW1vSWQpO1xuICAgIH1cbiAgICBjb25zdCBiYXNlVHhuID0gYXdhaXQgdHhCdWlsZGVyLmJ1aWxkKCk7XG4gICAgY29uc3QgdHhCcm9hZGNhc3RGb3JtYXQgPSBiYXNlVHhuLnRvQnJvYWRjYXN0Rm9ybWF0KCk7XG4gICAgY29uc3QgdHhEZXNlcmlhbGl6ZWQgPSBkZXNlcmlhbGl6ZVRyYW5zYWN0aW9uKHR4QnJvYWRjYXN0Rm9ybWF0KTtcbiAgICBjb25zdCBzZXJpYWxpemVkSGV4ID0gc2VyaWFsaXplUGF5bG9hZCh0eERlc2VyaWFsaXplZC5wYXlsb2FkKS50b1N0cmluZygnaGV4Jyk7XG4gICAgY29uc3QgeyByZWNvdmVyYWJsZUFtb3VudCwgZmVlIH0gPSBhd2FpdCB0aGlzLmdldFJlY292ZXJhYmxlQW1vdW50QW5kRmVlKFxuICAgICAgc2VyaWFsaXplZEhleCxcbiAgICAgIHR4QnJvYWRjYXN0Rm9ybWF0Lmxlbmd0aCxcbiAgICAgIHN0eEJhbGFuY2VcbiAgICApO1xuICAgIHR4QnVpbGRlci5hbW91bnQocmVjb3ZlcmFibGVBbW91bnQpO1xuICAgIHR4QnVpbGRlci5mZWUoeyBmZWU6IGZlZSB9KTtcbiAgICByZXR1cm4gYXdhaXQgdHhCdWlsZGVyLmJ1aWxkKCk7XG4gIH1cblxuICAvKipcbiAgICogTWV0aG9kIHRoYXQgdXNlcyBhcHByb3ByaWF0ZSBidWlsZGVyIGFuZCBidWlsZHMgdHJhbnNhY3Rpb24gZGVwZW5kaW5nIG9uIHRva2VuIG9yIG5hdGl2ZSBjb2luXG4gICAqIEBwYXJhbSB7U3RyaW5nW119IHB1YnMgLSBwdWJsaWMga2V5c1xuICAgKiBAcGFyYW0ge0FkZHJlc3NEZXRhaWxzfSByb290QWRkcmVzc0RldGFpbHMgLSBzZW5kZXIgYWRkcmVzcyBkZXRhaWxcbiAgICogQHBhcmFtIHtBZGRyZXNzRGV0YWlsc30gZGVzdGluYXRpb25BZGRyZXNzRGV0YWlscyAtIHJlY2VpdmVyIGFkZHJlc3MgZGV0YWlsXG4gICAqIEBwYXJhbSB7TnVtYmVyfSBub25jZSAtIHdhbGxldCBub25jZVxuICAgKiBAcGFyYW0ge1N0cmluZ30gYmFsYW5jZSAtIHdhbGxldCBiYWxhbmNlXG4gICAqIEBwYXJhbSB7U3RyaW5nIHwgdW5kZWZpbmVkfSBjb250cmFjdEFkZHJlc3MgLSB0b2tlbiBjb250cmFjdCBhZGRyZXNzXG4gICAqIEBwYXJhbSB7U3RyaW5nIHwgdW5kZWZpbmVkfSBjb250cmFjdE5hbWUgLSB0b2tlbiBjb250cmFjdCBuYW1lXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPEJhc2VUcmFuc2FjdGlvbj59IGJ1aWx0IHRyYW5zYWN0aW9uXG4gICAqL1xuICBwcm90ZWN0ZWQgYXN5bmMgZ2V0TmF0aXZlT3JUb2tlblRyYW5zYWN0aW9uKHtcbiAgICBwdWJzLFxuICAgIHJvb3RBZGRyZXNzRGV0YWlscyxcbiAgICBkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzLFxuICAgIG5vbmNlLFxuICAgIHN0eEJhbGFuY2UsXG4gICAgY29udHJhY3RBZGRyZXNzSW5wdXQsXG4gICAgY29udHJhY3ROYW1lLFxuICB9OiB7XG4gICAgcHViczogc3RyaW5nW107XG4gICAgcm9vdEFkZHJlc3NEZXRhaWxzOiBBZGRyZXNzRGV0YWlscztcbiAgICBkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzOiBBZGRyZXNzRGV0YWlscztcbiAgICBub25jZTogbnVtYmVyO1xuICAgIHN0eEJhbGFuY2U6IHN0cmluZztcbiAgICBjb250cmFjdEFkZHJlc3NJbnB1dD86IHN0cmluZztcbiAgICBjb250cmFjdE5hbWU/OiBzdHJpbmc7XG4gIH0pOiBQcm9taXNlPHsgdHg6IEJhc2VUcmFuc2FjdGlvbjsgYnVpbGRlcjogVHJhbnNmZXJCdWlsZGVyIHwgRnVuZ2libGVUb2tlblRyYW5zZmVyQnVpbGRlciB9PiB7XG4gICAgY29uc3QgYnVpbGRlciA9IHRoaXMuZ2V0VG9rZW5Pck5hdGl2ZVRyYW5zZmVyQnVpbGRlcihjb250cmFjdEFkZHJlc3NJbnB1dCwgY29udHJhY3ROYW1lKTtcbiAgICBjb25zdCBjb250cmFjdEFkZHJlc3MgPSBjb250cmFjdEFkZHJlc3NJbnB1dD8udG9VcHBlckNhc2UoKTtcbiAgICBjb25zdCBpc1Rva2VuID0gISFjb250cmFjdEFkZHJlc3MgJiYgISFjb250cmFjdE5hbWU7XG4gICAgbGV0IGZpbmFsVHg6IEJhc2VUcmFuc2FjdGlvbjtcbiAgICBpZiAoaXNUb2tlbikge1xuICAgICAgZmluYWxUeCA9IGF3YWl0IHRoaXMuYnVpbGRUb2tlblRyYW5zZmVyVHJhbnNhY3Rpb24oe1xuICAgICAgICBidWlsZGVyOiBidWlsZGVyIGFzIEZ1bmdpYmxlVG9rZW5UcmFuc2ZlckJ1aWxkZXIsXG4gICAgICAgIGNvbnRyYWN0QWRkcmVzcyxcbiAgICAgICAgY29udHJhY3ROYW1lLFxuICAgICAgICBwdWJzLFxuICAgICAgICBub25jZSxcbiAgICAgICAgcm9vdEFkZHJlc3NEZXRhaWxzLFxuICAgICAgICBkZXN0aW5hdGlvbkFkZHJlc3NEZXRhaWxzLFxuICAgICAgICBzdHhCYWxhbmNlLFxuICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGZpbmFsVHggPSBhd2FpdCB0aGlzLmJ1aWxkTmF0aXZlVHJhbnNmZXJUcmFuc2FjdGlvbih7XG4gICAgICAgIGJ1aWxkZXI6IGJ1aWxkZXIgYXMgVHJhbnNmZXJCdWlsZGVyLFxuICAgICAgICBwdWJzLFxuICAgICAgICBub25jZSxcbiAgICAgICAgZGVzdGluYXRpb25BZGRyZXNzRGV0YWlscyxcbiAgICAgICAgc3R4QmFsYW5jZSxcbiAgICAgIH0pO1xuICAgIH1cbiAgICByZXR1cm4ge1xuICAgICAgdHg6IGZpbmFsVHgsXG4gICAgICBidWlsZGVyOiBidWlsZGVyLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogTWV0aG9kIHRvIHJlY292ZXIgbmF0aXZlIHN0eCBvciBzaXAxMCB0b2tlbnMgZnJvbSBiaXRnbyBob3QgJiBjb2xkIHdhbGxldHNcbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5iYWNrdXBLZXkgLSBlbmNyeXB0ZWQgd2FsbGV0IGJhY2t1cCBrZXkgKHB1YmxpYyBvciBwcml2YXRlKVxuICAgKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLnVzZXJLZXkgLSBlbmNyeXB0ZWQgd2FsbGV0IHVzZXIga2V5IChwdWJsaWMgb3IgcHJpdmF0ZSlcbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5yb290QWRkcmVzcyAtIHdhbGxldCByb290IGFkZHJlc3NcbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5yZWNvdmVyeURlc3RpbmF0aW9uIC0gcmVjZWl2ZSBhZGRyZXNzXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBwYXJhbXMuYml0Z29LZXkgLSBlbmNyeXB0ZWQgYml0Z28gcHVibGljIGtleVxuICAgKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLndhbGxldFBhc3NwaHJhc2UgLSB3YWxsZXQgcGFzc3dvcmRcbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5jb250cmFjdElkIC0gY29udHJhY3QgaWQgb2YgdGhlIHRva2VuIChtYW5kYXRvcnkgZm9yIHRva2VuIHJlY292ZXJ5KVxuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxSZWNvdmVyeUluZm98UmVjb3ZlcnlUcmFuc2FjdGlvbj59IFJlY292ZXJ5VHJhbnNhY3Rpb24udHhIZXggLSBoZXggb2Ygc2VyaWFsaXplZCB0cmFuc2FjdGlvbiAoc2lnbmVkIG9yIHVuc2lnbmVkKVxuICAgKi9cbiAgYXN5bmMgcmVjb3ZlcihwYXJhbXM6IFJlY292ZXJ5T3B0aW9ucyk6IFByb21pc2U8UmVjb3ZlcnlJbmZvIHwgUmVjb3ZlcnlUcmFuc2FjdGlvbj4ge1xuICAgIGlmICghdGhpcy5pc1ZhbGlkQWRkcmVzcyhwYXJhbXMucm9vdEFkZHJlc3MpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2ludmFsaWQgcm9vdCBhZGRyZXNzIScpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuaXNWYWxpZEFkZHJlc3MocGFyYW1zLnJlY292ZXJ5RGVzdGluYXRpb24pKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2ludmFsaWQgZGVzdGluYXRpb24gYWRkcmVzcyEnKTtcbiAgICB9XG4gICAgbGV0IGNvbnRyYWN0QWRkcmVzczogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIGxldCBjb250cmFjdE5hbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICBpZiAocGFyYW1zLmNvbnRyYWN0SWQpIHtcbiAgICAgIFtjb250cmFjdEFkZHJlc3MsIGNvbnRyYWN0TmFtZV0gPSBwYXJhbXMuY29udHJhY3RJZC5zcGxpdCgnLicpO1xuICAgICAgaWYgKChjb250cmFjdEFkZHJlc3MgJiYgIWNvbnRyYWN0TmFtZSkgfHwgKGNvbnRyYWN0TmFtZSAmJiAhY29udHJhY3RBZGRyZXNzKSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ2ludmFsaWQgY29udHJhY3QgaWQsIHBsZWFzZSBwcm92aWRlIGl0IGluIHRoZSBmb3JtIChjb250cmFjdEFkZHJlc3MuY29udHJhY3ROYW1lKScpO1xuICAgICAgfVxuICAgIH1cbiAgICBjb25zdCBpc1Vuc2lnbmVkU3dlZXAgPSBnZXRJc1Vuc2lnbmVkU3dlZXAocGFyYW1zKTtcbiAgICBjb25zdCBrZXlzID0gZ2V0QmlwMzJLZXlzKHRoaXMuYml0Z28sIHBhcmFtcywgeyByZXF1aXJlQml0R29YcHViOiB0cnVlIH0pO1xuICAgIGNvbnN0IHJvb3RBZGRyZXNzRGV0YWlscyA9IGdldEFkZHJlc3NEZXRhaWxzKHBhcmFtcy5yb290QWRkcmVzcyk7XG4gICAgY29uc3QgW2FjY291bnRCYWxhbmNlRGF0YSwgYWNjb3VudE5vbmNlRGF0YV0gPSBhd2FpdCBQcm9taXNlLmFsbChbXG4gICAgICB0aGlzLmdldE5hdGl2ZVN0eEJhbGFuY2VGcm9tTm9kZSh7IGFkZHJlc3M6IHJvb3RBZGRyZXNzRGV0YWlscy5hZGRyZXNzIH0pLFxuICAgICAgdGhpcy5nZXRBY2NvdW50Tm9uY2VGcm9tTm9kZSh7IGFkZHJlc3M6IHJvb3RBZGRyZXNzRGV0YWlscy5hZGRyZXNzIH0pLFxuICAgIF0pO1xuICAgIGNvbnN0IGJhbGFuY2UgPSBOdW1iZXIoYWNjb3VudEJhbGFuY2VEYXRhLmJhbGFuY2UpO1xuICAgIGlmICghYmFsYW5jZSB8fCBpc05hTihiYWxhbmNlKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdjb3VsZCBub3QgZmluZCBhbnkgYmFsYW5jZSB0byByZWNvdmVyIGZvciAnICsgcGFyYW1zLnJvb3RBZGRyZXNzKTtcbiAgICB9XG4gICAgY29uc3QgdXNlclB1YiA9IHB1YmxpY0tleUZyb21CdWZmZXIoa2V5c1swXS5wdWJsaWNLZXkpO1xuICAgIGNvbnN0IGJhY2t1cFB1YiA9IHB1YmxpY0tleUZyb21CdWZmZXIoa2V5c1sxXS5wdWJsaWNLZXkpO1xuICAgIGNvbnN0IGJpdGdvUHViS2V5ID0gcHVibGljS2V5RnJvbUJ1ZmZlcihrZXlzWzJdLnB1YmxpY0tleSk7XG4gICAgY29uc3QgcHVicyA9IFtwdWJsaWNLZXlUb1N0cmluZyh1c2VyUHViKSwgcHVibGljS2V5VG9TdHJpbmcoYmFja3VwUHViKSwgcHVibGljS2V5VG9TdHJpbmcoYml0Z29QdWJLZXkpXTtcblxuICAgIGNvbnN0IGRlc3RpbmF0aW9uQWRkcmVzc0RldGFpbHMgPSBnZXRBZGRyZXNzRGV0YWlscyhwYXJhbXMucmVjb3ZlcnlEZXN0aW5hdGlvbik7XG4gICAgY29uc3Qgbm9uY2UgPVxuICAgICAgdHlwZW9mIGFjY291bnROb25jZURhdGE/Lmxhc3RfZXhlY3V0ZWRfdHhfbm9uY2UgPT09ICdudW1iZXInID8gYWNjb3VudE5vbmNlRGF0YS5sYXN0X2V4ZWN1dGVkX3R4X25vbmNlICsgMSA6IDA7XG5cbiAgICBjb25zdCB7IHR4LCBidWlsZGVyIH0gPSBhd2FpdCB0aGlzLmdldE5hdGl2ZU9yVG9rZW5UcmFuc2FjdGlvbih7XG4gICAgICBwdWJzLFxuICAgICAgcm9vdEFkZHJlc3NEZXRhaWxzLFxuICAgICAgZGVzdGluYXRpb25BZGRyZXNzRGV0YWlscyxcbiAgICAgIG5vbmNlLFxuICAgICAgc3R4QmFsYW5jZTogYWNjb3VudEJhbGFuY2VEYXRhLmJhbGFuY2UsXG4gICAgICBjb250cmFjdEFkZHJlc3NJbnB1dDogY29udHJhY3RBZGRyZXNzLFxuICAgICAgY29udHJhY3ROYW1lOiBjb250cmFjdE5hbWUsXG4gICAgfSk7XG5cbiAgICBpZiAoaXNVbnNpZ25lZFN3ZWVwKSB7XG4gICAgICByZXR1cm4gYXdhaXQgdGhpcy5mb3JtYXRGb3JPZmZsaW5lVmF1bHQodHgpO1xuICAgIH1cbiAgICAvLyBjaGVjayB0aGUgcHJpdmF0ZSBrZXkgJiBzaWduXG4gICAgaWYgKCFrZXlzWzBdLnByaXZhdGVLZXkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdXNlcktleSBpcyBub3QgYSBwcml2YXRlIGtleWApO1xuICAgIH1cbiAgICBjb25zdCB1c2VyS2V5ID0gY3JlYXRlU3RhY2tzUHJpdmF0ZUtleShrZXlzWzBdLnByaXZhdGVLZXkpO1xuICAgIGJ1aWxkZXIuc2lnbih7IGtleTogcHJpdmF0ZUtleVRvU3RyaW5nKHVzZXJLZXkpIH0pO1xuXG4gICAgY29uc3QgaGFsZlNpZ25lZFR4ID0gYXdhaXQgYnVpbGRlci5idWlsZCgpO1xuICAgIGNvbnN0IHR4SGV4SGFsZlNpZ25lZCA9IGhhbGZTaWduZWRUeC50b0Jyb2FkY2FzdEZvcm1hdCgpO1xuICAgIGNvbnN0IGJ1aWxkZXIyID0gdGhpcy5nZXRUb2tlbk9yTmF0aXZlVHJhbnNmZXJCdWlsZGVyKGNvbnRyYWN0QWRkcmVzcywgY29udHJhY3ROYW1lKTtcbiAgICBidWlsZGVyMi5mcm9tKHR4SGV4SGFsZlNpZ25lZCk7XG5cbiAgICBpZiAoIWtleXNbMV0ucHJpdmF0ZUtleSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBiYWNrdXBLZXkgaXMgbm90IGEgcHJpdmF0ZSBrZXlgKTtcbiAgICB9XG4gICAgY29uc3QgYmFja3VwS2V5ID0gY3JlYXRlU3RhY2tzUHJpdmF0ZUtleShrZXlzWzFdLnByaXZhdGVLZXkpO1xuICAgIGJ1aWxkZXIyLnNpZ24oeyBrZXk6IHByaXZhdGVLZXlUb1N0cmluZyhiYWNrdXBLZXkpIH0pO1xuXG4gICAgY29uc3QgZnVsbHlTaWduZWRUeCA9IGF3YWl0IGJ1aWxkZXIyLmJ1aWxkKCk7XG4gICAgY29uc3QgZnVsbHlTaWduZWRUeEhleCA9IGZ1bGx5U2lnbmVkVHgudG9Ccm9hZGNhc3RGb3JtYXQoKTtcblxuICAgIHJldHVybiB7XG4gICAgICB0eEhleDogZnVsbHlTaWduZWRUeEhleCxcbiAgICB9O1xuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICovXG4gIGF1ZGl0RGVjcnlwdGVkS2V5KHBhcmFtczogQXVkaXREZWNyeXB0ZWRLZXlQYXJhbXMpIHtcbiAgICB0aHJvdyBuZXcgTWV0aG9kTm90SW1wbGVtZW50ZWRFcnJvcigpO1xuICB9XG59XG4iXX0=