@bitgo-beta/sdk-coin-flrp 1.0.1-beta.35 → 1.0.1-beta.350

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 (119) hide show
  1. package/dist/src/flrp.d.ts +10 -17
  2. package/dist/src/flrp.d.ts.map +1 -1
  3. package/dist/src/flrp.js +51 -77
  4. package/dist/src/index.d.ts +0 -1
  5. package/dist/src/index.d.ts.map +1 -1
  6. package/dist/src/index.js +1 -2
  7. package/dist/src/lib/ExportInCTxBuilder.d.ts +51 -0
  8. package/dist/src/lib/ExportInCTxBuilder.d.ts.map +1 -0
  9. package/dist/src/lib/ExportInCTxBuilder.js +190 -0
  10. package/dist/src/lib/ExportInPTxBuilder.d.ts +47 -0
  11. package/dist/src/lib/ExportInPTxBuilder.d.ts.map +1 -0
  12. package/dist/src/lib/ExportInPTxBuilder.js +277 -0
  13. package/dist/src/lib/ImportInCTxBuilder.d.ts +63 -0
  14. package/dist/src/lib/ImportInCTxBuilder.d.ts.map +1 -0
  15. package/dist/src/lib/ImportInCTxBuilder.js +280 -0
  16. package/dist/src/lib/ImportInPTxBuilder.d.ts +33 -0
  17. package/dist/src/lib/ImportInPTxBuilder.d.ts.map +1 -0
  18. package/dist/src/lib/ImportInPTxBuilder.js +192 -0
  19. package/dist/src/lib/atomicInCTransactionBuilder.d.ts +18 -16
  20. package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +1 -1
  21. package/dist/src/lib/atomicInCTransactionBuilder.js +38 -36
  22. package/dist/src/lib/atomicTransactionBuilder.d.ts +57 -71
  23. package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
  24. package/dist/src/lib/atomicTransactionBuilder.js +246 -209
  25. package/dist/src/lib/iface.d.ts +38 -61
  26. package/dist/src/lib/iface.d.ts.map +1 -1
  27. package/dist/src/lib/iface.js +13 -14
  28. package/dist/src/lib/index.d.ts +5 -0
  29. package/dist/src/lib/index.d.ts.map +1 -1
  30. package/dist/src/lib/index.js +12 -2
  31. package/dist/src/lib/keyPair.d.ts +5 -5
  32. package/dist/src/lib/keyPair.d.ts.map +1 -1
  33. package/dist/src/lib/keyPair.js +17 -9
  34. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +43 -0
  35. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -0
  36. package/dist/src/lib/permissionlessValidatorTxBuilder.js +132 -0
  37. package/dist/src/lib/transaction.d.ts +25 -65
  38. package/dist/src/lib/transaction.d.ts.map +1 -1
  39. package/dist/src/lib/transaction.js +341 -199
  40. package/dist/src/lib/transactionBuilder.d.ts +107 -0
  41. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  42. package/dist/src/lib/transactionBuilder.js +210 -0
  43. package/dist/src/lib/transactionBuilderFactory.d.ts +50 -30
  44. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  45. package/dist/src/lib/transactionBuilderFactory.js +129 -72
  46. package/dist/src/lib/utils.d.ts +78 -147
  47. package/dist/src/lib/utils.d.ts.map +1 -1
  48. package/dist/src/lib/utils.js +238 -324
  49. package/dist/test/resources/account.d.ts +51 -0
  50. package/dist/test/resources/account.d.ts.map +1 -0
  51. package/dist/test/resources/account.js +54 -0
  52. package/dist/test/resources/transactionData/exportInC.d.ts +20 -0
  53. package/dist/test/resources/transactionData/exportInC.d.ts.map +1 -0
  54. package/dist/test/resources/transactionData/exportInC.js +39 -0
  55. package/dist/test/resources/transactionData/exportInP.d.ts +69 -0
  56. package/dist/test/resources/transactionData/exportInP.d.ts.map +1 -0
  57. package/dist/test/resources/transactionData/exportInP.js +140 -0
  58. package/dist/test/resources/transactionData/importInC.d.ts +27 -0
  59. package/dist/test/resources/transactionData/importInC.d.ts.map +1 -0
  60. package/dist/test/resources/transactionData/importInC.js +44 -0
  61. package/dist/test/resources/transactionData/importInP.d.ts +35 -0
  62. package/dist/test/resources/transactionData/importInP.d.ts.map +1 -0
  63. package/dist/test/resources/transactionData/importInP.js +58 -0
  64. package/dist/test/unit/flrp.js +446 -68
  65. package/dist/test/unit/lib/exportInCTxBuilder.d.ts +2 -0
  66. package/dist/test/unit/lib/exportInCTxBuilder.d.ts.map +1 -0
  67. package/dist/test/unit/lib/exportInCTxBuilder.js +192 -0
  68. package/dist/test/unit/lib/exportInPTxBuilder.d.ts +2 -0
  69. package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +1 -0
  70. package/dist/test/unit/lib/exportInPTxBuilder.js +325 -0
  71. package/dist/test/unit/lib/importInCTxBuilder.d.ts +2 -0
  72. package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +1 -0
  73. package/dist/test/unit/lib/importInCTxBuilder.js +307 -0
  74. package/dist/test/unit/lib/importInPTxBuilder.d.ts +2 -0
  75. package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +1 -0
  76. package/dist/test/unit/lib/importInPTxBuilder.js +307 -0
  77. package/dist/test/unit/lib/keyPair.d.ts +2 -0
  78. package/dist/test/unit/lib/keyPair.d.ts.map +1 -0
  79. package/dist/test/unit/lib/keyPair.js +158 -0
  80. package/dist/test/unit/lib/signFlowTestSuit.d.ts +20 -0
  81. package/dist/test/unit/lib/signFlowTestSuit.d.ts.map +1 -0
  82. package/dist/test/unit/lib/signFlowTestSuit.js +83 -0
  83. package/dist/test/unit/lib/transactionBuilderFactory.d.ts +2 -0
  84. package/dist/test/unit/lib/transactionBuilderFactory.d.ts.map +1 -0
  85. package/dist/test/unit/lib/transactionBuilderFactory.js +60 -0
  86. package/dist/test/unit/lib/utils.js +539 -207
  87. package/dist/tsconfig.tsbuildinfo +1 -1
  88. package/package.json +18 -10
  89. package/.eslintignore +0 -5
  90. package/.eslintrc.json +0 -7
  91. package/.mocharc.yml +0 -8
  92. package/CHANGELOG.md +0 -0
  93. package/dist/src/iface.d.ts +0 -25
  94. package/dist/src/iface.d.ts.map +0 -1
  95. package/dist/src/iface.js +0 -3
  96. package/dist/src/lib/constants.d.ts +0 -11
  97. package/dist/src/lib/constants.d.ts.map +0 -1
  98. package/dist/src/lib/constants.js +0 -17
  99. package/dist/src/lib/errors.d.ts +0 -8
  100. package/dist/src/lib/errors.d.ts.map +0 -1
  101. package/dist/src/lib/errors.js +0 -19
  102. package/dist/src/lib/exportInCTxBuilder.d.ts +0 -77
  103. package/dist/src/lib/exportInCTxBuilder.d.ts.map +0 -1
  104. package/dist/src/lib/exportInCTxBuilder.js +0 -170
  105. package/dist/src/lib/exportInPTxBuilder.d.ts +0 -30
  106. package/dist/src/lib/exportInPTxBuilder.d.ts.map +0 -1
  107. package/dist/src/lib/exportInPTxBuilder.js +0 -56
  108. package/dist/test/unit/lib/atomicTransactionBuilder.d.ts +0 -2
  109. package/dist/test/unit/lib/atomicTransactionBuilder.d.ts.map +0 -1
  110. package/dist/test/unit/lib/atomicTransactionBuilder.js +0 -222
  111. package/dist/test/unit/lib/exportTxBuilder.d.ts +0 -2
  112. package/dist/test/unit/lib/exportTxBuilder.d.ts.map +0 -1
  113. package/dist/test/unit/lib/exportTxBuilder.js +0 -45
  114. package/dist/test/unit/lib/transaction.d.ts +0 -2
  115. package/dist/test/unit/lib/transaction.d.ts.map +0 -1
  116. package/dist/test/unit/lib/transaction.js +0 -460
  117. package/dist/test/unit/smoke.d.ts +0 -2
  118. package/dist/test/unit/smoke.d.ts.map +0 -1
  119. package/dist/test/unit/smoke.js +0 -23
@@ -0,0 +1,307 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const assert_1 = __importDefault(require("assert"));
7
+ require("should");
8
+ const lib_1 = require("../../../src/lib");
9
+ const statics_1 = require("@bitgo-beta/statics");
10
+ const importInC_1 = require("../../resources/transactionData/importInC");
11
+ const signFlowTestSuit_1 = __importDefault(require("./signFlowTestSuit"));
12
+ const utils_1 = __importDefault(require("../../../src/lib/utils"));
13
+ describe('Flrp Import In C Tx Builder', () => {
14
+ const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp'));
15
+ describe('validate txBuilder fields', () => {
16
+ const txBuilder = factory.getImportInCBuilder();
17
+ it('should fail validate Utxos empty string', () => {
18
+ assert_1.default.throws(() => {
19
+ txBuilder.validateUtxos([]);
20
+ }, (e) => e.message === 'UTXOs array cannot be empty');
21
+ });
22
+ it('should fail validate Utxos without amount field', () => {
23
+ assert_1.default.throws(() => {
24
+ txBuilder.validateUtxos([{ outputID: '' }]);
25
+ }, (e) => e.message === 'UTXO missing required field: amount');
26
+ });
27
+ });
28
+ (0, signFlowTestSuit_1.default)({
29
+ transactionType: 'Import C2P',
30
+ newTxFactory: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp')),
31
+ newTxBuilder: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp'))
32
+ .getImportInCBuilder()
33
+ .threshold(importInC_1.IMPORT_IN_C.threshold)
34
+ .fromPubKey(importInC_1.IMPORT_IN_C.pAddresses)
35
+ .utxos(importInC_1.IMPORT_IN_C.outputs)
36
+ .to(importInC_1.IMPORT_IN_C.to)
37
+ .feeRate(importInC_1.IMPORT_IN_C.fee),
38
+ unsignedTxHex: importInC_1.IMPORT_IN_C.unsignedHex,
39
+ halfSignedTxHex: importInC_1.IMPORT_IN_C.halfSigntxHex,
40
+ fullSignedTxHex: importInC_1.IMPORT_IN_C.fullSigntxHex,
41
+ privateKey: {
42
+ prv1: importInC_1.IMPORT_IN_C.privateKeys[0],
43
+ prv2: importInC_1.IMPORT_IN_C.privateKeys[1],
44
+ },
45
+ txHash: importInC_1.IMPORT_IN_C.txhash,
46
+ });
47
+ describe('dynamic fee calculation', () => {
48
+ it('should calculate proper fee using feeRate multiplier (AVAXP approach) to avoid "insufficient unlocked funds" error', async () => {
49
+ const amount = '100000000'; // 100M nanoFLRP (0.1 FLR)
50
+ const feeRate = '1'; // 1 nanoFLRP per cost unit (matching AVAXP's feeRate usage)
51
+ const utxo = {
52
+ outputID: 0,
53
+ amount: amount,
54
+ txid: '2vPMx8P63adgBae7GAWFx7qvJDwRmMnDCyKddHRBXWhysjX4BP',
55
+ outputidx: '0',
56
+ addresses: [
57
+ '0x3329be7d01cd3ebaae6654d7327dd9f17a2e1581',
58
+ '0x7e918a5e8083ae4c9f2f0ed77055c24bf3665001',
59
+ '0xc7324437c96c7c8a6a152da2385c1db5c3ab1f91',
60
+ ],
61
+ threshold: 2,
62
+ };
63
+ const txBuilder = factory
64
+ .getImportInCBuilder()
65
+ .threshold(2)
66
+ .fromPubKey(importInC_1.IMPORT_IN_C.pAddresses)
67
+ .utxos([utxo])
68
+ .to(importInC_1.IMPORT_IN_C.to)
69
+ .feeRate(feeRate);
70
+ const tx = await txBuilder.build();
71
+ const calculatedFee = BigInt(tx.fee.fee);
72
+ const feeRateBigInt = BigInt(feeRate);
73
+ // The fee should be approximately: feeRate × (txSize + inputCost + fixedFee)
74
+ // For 1 input, threshold=2, ~228 bytes: 1 × (228 + 2000 + 10000) = 12,228
75
+ const expectedMinCost = 12000; // Minimum cost units (conservative estimate)
76
+ const expectedMaxCost = 13000; // Maximum cost units (with some buffer)
77
+ const expectedMinFee = feeRateBigInt * BigInt(expectedMinCost);
78
+ const expectedMaxFee = feeRateBigInt * BigInt(expectedMaxCost);
79
+ // Verify fee is in the expected range
80
+ (0, assert_1.default)(calculatedFee >= expectedMinFee, `Fee ${calculatedFee} should be at least ${expectedMinFee} (feeRate × minCost)`);
81
+ (0, assert_1.default)(calculatedFee <= expectedMaxFee, `Fee ${calculatedFee} should not exceed ${expectedMaxFee} (feeRate × maxCost)`);
82
+ // Verify the output amount is positive (no "insufficient funds" error)
83
+ const outputs = tx.outputs;
84
+ outputs.length.should.equal(1);
85
+ const outputAmount = BigInt(outputs[0].value);
86
+ (0, assert_1.default)(outputAmount > BigInt(0), 'Output amount should be positive - transaction should not fail with insufficient funds');
87
+ // Verify the math: input - output = fee
88
+ const inputAmount = BigInt(amount);
89
+ const calculatedOutput = inputAmount - calculatedFee;
90
+ (0, assert_1.default)(outputAmount === calculatedOutput, 'Output should equal input minus total fee');
91
+ });
92
+ });
93
+ describe('on-chain verified transactions', () => {
94
+ it('should verify on-chain tx id for signed C-chain import', async () => {
95
+ const signedImportHex = '0x0000000000000000007278db5c30bed04c05ce209179812850bbb3fe6d46d7eef3744d814c0da555247900000000000000000000000000000000000000000000000000000000000000000000000162ef0c8ced5668d1230c82e274f5c19357df8c005743367421e8a2b48c73989a0000000158734f94af871c3d131b56131b6fb7a0291eacadd261e69dfb42a9cdf6f7fddd000000050000000002faf0800000000200000000000000010000000117dbd11b9dd1c9be337353db7c14f9fb3662e5b50000000002aea54058734f94af871c3d131b56131b6fb7a0291eacadd261e69dfb42a9cdf6f7fddd000000010000000900000002ab32c15c75c763b24adf26eee85aa7d6a76b366e6b88e34b94f76baec91bae7336a32ed637fc232cccb2f772d3092eee66594070a2be92751148feffc76005b1013ee78fb11f3f9ffd90d970cd5c95e9dee611bb4feafaa0b0220cc641ef054c9f5701fde4fad2fe7f2594db9dafd858c62f9cf6fe6b58334d73da40a5a8412d4600';
96
+ const txBuilder = new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp')).from(signedImportHex);
97
+ const tx = await txBuilder.build();
98
+ const rawTx = tx.toBroadcastFormat();
99
+ rawTx.should.equal(signedImportHex);
100
+ tx.id.should.equal('2ks9vW1SVWD4KsNPHgXnV5dpJaCcaxVNbQW4H7t9BMDxApGvfa');
101
+ });
102
+ it('should FAIL with unsorted UTXO addresses - demonstrates AddressMap mismatch issue for import in C-chain tx', async () => {
103
+ // This test uses UTXO addresses in UNSORTED order to demonstrate the issue.
104
+ // With unsorted addresses, the current implementation will create AddressMaps incorrectly
105
+ // because it uses sequential indices, not UTXO address order.
106
+ //
107
+ // Expected: AddressMap should map addresses to signature slots based on UTXO order (addressesIndex)
108
+ // Current (WRONG): AddressMap uses sequential indices (0, 1, 2...)
109
+ //
110
+ // This test WILL FAIL with current implementation because AddressMaps don't match credential order
111
+ // UTXO addresses in UNSORTED order (different from sorted)
112
+ // Sorted would be: [0x3329... (smallest), 0x7e91... (middle), 0xc732... (largest)]
113
+ // Unsorted: [0xc732... (largest), 0x3329... (smallest), 0x7e91... (middle)]
114
+ const unsortedUtxoAddresses = [
115
+ '0xc7324437c96c7c8a6a152da2385c1db5c3ab1f91', // Largest (would be index 2 if sorted)
116
+ '0x3329be7d01cd3ebaae6654d7327dd9f17a2e1581', // Smallest (would be index 0 if sorted)
117
+ '0x7e918a5e8083ae4c9f2f0ed77055c24bf3665001', // Middle (would be index 1 if sorted)
118
+ ];
119
+ // Corresponding P-chain addresses (in same order as _fromAddresses)
120
+ const pAddresses = [
121
+ 'P-costwo1xv5mulgpe5lt4tnx2ntnylwe79azu9vpja6lut', // Maps to 0xc732... (UTXO index 0 in unsorted)
122
+ 'P-costwo106gc5h5qswhye8e0pmthq4wzf0ekv5qppsrvpu', // Maps to 0x3329... (UTXO index 1 in unsorted)
123
+ 'P-costwo1cueygd7fd37g56s49k3rshqakhp6k8u3adzt6m', // Maps to 0x7e91... (UTXO index 2 in unsorted)
124
+ ];
125
+ // Create UTXO with UNSORTED addresses
126
+ const amount = '500000000'; // 0.5 FLR
127
+ const fee = '5000000'; // Example fee
128
+ const utxoAmount = (BigInt(amount) + BigInt(fee) + BigInt('10000000')).toString(); // amount + fee + some buffer
129
+ const utxo = {
130
+ outputID: 0,
131
+ amount: utxoAmount,
132
+ txid: '2vPMx8P63adgBae7GAWFx7qvJDwRmMnDCyKddHRBXWhysjX4BP',
133
+ outputidx: '1',
134
+ addresses: unsortedUtxoAddresses, // UNSORTED order
135
+ threshold: 2,
136
+ };
137
+ // Build transaction
138
+ const txBuilder = factory
139
+ .getImportInCBuilder()
140
+ .threshold(2)
141
+ .fromPubKey(pAddresses)
142
+ .utxos([utxo])
143
+ .to(importInC_1.IMPORT_IN_C.to)
144
+ .feeRate(importInC_1.IMPORT_IN_C.fee);
145
+ // Build unsigned transaction
146
+ const unsignedTx = await txBuilder.build();
147
+ const unsignedHex = unsignedTx.toBroadcastFormat();
148
+ // Get AddressMaps from the ORIGINAL transaction (before parsing)
149
+ // The parsed transaction's AddressMap only contains the output address, not _fromAddresses
150
+ const originalFlareTx = unsignedTx._flareTransaction;
151
+ const originalAddressMaps = originalFlareTx.addressMaps;
152
+ // Parse it back to inspect AddressMaps and credentials
153
+ const parsedBuilder = factory.from(unsignedHex);
154
+ const parsedTx = await parsedBuilder.build();
155
+ const flareTx = parsedTx._flareTransaction;
156
+ // Get the input to check sigIndicies (for C-chain imports, inputs are importedInputs)
157
+ const importTx = flareTx.tx;
158
+ const input = importTx.importedInputs[0];
159
+ const sigIndicies = input.sigIndicies();
160
+ // sigIndicies tells us: sigIndicies[slotIndex] = utxoAddressIndex
161
+ // For threshold=2, we need signatures for first 2 addresses in UTXO order
162
+ // UTXO order: [0xc732... (index 0), 0x3329... (index 1), 0x7e91... (index 2)]
163
+ // So sigIndicies should be [0, 1] meaning: slot 0 = UTXO index 0, slot 1 = UTXO index 1
164
+ // Verify sigIndicies are [0, 1] (first 2 addresses in UTXO order, NOT sorted order)
165
+ sigIndicies.length.should.equal(2);
166
+ sigIndicies[0].should.equal(0, 'First signature slot should be UTXO address index 0 (0xc732...)');
167
+ sigIndicies[1].should.equal(1, 'Second signature slot should be UTXO address index 1 (0x3329...)');
168
+ // The critical test: Verify that signature slots have embedded addresses based on UTXO order
169
+ // With unsorted UTXO addresses, this will FAIL if AddressMaps don't match UTXO order
170
+ //
171
+ // Parse the credential to see which slots have which embedded addresses
172
+ const credential = flareTx.credentials[0];
173
+ const signatures = credential.getSignatures();
174
+ // Extract embedded addresses from signature slots
175
+ const embeddedAddresses = [];
176
+ const isEmptySignature = (signature) => {
177
+ return !!signature && utils_1.default.removeHexPrefix(signature).startsWith('0'.repeat(90));
178
+ };
179
+ const hasEmbeddedAddress = (signature) => {
180
+ if (!isEmptySignature(signature))
181
+ return false;
182
+ const cleanSig = utils_1.default.removeHexPrefix(signature);
183
+ if (cleanSig.length < 130)
184
+ return false;
185
+ const embeddedPart = cleanSig.substring(90, 130);
186
+ // Check if embedded part is not all zeros
187
+ return embeddedPart !== '0'.repeat(40);
188
+ };
189
+ signatures.forEach((sig, slotIndex) => {
190
+ if (hasEmbeddedAddress(sig)) {
191
+ // Extract embedded address (after position 90, 40 chars = 20 bytes)
192
+ const cleanSig = utils_1.default.removeHexPrefix(sig);
193
+ const embeddedAddr = cleanSig.substring(90, 130).toLowerCase();
194
+ embeddedAddresses[slotIndex] = '0x' + embeddedAddr;
195
+ }
196
+ });
197
+ // Verify: Credentials only embed ONE address (user/recovery), not both
198
+ // The embedded address should be based on addressesIndex logic, not sequential order
199
+ //
200
+ // Compute addressesIndex to determine expected signature order
201
+ const utxoAddressBytes = unsortedUtxoAddresses.map((addr) => utils_1.default.parseAddress(addr));
202
+ const pAddressBytes = pAddresses.map((addr) => utils_1.default.parseAddress(addr));
203
+ const addressesIndex = [];
204
+ pAddressBytes.forEach((pAddr) => {
205
+ const utxoIndex = utxoAddressBytes.findIndex((uAddr) => Buffer.compare(Buffer.from(uAddr), Buffer.from(pAddr)) === 0);
206
+ addressesIndex.push(utxoIndex);
207
+ });
208
+ // firstIndex = 0 (user), bitgoIndex = 1
209
+ const firstIndex = 0;
210
+ const bitgoIndex = 1;
211
+ // Determine expected signature order based on addressesIndex
212
+ const userComesFirst = addressesIndex[bitgoIndex] > addressesIndex[firstIndex];
213
+ // Expected credential structure:
214
+ // - If user comes first: [userAddress, zeros]
215
+ // - If bitgo comes first: [zeros, userAddress]
216
+ const userAddressHex = Buffer.from(pAddressBytes[firstIndex]).toString('hex').toLowerCase();
217
+ const expectedUserAddr = '0x' + userAddressHex;
218
+ if (userComesFirst) {
219
+ // Expected: [userAddress, zeros]
220
+ // Slot 0 should have user address (pAddr0 = 0xc732... = UTXO index 0)
221
+ if (embeddedAddresses[0]) {
222
+ embeddedAddresses[0]
223
+ .toLowerCase()
224
+ .should.equal(expectedUserAddr, `Slot 0 should have user address (${expectedUserAddr}) because user comes first in UTXO order`);
225
+ }
226
+ else {
227
+ throw new Error(`Slot 0 should have embedded user address, but is empty`);
228
+ }
229
+ // Slot 1 should be zeros (no embedded address)
230
+ if (embeddedAddresses[1]) {
231
+ throw new Error(`Slot 1 should be zeros, but has embedded address: ${embeddedAddresses[1]}`);
232
+ }
233
+ }
234
+ else {
235
+ // Expected: [zeros, userAddress]
236
+ // Slot 0 should be zeros
237
+ if (embeddedAddresses[0]) {
238
+ throw new Error(`Slot 0 should be zeros, but has embedded address: ${embeddedAddresses[0]}`);
239
+ }
240
+ // Slot 1 should have user address
241
+ if (embeddedAddresses[1]) {
242
+ embeddedAddresses[1]
243
+ .toLowerCase()
244
+ .should.equal(expectedUserAddr, `Slot 1 should have user address (${expectedUserAddr}) because bitgo comes first in UTXO order`);
245
+ }
246
+ else {
247
+ throw new Error(`Slot 1 should have embedded user address, but is empty`);
248
+ }
249
+ }
250
+ // The key verification: AddressMaps should match the credential order
251
+ // Current implementation (WRONG): AddressMaps use sequential indices (0, 1, 2...)
252
+ // Expected (CORRECT): AddressMaps should use addressesIndex logic, matching credential order
253
+ //
254
+ // Get AddressMaps from the ORIGINAL transaction (not parsed, because parsed AddressMap only has output address)
255
+ // For C-chain imports, originalFlareTx is EVMUnsignedTx which has addressMaps property
256
+ const addressMaps = originalAddressMaps;
257
+ addressMaps.toArray().length.should.equal(1, 'Should have one AddressMap for one input');
258
+ const addressMap = addressMaps.toArray()[0];
259
+ // Expected: Based on addressesIndex logic
260
+ // If user comes first: slot 0 = user, slot 1 = bitgo
261
+ // If bitgo comes first: slot 0 = bitgo, slot 1 = user
262
+ const expectedSlot0Addr = userComesFirst ? pAddressBytes[firstIndex] : pAddressBytes[bitgoIndex];
263
+ const expectedSlot1Addr = userComesFirst ? pAddressBytes[bitgoIndex] : pAddressBytes[firstIndex];
264
+ // AddressMap maps: Address -> slot index
265
+ // We need to check which addresses are mapped to slots 0 and 1
266
+ // AddressMap.get() returns the slot index for a given address
267
+ // Verify that AddressMap correctly maps addresses based on credential order (UTXO order)
268
+ // The AddressMap should map the addresses that appear in credentials to the correct slots
269
+ const { Address } = require('@flarenetwork/flarejs');
270
+ const expectedSlot0Address = new Address(expectedSlot0Addr);
271
+ const expectedSlot1Address = new Address(expectedSlot1Addr);
272
+ const expectedSlot0FromMap = addressMap.get(expectedSlot0Address);
273
+ const expectedSlot1FromMap = addressMap.get(expectedSlot1Address);
274
+ // Verify that the expected addresses map to the correct slots
275
+ if (expectedSlot0FromMap === undefined) {
276
+ throw new Error(`Address at UTXO index ${addressesIndex[firstIndex]} not found in AddressMap`);
277
+ }
278
+ if (expectedSlot1FromMap === undefined) {
279
+ throw new Error(`Address at UTXO index ${addressesIndex[bitgoIndex]} not found in AddressMap`);
280
+ }
281
+ expectedSlot0FromMap.should.equal(0, `Address at UTXO index ${addressesIndex[firstIndex]} should map to slot 0`);
282
+ expectedSlot1FromMap.should.equal(1, `Address at UTXO index ${addressesIndex[bitgoIndex]} should map to slot 1`);
283
+ // If addressesIndex is not sequential ([0, 1, ...]), verify that sequential mapping is NOT used incorrectly
284
+ // Sequential mapping means: pAddresses[0] -> slot 0, pAddresses[1] -> slot 1, regardless of UTXO order
285
+ const usesSequentialMapping = addressesIndex[0] === 0 && addressesIndex[1] === 1;
286
+ if (!usesSequentialMapping) {
287
+ // Check if AddressMap uses sequential mapping (array order) instead of UTXO order
288
+ const sequentialSlot0 = addressMap.get(new Address(pAddressBytes[0]));
289
+ const sequentialSlot1 = addressMap.get(new Address(pAddressBytes[1]));
290
+ // Sequential mapping would map pAddresses[0] -> slot 0, pAddresses[1] -> slot 1
291
+ // But we want UTXO order mapping based on addressesIndex
292
+ const isSequential = sequentialSlot0 === 0 && sequentialSlot1 === 1;
293
+ // Check if pAddresses[0] and pAddresses[1] are the expected addresses for slots 0 and 1
294
+ // If they are, then sequential mapping happens to be correct (by coincidence)
295
+ const pAddress0IsExpectedSlot0 = Buffer.compare(Buffer.from(pAddressBytes[0]), Buffer.from(expectedSlot0Addr)) === 0;
296
+ const pAddress1IsExpectedSlot1 = Buffer.compare(Buffer.from(pAddressBytes[1]), Buffer.from(expectedSlot1Addr)) === 0;
297
+ // If sequential mapping is used but it's NOT correct (doesn't match expected addresses), fail
298
+ if (isSequential && (!pAddress0IsExpectedSlot0 || !pAddress1IsExpectedSlot1)) {
299
+ throw new Error(`AddressMap uses sequential mapping (array order) but should use UTXO order. ` +
300
+ `addressesIndex: [${addressesIndex.join(', ')}]. ` +
301
+ `Expected slot 0 = address at UTXO index ${addressesIndex[firstIndex]}, slot 1 = address at UTXO index ${addressesIndex[bitgoIndex]}`);
302
+ }
303
+ }
304
+ });
305
+ });
306
+ });
307
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1wb3J0SW5DVHhCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdGVzdC91bml0L2xpYi9pbXBvcnRJbkNUeEJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxvREFBNEI7QUFDNUIsa0JBQWdCO0FBQ2hCLDBDQUE2RTtBQUM3RSxpREFBNEM7QUFDNUMseUVBQW9GO0FBQ3BGLDBFQUE4QztBQUU5QyxtRUFBK0M7QUFFL0MsUUFBUSxDQUFDLDZCQUE2QixFQUFFLEdBQUcsRUFBRTtJQUMzQyxNQUFNLE9BQU8sR0FBRyxJQUFJLCtCQUF5QixDQUFDLGVBQUssQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNsRSxRQUFRLENBQUMsMkJBQTJCLEVBQUUsR0FBRyxFQUFFO1FBQ3pDLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBRWhELEVBQUUsQ0FBQyx5Q0FBeUMsRUFBRSxHQUFHLEVBQUU7WUFDakQsZ0JBQU0sQ0FBQyxNQUFNLENBQ1gsR0FBRyxFQUFFO2dCQUNILFNBQVMsQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDOUIsQ0FBQyxFQUNELENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxLQUFLLDZCQUE2QixDQUN4RCxDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7UUFFSCxFQUFFLENBQUMsaURBQWlELEVBQUUsR0FBRyxFQUFFO1lBQ3pELGdCQUFNLENBQUMsTUFBTSxDQUNYLEdBQUcsRUFBRTtnQkFDSCxTQUFTLENBQUMsYUFBYSxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUEyQixDQUFDLENBQUMsQ0FBQztZQUN2RSxDQUFDLEVBQ0QsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLEtBQUsscUNBQXFDLENBQ2hFLENBQUM7UUFDSixDQUFDLENBQUMsQ0FB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Y2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgJ3Nob3VsZCc7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5LCBEZWNvZGVkVXR4b09iaiB9IGZyb20gJy4uLy4uLy4uL3NyYy9saWInO1xuaW1wb3J0IHsgY29pbnMgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7IElNUE9SVF9JTl9DIGFzIHRlc3REYXRhIH0gZnJvbSAnLi4vLi4vcmVzb3VyY2VzL3RyYW5zYWN0aW9uRGF0YS9pbXBvcnRJbkMnO1xuaW1wb3J0IHNpZ25GbG93VGVzdCBmcm9tICcuL3NpZ25GbG93VGVzdFN1aXQnO1xuaW1wb3J0IHsgVW5zaWduZWRUeCB9IGZyb20gJ0BmbGFyZW5ldHdvcmsvZmxhcmVqcyc7XG5pbXBvcnQgdGVzdFV0aWxzIGZyb20gJy4uLy4uLy4uL3NyYy9saWIvdXRpbHMnO1xuXG5kZXNjcmliZSgnRmxycCBJbXBvcnQgSW4gQyBUeCBCdWlsZGVyJywgKCkgPT4ge1xuICBjb25zdCBmYWN0b3J5ID0gbmV3IFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkoY29pbnMuZ2V0KCd0ZmxycCcpKTtcbiAgZGVzY3JpYmUoJ3ZhbGlkYXRlIHR4QnVpbGRlciBmaWVsZHMnLCAoKSA9PiB7XG4gICAgY29uc3QgdHhCdWlsZGVyID0gZmFjdG9yeS5nZXRJbXBvcnRJbkNCdWlsZGVyKCk7XG5cbiAgICBpdCgnc2hvdWxkIGZhaWwgdmFsaWRhdGUgVXR4b3MgZW1wdHkgc3RyaW5nJywgKCkgPT4ge1xuICAgICAgYXNzZXJ0LnRocm93cyhcbiAgICAgICAgKCkgPT4ge1xuICAgICAgICAgIHR4QnVpbGRlci52YWxpZGF0ZVV0eG9zKFtdKTtcbiAgICAgICAgfSxcbiAgICAgICAgKGU6IGFueSkgPT4gZS5tZXNzYWdlID09PSAnVVRYT3MgYXJyYXkgY2Fubm90IGJlIGVtcHR5J1xuICAgICAgKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgZmFpbCB2YWxpZGF0ZSBVdHhvcyB3aXRob3V0IGFtb3VudCBmaWVsZCcsICgpID0+IHtcbiAgICAgIGFzc2VydC50aHJvd3MoXG4gICAgICAgICgpID0+IHtcbiAgICAgICAgICB0eEJ1aWxkZXIudmFsaWRhdGVVdHhvcyhbeyBvdXRwdXRJRDogJycgfSBhcyBhbnkgYXMgRGVjb2RlZFV0eG9PYmpdKTtcbiAgICAgICAgfSxcbiAgICAgICAgKGU6IGFueSkgPT4gZS5tZXNzYWdlID09PSAnVVRYTyBtaXNzaW5nIHJlcXVpcmVkIGZpZWxkOiBhbW91bnQnXG4gICAgICApO1xuICAgIH0pO1xuICB9KTtcblxuICBzaWduRmxvd1Rlc3Qoe1xuICAgIHRyYW5zYWN0aW9uVHlwZTogJ0ltcG9ydCBDMlAnLFxuICAgIG5ld1R4RmFjdG9yeTogKCkgPT4gbmV3IFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkoY29pbnMuZ2V0KCd0ZmxycCcpKSxcbiAgICBuZXdUeEJ1aWxkZXI6ICgpID0+XG4gICAgICBuZXcgVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeShjb2lucy5nZXQoJ3RmbHJwJykpXG4gICAgICAgIC5nZXRJbXBvcnRJbkNCdWlsZGVyKClcbiAgICAgICAgLnRocmVzaG9sZCh0ZXN0RGF0YS50aHJlc2hvbGQpXG4gICAgICAgIC5mcm9tUHViS2V5KHRlc3REYXRhLnBBZGRyZXNzZXMpXG4gICAgICAgIC51dHhvcyh0ZXN0RGF0YS5vdXRwdXRzKVxuICAgICAgICAudG8odGVzdERhdGEudG8pXG4gICAgICAgIC5mZWVSYXRlKHRlc3REYXRhLmZlZSksXG4gICAgdW5zaWduZWRUeEhleDogdGVzdERhdGEudW5zaWduZWRIZXgsXG4gICAgaGFsZlNpZ25lZFR4SGV4OiB0ZXN0RGF0YS5oYWxmU2lnbnR4SGV4LFxuICAgIGZ1bGxTaWduZWRUeEhleDogdGVzdERhdGEuZnVsbFNpZ250eEhleCxcbiAgICBwcml2YXRlS2V5OiB7XG4gICAgICBwcnYxOiB0ZXN0RGF0YS5wcml2YXRlS2V5c1swXSxcbiAgICAgIHBydjI6IHRlc3REYXRhLnByaXZhdGVLZXlzWzFdLFxuICAgIH0sXG4gICAgdHhIYXNoOiB0ZXN0RGF0YS50eGhhc2gsXG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdkeW5hbWljIGZlZSBjYWxjdWxhdGlvbicsICgpID0+IHtcbiAgICBpdCgnc2hvdWxkIGNhbGN1bGF0ZSBwcm9wZXIgZmVlIHVzaW5nIGZlZVJhdGUgbXVsdGlwbGllciAoQVZBWFAgYXBwcm9hY2gpIHRvIGF2b2lkIFwiaW5zdWZmaWNpZW50IHVubG9ja2VkIGZ1bmRzXCIgZXJyb3InLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCBhbW91bnQgPSAnMTAwMDAwMDAwJzsgLy8gMTAwTSBuYW5vRkxSUCAoMC4xIEZMUilcbiAgICAgIGNvbnN0IGZlZVJhdGUgPSAnMSc7IC8vIDEgbmFub0ZMUlAgcGVyIGNvc3QgdW5pdCAobWF0Y2hpbmcgQVZBWFAncyBmZWVSYXRlIHVzYWdlKVxuXG4gICAgICBjb25zdCB1dHhvOiBEZWNvZGVkVXR4b09iaiA9IHtcbiAgICAgICAgb3V0cHV0SUQ6IDAsXG4gICAgICAgIGFtb3VudDogYW1vdW50LFxuICAgICAgICB0eGlkOiAnMnZQTXg4UDYzYWRnQmFlN0dBV0Z4N3F2SkR3Um1NbkRDeUtkZEhSQlhXaHlzalg0QlAnLFxuICAgICAgICBvdXRwdXRpZHg6ICcwJyxcbiAgICAgICAgYWRkcmVzc2VzOiBbXG4gICAgICAgICAgJzB4MzMyOWJlN2QwMWNkM2ViYWFlNjY1NGQ3MzI3ZGQ5ZjE3YTJlMTU4MScsXG4gICAgICAgICAgJzB4N2U5MThhNWU4MDgzYWU0YzlmMmYwZWQ3NzA1NWMyNGJmMzY2NTAwMScsXG4gICAgICAgICAgJzB4YzczMjQ0MzdjOTZjN2M4YTZhMTUyZGEyMzg1YzFkYjVjM2FiMWY5MScsXG4gICAgICAgIF0sXG4gICAgICAgIHRocmVzaG9sZDogMixcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IHR4QnVpbGRlciA9IGZhY3RvcnlcbiAgICAgICAgLmdldEltcG9ydEluQ0J1aWxkZXIoKVxuICAgICAgICAudGhyZXNob2xkKDIpXG4gICAgICAgIC5mcm9tUHViS2V5KHRlc3REYXRhLnBBZGRyZXNzZXMpXG4gICAgICAgIC51dHhvcyhbdXR4b10pXG4gICAgICAgIC50byh0ZXN0RGF0YS50bylcbiAgICAgICAgLmZlZVJhdGUoZmVlUmF0ZSkgYXMgYW55O1xuXG4gICAgICBjb25zdCB0eCA9IGF3YWl0IHR4QnVpbGRlci5idWlsZCgpO1xuXG4gICAgICBjb25zdCBjYWxjdWxhdGVkRmVlID0gQmlnSW50KCh0eCBhcyBhbnkpLmZlZS5mZWUpO1xuICAgICAgY29uc3QgZmVlUmF0ZUJpZ0ludCA9IEJpZ0ludChmZWVSYXRlKTtcblxuICAgICAgLy8gVGhlIGZlZSBzaG91bGQgYmUgYXBwcm94aW1hdGVseTogZmVlUmF0ZSDDlyAodHhTaXplICsgaW5wdXRDb3N0ICsgZml4ZWRGZWUpXG4gICAgICAvLyBGb3IgMSBpbnB1dCwgdGhyZXNob2xkPTIsIH4yMjggYnl0ZXM6IDEgw5cgKDIyOCArIDIwMDAgKyAxMDAwMCkgPSAxMiwyMjhcbiAgICAgIGNvbnN0IGV4cGVjdGVkTWluQ29zdCA9IDEyMDAwOyAvLyBNaW5pbXVtIGNvc3QgdW5pdHMgKGNvbnNlcnZhdGl2ZSBlc3RpbWF0ZSlcbiAgICAgIGNvbnN0IGV4cGVjdGVkTWF4Q29zdCA9IDEzMDAwOyAvLyBNYXhpbXVtIGNvc3QgdW5pdHMgKHdpdGggc29tZSBidWZmZXIpXG5cbiAgICAgIGNvbnN0IGV4cGVjdGVkTWluRmVlID0gZmVlUmF0ZUJpZ0ludCAqIEJpZ0ludChleHBlY3RlZE1pbkNvc3QpO1xuICAgICAgY29uc3QgZXhwZWN0ZWRNYXhGZWUgPSBmZWVSYXRlQmlnSW50ICogQmlnSW50KGV4cGVjdGVkTWF4Q29zdCk7XG5cbiAgICAgIC8vIFZlcmlmeSBmZWUgaXMgaW4gdGhlIGV4cGVjdGVkIHJhbmdlXG4gICAgICBhc3NlcnQoXG4gICAgICAgIGNhbGN1bGF0ZWRGZWUgPj0gZXhwZWN0ZWRNaW5GZWUsXG4gICAgICAgIGBGZWUgJHtjYWxjdWxhdGVkRmVlfSBzaG91bGQgYmUgYXQgbGVhc3QgJHtleHBlY3RlZE1pbkZlZX0gKGZlZVJhdGUgw5cgbWluQ29zdClgXG4gICAgICApO1xuICAgICAgYXNzZXJ0KFxuICAgICAgICBjYWxjdWxhdGVkRmVlIDw9IGV4cGVjdGVkTWF4RmVlLFxuICAgICAgICBgRmVlICR7Y2FsY3VsYXRlZEZlZX0gc2hvdWxkIG5vdCBleGNlZWQgJHtleHBlY3RlZE1heEZlZX0gKGZlZVJhdGUgw5cgbWF4Q29zdClgXG4gICAgICApO1xuXG4gICAgICAvLyBWZXJpZnkgdGhlIG91dHB1dCBhbW91bnQgaXMgcG9zaXRpdmUgKG5vIFwiaW5zdWZmaWNpZW50IGZ1bmRzXCIgZXJyb3IpXG4gICAgICBjb25zdCBvdXRwdXRzID0gdHgub3V0cHV0cztcbiAgICAgIG91dHB1dHMubGVuZ3RoLnNob3VsZC5lcXVhbCgxKTtcbiAgICAgIGNvbnN0IG91dHB1dEFtb3VudCA9IEJpZ0ludChvdXRwdXRzWzBdLnZhbHVlKTtcbiAgICAgIGFzc2VydChcbiAgICAgICAgb3V0cHV0QW1vdW50ID4gQmlnSW50KDApLFxuICAgICAgICAnT3V0cHV0IGFtb3VudCBzaG91bGQgYmUgcG9zaXRpdmUgLSB0cmFuc2FjdGlvbiBzaG91bGQgbm90IGZhaWwgd2l0aCBpbnN1ZmZpY2llbnQgZnVuZHMnXG4gICAgICApO1xuXG4gICAgICAvLyBWZXJpZnkgdGhlIG1hdGg6IGlucHV0IC0gb3V0cHV0ID0gZmVlXG4gICAgICBjb25zdCBpbnB1dEFtb3VudCA9IEJpZ0ludChhbW91bnQpO1xuICAgICAgY29uc3QgY2FsY3VsYXRlZE91dHB1dCA9IGlucHV0QW1vdW50IC0gY2FsY3VsYXRlZEZlZTtcbiAgICAgIGFzc2VydChvdXRwdXRBbW91bnQgPT09IGNhbGN1bGF0ZWRPdXRwdXQsICdPdXRwdXQgc2hvdWxkIGVxdWFsIGlucHV0IG1pbnVzIHRvdGFsIGZlZScpO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZSgnb24tY2hhaW4gdmVyaWZpZWQgdHJhbnNhY3Rpb25zJywgKCkgPT4ge1xuICAgIGl0KCdzaG91bGQgdmVyaWZ5IG9uLWNoYWluIHR4IGlkIGZvciBzaWduZWQgQy1jaGFpbiBpbXBvcnQnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCBzaWduZWRJbXBvcnRIZXggPVxuICAgICAgICAnMHgwMDAwMDAwMDAwMDAwMDAwMDA3Mjc4ZGI1YzMwYmVkMDRjMDVjZTIwOTE3OTgxMjg1MGJiYjNmZTZkNDZkN2VlZjM3NDRkODE0YzBkYTU1NTI0NzkwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE2MmVmMGM4Y2VkNTY2OGQxMjMwYzgyZTI3NGY1YzE5MzU3ZGY4YzAwNTc0MzM2NzQyMWU4YTJiNDhjNzM5ODlhMDAwMDAwMDE1ODczNGY5NGFmODcxYzNkMTMxYjU2MTMxYjZmYjdhMDI5MWVhY2FkZDI2MWU2OWRmYjQyYTljZGY2ZjdmZGRkMDAwMDAwMDUwMDAwMDAwMDAyZmFmMDgwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDExN2RiZDExYjlkZDFjOWJlMzM3MzUzZGI3YzE0ZjlmYjM2NjJlNWI1MDAwMDAwMDAwMmFlYTU0MDU4NzM0Zjk0YWY4NzFjM2QxMzFiNTYxMzFiNmZiN2EwMjkxZWFjYWRkMjYxZTY5ZGZiNDJhOWNkZjZmN2ZkZGQwMDAwMDAwMTAwMDAwMDA5MDAwMDAwMDJhYjMyYzE1Yzc1Yzc2M2IyNGFkZjI2ZWVlODVhYTdkNmE3NmIzNjZlNmI4OGUzNGI5NGY3NmJhZWM5MWJhZTczMzZhMzJlZDYzN2ZjMjMyY2NjYjJmNzcyZDMwOTJlZWU2NjU5NDA3MGEyYmU5Mjc1MTE0OGZlZmZjNzYwMDViMTAxM2VlNzhmYjExZjNmOWZmZDkwZDk3MGNkNWM5NWU5ZGVlNjExYmI0ZmVhZmFhMGIwMjIwY2M2NDFlZjA1NGM5ZjU3MDFmZGU0ZmFkMmZlN2YyNTk0ZGI5ZGFmZDg1OGM2MmY5Y2Y2ZmU2YjU4MzM0ZDczZGE0MGE1YTg0MTJkNDYwMCc7XG4gICAgICBjb25zdCB0eEJ1aWxkZXIgPSBuZXcgVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeShjb2lucy5nZXQoJ3RmbHJwJykpLmZyb20oc2lnbmVkSW1wb3J0SGV4KTtcbiAgICAgIGNvbnN0IHR4ID0gYXdhaXQgdHhCdWlsZGVyLmJ1aWxkKCk7XG4gICAgICBjb25zdCByYXdUeCA9IHR4LnRvQnJvYWRjYXN0Rm9ybWF0KCk7XG4gICAgICByYXdUeC5zaG91bGQuZXF1YWwoc2lnbmVkSW1wb3J0SGV4KTtcbiAgICAgIHR4LmlkLnNob3VsZC5lcXVhbCgnMmtzOXZXMVNWV0Q0S3NOUEhnWG5WNWRwSmFDY2F4Vk5iUVc0SDd0OUJNRHhBcEd2ZmEnKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgRkFJTCB3aXRoIHVuc29ydGVkIFVUWE8gYWRkcmVzc2VzIC0gZGVtb25zdHJhdGVzIEFkZHJlc3NNYXAgbWlzbWF0Y2ggaXNzdWUgZm9yIGltcG9ydCBpbiBDLWNoYWluIHR4JywgYXN5bmMgKCkgPT4ge1xuICAgICAgLy8gVGhpcyB0ZXN0IHVzZXMgVVRYTyBhZGRyZXNzZXMgaW4gVU5TT1JURUQgb3JkZXIgdG8gZGVtb25zdHJhdGUgdGhlIGlzc3VlLlxuICAgICAgLy8gV2l0aCB1bnNvcnRlZCBhZGRyZXNzZXMsIHRoZSBjdXJyZW50IGltcGxlbWVudGF0aW9uIHdpbGwgY3JlYXRlIEFkZHJlc3NNYXBzIGluY29ycmVjdGx5XG4gICAgICAvLyBiZWNhdXNlIGl0IHVzZXMgc2VxdWVudGlhbCBpbmRpY2VzLCBub3QgVVRYTyBhZGRyZXNzIG9yZGVyLlxuICAgICAgLy9cbiAgICAgIC8vIEV4cGVjdGVkOiBBZGRyZXNzTWFwIHNob3VsZCBtYXAgYWRkcmVzc2VzIHRvIHNpZ25hdHVyZSBzbG90cyBiYXNlZCBvbiBVVFhPIG9yZGVyIChhZGRyZXNzZXNJbmRleClcbiAgICAgIC8vIEN1cnJlbnQgKFdST05HKTogQWRkcmVzc01hcCB1c2VzIHNlcXVlbnRpYWwgaW5kaWNlcyAoMCwgMSwgMi4uLilcbiAgICAgIC8vXG4gICAgICAvLyBUaGlzIHRlc3QgV0lMTCBGQUlMIHdpdGggY3VycmVudCBpbXBsZW1lbnRhdGlvbiBiZWNhdXNlIEFkZHJlc3NNYXBzIGRvbid0IG1hdGNoIGNyZWRlbnRpYWwgb3JkZXJcblxuICAgICAgLy8gVVRYTyBhZGRyZXNzZXMgaW4gVU5TT1JURUQgb3JkZXIgKGRpZmZlcmVudCBmcm9tIHNvcnRlZClcbiAgICAgIC8vIFNvcnRlZCB3b3VsZCBiZTogWzB4MzMyOS4uLiAoc21hbGxlc3QpLCAweDdlOTEuLi4gKG1pZGRsZSksIDB4YzczMi4uLiAobGFyZ2VzdCldXG4gICAgICAvLyBVbnNvcnRlZDogWzB4YzczMi4uLiAobGFyZ2VzdCksIDB4MzMyOS4uLiAoc21hbGxlc3QpLCAweDdlOTEuLi4gKG1pZGRsZSldXG4gICAgICBjb25zdCB1bnNvcnRlZFV0eG9BZGRyZXNzZXMgPSBbXG4gICAgICAgICcweGM3MzI0NDM3Yzk2YzdjOGE2YTE1MmRhMjM4NWMxZGI1YzNhYjFmOTEnLCAvLyBMYXJnZXN0ICh3b3VsZCBiZSBpbmRleCAyIGlmIHNvcnRlZClcbiAgICAgICAgJzB4MzMyOWJlN2QwMWNkM2ViYWFlNjY1NGQ3MzI3ZGQ5ZjE3YTJlMTU4MScsIC8vIFNtYWxsZXN0ICh3b3VsZCBiZSBpbmRleCAwIGlmIHNvcnRlZClcbiAgICAgICAgJzB4N2U5MThhNWU4MDgzYWU0YzlmMmYwZWQ3NzA1NWMyNGJmMzY2NTAwMScsIC8vIE1pZGRsZSAod291bGQgYmUgaW5kZXggMSBpZiBzb3J0ZWQpXG4gICAgICBdO1xuXG4gICAgICAvLyBDb3JyZXNwb25kaW5nIFAtY2hhaW4gYWRkcmVzc2VzIChpbiBzYW1lIG9yZGVyIGFzIF9mcm9tQWRkcmVzc2VzKVxuICAgICAgY29uc3QgcEFkZHJlc3NlcyA9IFtcbiAgICAgICAgJ1AtY29zdHdvMXh2NW11bGdwZTVsdDR0bngybnRueWx3ZTc5YXp1OXZwamE2bHV0JywgLy8gTWFwcyB0byAweGM3MzIuLi4gKFVUWE8gaW5kZXggMCBpbiB1bnNvcnRlZClcbiAgICAgICAgJ1AtY29zdHdvMTA2Z2M1aDVxc3doeWU4ZTBwbXRocTR3emYwZWt2NXFwcHNydnB1JywgLy8gTWFwcyB0byAweDMzMjkuLi4gKFVUWE8gaW5kZXggMSBpbiB1bnNvcnRlZClcbiAgICAgICAgJ1AtY29zdHdvMWN1ZXlnZDdmZDM3ZzU2czQ5azNyc2hxYWtocDZrOHUzYWR6dDZtJywgLy8gTWFwcyB0byAweDdlOTEuLi4gKFVUWE8gaW5kZXggMiBpbiB1bnNvcnRlZClcbiAgICAgIF07XG5cbiAgICAgIC8vIENyZWF0ZSBVVFhPIHdpdGggVU5TT1JURUQgYWRkcmVzc2VzXG4gICAgICBjb25zdCBhbW91bnQgPSAnNTAwMDAwMDAwJzsgLy8gMC41IEZMUlxuICAgICAgY29uc3QgZmVlID0gJzUwMDAwMDAnOyAvLyBFeGFtcGxlIGZlZVxuICAgICAgY29uc3QgdXR4b0Ftb3VudCA9IChCaWdJbnQoYW1vdW50KSArIEJpZ0ludChmZWUpICsgQmlnSW50KCcxMDAwMDAwMCcpKS50b1N0cmluZygpOyAvLyBhbW91bnQgKyBmZWUgKyBzb21lIGJ1ZmZlclxuXG4gICAgICBjb25zdCB1dHhvOiBEZWNvZGVkVXR4b09iaiA9IHtcbiAgICAgICAgb3V0cHV0SUQ6IDAsXG4gICAgICAgIGFtb3VudDogdXR4b0Ftb3VudCxcbiAgICAgICAgdHhpZDogJzJ2UE14OFA2M2FkZ0JhZTdHQVdGeDdxdkpEd1JtTW5EQ3lLZGRIUkJYV2h5c2pYNEJQJyxcbiAgICAgICAgb3V0cHV0aWR4OiAnMScsXG4gICAgICAgIGFkZHJlc3NlczogdW5zb3J0ZWRVdHhvQWRkcmVzc2VzLCAvLyBVTlNPUlRFRCBvcmRlclxuICAgICAgICB0aHJlc2hvbGQ6IDIsXG4gICAgICB9O1xuXG4gICAgICAvLyBCdWlsZCB0cmFuc2FjdGlvblxuICAgICAgY29uc3QgdHhCdWlsZGVyID0gZmFjdG9yeVxuICAgICAgICAuZ2V0SW1wb3J0SW5DQnVpbGRlcigpXG4gICAgICAgIC50aHJlc2hvbGQoMilcbiAgICAgICAgLmZyb21QdWJLZXkocEFkZHJlc3NlcylcbiAgICAgICAgLnV0eG9zKFt1dHhvXSlcbiAgICAgICAgLnRvKHRlc3REYXRhLnRvKVxuICAgICAgICAuZmVlUmF0ZSh0ZXN0RGF0YS5mZWUpO1xuXG4gICAgICAvLyBCdWlsZCB1bnNpZ25lZCB0cmFuc2FjdGlvblxuICAgICAgY29uc3QgdW5zaWduZWRUeCA9IGF3YWl0IHR4QnVpbGRlci5idWlsZCgpO1xuICAgICAgY29uc3QgdW5zaWduZWRIZXggPSB1bnNpZ25lZFR4LnRvQnJvYWRjYXN0Rm9ybWF0KCk7XG5cbiAgICAgIC8vIEdldCBBZGRyZXNzTWFwcyBmcm9tIHRoZSBPUklHSU5BTCB0cmFuc2FjdGlvbiAoYmVmb3JlIHBhcnNpbmcpXG4gICAgICAvLyBUaGUgcGFyc2VkIHRyYW5zYWN0aW9uJ3MgQWRkcmVzc01hcCBvbmx5IGNvbnRhaW5zIHRoZSBvdXRwdXQgYWRkcmVzcywgbm90IF9mcm9tQWRkcmVzc2VzXG4gICAgICBjb25zdCBvcmlnaW5hbEZsYXJlVHggPSAodW5zaWduZWRUeCBhcyBhbnkpLl9mbGFyZVRyYW5zYWN0aW9uO1xuICAgICAgY29uc3Qgb3JpZ2luYWxBZGRyZXNzTWFwcyA9IChvcmlnaW5hbEZsYXJlVHggYXMgYW55IGFzIFVuc2lnbmVkVHgpLmFkZHJlc3NNYXBzO1xuXG4gICAgICAvLyBQYXJzZSBpdCBiYWNrIHRvIGluc3BlY3QgQWRkcmVzc01hcHMgYW5kIGNyZWRlbnRpYWxzXG4gICAgICBjb25zdCBwYXJzZWRCdWlsZGVyID0gZmFjdG9yeS5mcm9tKHVuc2lnbmVkSGV4KTtcbiAgICAgIGNvbnN0IHBhcnNlZFR4ID0gYXdhaXQgcGFyc2VkQnVpbGRlci5idWlsZCgpO1xuICAgICAgY29uc3QgZmxhcmVUeCA9IChwYXJzZWRUeCBhcyBhbnkpLl9mbGFyZVRyYW5zYWN0aW9uO1xuXG4gICAgICAvLyBHZXQgdGhlIGlucHV0IHRvIGNoZWNrIHNpZ0luZGljaWVzIChmb3IgQy1jaGFpbiBpbXBvcnRzLCBpbnB1dHMgYXJlIGltcG9ydGVkSW5wdXRzKVxuICAgICAgY29uc3QgaW1wb3J0VHggPSBmbGFyZVR4LnR4IGFzIGFueTtcbiAgICAgIGNvbnN0IGlucHV0ID0gaW1wb3J0VHguaW1wb3J0ZWRJbnB1dHNbMF07XG4gICAgICBjb25zdCBzaWdJbmRpY2llcyA9IGlucHV0LnNpZ0luZGljaWVzKCk7XG5cbiAgICAgIC8vIHNpZ0luZGljaWVzIHRlbGxzIHVzOiBzaWdJbmRpY2llc1tzbG90SW5kZXhdID0gdXR4b0FkZHJlc3NJbmRleFxuICAgICAgLy8gRm9yIHRocmVzaG9sZD0yLCB3ZSBuZWVkIHNpZ25hdHVyZXMgZm9yIGZpcnN0IDIgYWRkcmVzc2VzIGluIFVUWE8gb3JkZXJcbiAgICAgIC8vIFVUWE8gb3JkZXI6IFsweGM3MzIuLi4gKGluZGV4IDApLCAweDMzMjkuLi4gKGluZGV4IDEpLCAweDdlOTEuLi4gKGluZGV4IDIpXVxuICAgICAgLy8gU28gc2lnSW5kaWNpZXMgc2hvdWxkIGJlIFswLCAxXSBtZWFuaW5nOiBzbG90IDAgPSBVVFhPIGluZGV4IDAsIHNsb3QgMSA9IFVUWE8gaW5kZXggMVxuXG4gICAgICAvLyBWZXJpZnkgc2lnSW5kaWNpZXMgYXJlIFswLCAxXSAoZmlyc3QgMiBhZGRyZXNzZXMgaW4gVVRYTyBvcmRlciwgTk9UIHNvcnRlZCBvcmRlcilcbiAgICAgIHNpZ0luZGljaWVzLmxlbmd0aC5zaG91bGQuZXF1YWwoMik7XG4gICAgICBzaWdJbmRpY2llc1swXS5zaG91bGQuZXF1YWwoMCwgJ0ZpcnN0IHNpZ25hdHVyZSBzbG90IHNob3VsZCBiZSBVVFhPIGFkZHJlc3MgaW5kZXggMCAoMHhjNzMyLi4uKScpO1xuICAgICAgc2lnSW5kaWNpZXNbMV0uc2hvdWxkLmVxdWFsKDEsICdTZWNvbmQgc2lnbmF0dXJlIHNsb3Qgc2hvdWxkIGJlIFVUWE8gYWRkcmVzcyBpbmRleCAxICgweDMzMjkuLi4pJyk7XG5cbiAgICAgIC8vIFRoZSBjcml0aWNhbCB0ZXN0OiBWZXJpZnkgdGhhdCBzaWduYXR1cmUgc2xvdHMgaGF2ZSBlbWJlZGRlZCBhZGRyZXNzZXMgYmFzZWQgb24gVVRYTyBvcmRlclxuICAgICAgLy8gV2l0aCB1bnNvcnRlZCBVVFhPIGFkZHJlc3NlcywgdGhpcyB3aWxsIEZBSUwgaWYgQWRkcmVzc01hcHMgZG9uJ3QgbWF0Y2ggVVRYTyBvcmRlclxuICAgICAgLy9cbiAgICAgIC8vIFBhcnNlIHRoZSBjcmVkZW50aWFsIHRvIHNlZSB3aGljaCBzbG90cyBoYXZlIHdoaWNoIGVtYmVkZGVkIGFkZHJlc3Nlc1xuICAgICAgY29uc3QgY3JlZGVudGlhbCA9IGZsYXJlVHguY3JlZGVudGlhbHNbMF07XG4gICAgICBjb25zdCBzaWduYXR1cmVzID0gY3JlZGVudGlhbC5nZXRTaWduYXR1cmVzKCk7XG5cbiAgICAgIC8vIEV4dHJhY3QgZW1iZWRkZWQgYWRkcmVzc2VzIGZyb20gc2lnbmF0dXJlIHNsb3RzXG4gICAgICBjb25zdCBlbWJlZGRlZEFkZHJlc3Nlczogc3RyaW5nW10gPSBbXTtcbiAgICAgIGNvbnN0IGlzRW1wdHlTaWduYXR1cmUgPSAoc2lnbmF0dXJlOiBzdHJpbmcpOiBib29sZWFuID0+IHtcbiAgICAgICAgcmV0dXJuICEhc2lnbmF0dXJlICYmIHRlc3RVdGlscy5yZW1vdmVIZXhQcmVmaXgoc2lnbmF0dXJlKS5zdGFydHNXaXRoKCcwJy5yZXBlYXQoOTApKTtcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IGhhc0VtYmVkZGVkQWRkcmVzcyA9IChzaWduYXR1cmU6IHN0cmluZyk6IGJvb2xlYW4gPT4ge1xuICAgICAgICBpZiAoIWlzRW1wdHlTaWduYXR1cmUoc2lnbmF0dXJlKSkgcmV0dXJuIGZhbHNlO1xuICAgICAgICBjb25zdCBjbGVhblNpZyA9IHRlc3RVdGlscy5yZW1vdmVIZXhQcmVmaXgoc2lnbmF0dXJlKTtcbiAgICAgICAgaWYgKGNsZWFuU2lnLmxlbmd0aCA8IDEzMCkgcmV0dXJuIGZhbHNlO1xuICAgICAgICBjb25zdCBlbWJlZGRlZFBhcnQgPSBjbGVhblNpZy5zdWJzdHJpbmcoOTAsIDEzMCk7XG4gICAgICAgIC8vIENoZWNrIGlmIGVtYmVkZGVkIHBhcnQgaXMgbm90IGFsbCB6ZXJvc1xuICAgICAgICByZXR1cm4gZW1iZWRkZWRQYXJ0ICE9PSAnMCcucmVwZWF0KDQwKTtcbiAgICAgIH07XG5cbiAgICAgIHNpZ25hdHVyZXMuZm9yRWFjaCgoc2lnOiBzdHJpbmcsIHNsb3RJbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICAgIGlmIChoYXNFbWJlZGRlZEFkZHJlc3Moc2lnKSkge1xuICAgICAgICAgIC8vIEV4dHJhY3QgZW1iZWRkZWQgYWRkcmVzcyAoYWZ0ZXIgcG9zaXRpb24gOTAsIDQwIGNoYXJzID0gMjAgYnl0ZXMpXG4gICAgICAgICAgY29uc3QgY2xlYW5TaWcgPSB0ZXN0VXRpbHMucmVtb3ZlSGV4UHJlZml4KHNpZyk7XG4gICAgICAgICAgY29uc3QgZW1iZWRkZWRBZGRyID0gY2xlYW5TaWcuc3Vic3RyaW5nKDkwLCAxMzApLnRvTG93ZXJDYXNlKCk7XG4gICAgICAgICAgZW1iZWRkZWRBZGRyZXNzZXNbc2xvdEluZGV4XSA9ICcweCcgKyBlbWJlZGRlZEFkZHI7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuXG4gICAgICAvLyBWZXJpZnk6IENyZWRlbnRpYWxzIG9ubHkgZW1iZWQgT05FIGFkZHJlc3MgKHVzZXIvcmVjb3ZlcnkpLCBub3QgYm90aFxuICAgICAgLy8gVGhlIGVtYmVkZGVkIGFkZHJlc3Mgc2hvdWxkIGJlIGJhc2VkIG9uIGFkZHJlc3Nlc0luZGV4IGxvZ2ljLCBub3Qgc2VxdWVudGlhbCBvcmRlclxuICAgICAgLy9cbiAgICAgIC8vIENvbXB1dGUgYWRkcmVzc2VzSW5kZXggdG8gZGV0ZXJtaW5lIGV4cGVjdGVkIHNpZ25hdHVyZSBvcmRlclxuICAgICAgY29uc3QgdXR4b0FkZHJlc3NCeXRlcyA9IHVuc29ydGVkVXR4b0FkZHJlc3Nlcy5tYXAoKGFkZHIpID0+IHRlc3RVdGlscy5wYXJzZUFkZHJlc3MoYWRkcikpO1xuICAgICAgY29uc3QgcEFkZHJlc3NCeXRlcyA9IHBBZGRyZXNzZXMubWFwKChhZGRyKSA9PiB0ZXN0VXRpbHMucGFyc2VBZGRyZXNzKGFkZHIpKTtcblxuICAgICAgY29uc3QgYWRkcmVzc2VzSW5kZXg6IG51bWJlcltdID0gW107XG4gICAgICBwQWRkcmVzc0J5dGVzLmZvckVhY2goKHBBZGRyKSA9PiB7XG4gICAgICAgIGNvbnN0IHV0eG9JbmRleCA9IHV0eG9BZGRyZXNzQnl0ZXMuZmluZEluZGV4KFxuICAgICAgICAgICh1QWRkcikgPT4gQnVmZmVyLmNvbXBhcmUoQnVmZmVyLmZyb20odUFkZHIpLCBCdWZmZXIuZnJvbShwQWRkcikpID09PSAwXG4gICAgICAgICk7XG4gICAgICAgIGFkZHJlc3Nlc0luZGV4LnB1c2godXR4b0luZGV4KTtcbiAgICAgIH0pO1xuXG4gICAgICAvLyBmaXJzdEluZGV4ID0gMCAodXNlciksIGJpdGdvSW5kZXggPSAxXG4gICAgICBjb25zdCBmaXJzdEluZGV4ID0gMDtcbiAgICAgIGNvbnN0IGJpdGdvSW5kZXggPSAxO1xuXG4gICAgICAvLyBEZXRlcm1pbmUgZXhwZWN0ZWQgc2lnbmF0dXJlIG9yZGVyIGJhc2VkIG9uIGFkZHJlc3Nlc0luZGV4XG4gICAgICBjb25zdCB1c2VyQ29tZXNGaXJzdCA9IGFkZHJlc3Nlc0luZGV4W2JpdGdvSW5kZXhdID4gYWRkcmVzc2VzSW5kZXhbZmlyc3RJbmRleF07XG5cbiAgICAgIC8vIEV4cGVjdGVkIGNyZWRlbnRpYWwgc3RydWN0dXJlOlxuICAgICAgLy8gLSBJZiB1c2VyIGNvbWVzIGZpcnN0OiBbdXNlckFkZHJlc3MsIHplcm9zXVxuICAgICAgLy8gLSBJZiBiaXRnbyBjb21lcyBmaXJzdDogW3plcm9zLCB1c2VyQWRkcmVzc11cbiAgICAgIGNvbnN0IHVzZXJBZGRyZXNzSGV4ID0gQnVmZmVyLmZyb20ocEFkZHJlc3NCeXRlc1tmaXJzdEluZGV4XSkudG9TdHJpbmcoJ2hleCcpLnRvTG93ZXJDYXNlKCk7XG4gICAgICBjb25zdCBleHBlY3RlZFVzZXJBZGRyID0gJzB4JyArIHVzZXJBZGRyZXNzSGV4O1xuXG4gICAgICBpZiAodXNlckNvbWVzRmlyc3QpIHtcbiAgICAgICAgLy8gRXhwZWN0ZWQ6IFt1c2VyQWRkcmVzcywgemVyb3NdXG4gICAgICAgIC8vIFNsb3QgMCBzaG91bGQgaGF2ZSB1c2VyIGFkZHJlc3MgKHBBZGRyMCA9IDB4YzczMi4uLiA9IFVUWE8gaW5kZXggMClcbiAgICAgICAgaWYgKGVtYmVkZGVkQWRkcmVzc2VzWzBdKSB7XG4gICAgICAgICAgZW1iZWRkZWRBZGRyZXNzZXNbMF1cbiAgICAgICAgICAgIC50b0xvd2VyQ2FzZSgpXG4gICAgICAgICAgICAuc2hvdWxkLmVxdWFsKFxuICAgICAgICAgICAgICBleHBlY3RlZFVzZXJBZGRyLFxuICAgICAgICAgICAgICBgU2xvdCAwIHNob3VsZCBoYXZlIHVzZXIgYWRkcmVzcyAoJHtleHBlY3RlZFVzZXJBZGRyfSkgYmVjYXVzZSB1c2VyIGNvbWVzIGZpcnN0IGluIFVUWE8gb3JkZXJgXG4gICAgICAgICAgICApO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgU2xvdCAwIHNob3VsZCBoYXZlIGVtYmVkZGVkIHVzZXIgYWRkcmVzcywgYnV0IGlzIGVtcHR5YCk7XG4gICAgICAgIH1cbiAgICAgICAgLy8gU2xvdCAxIHNob3VsZCBiZSB6ZXJvcyAobm8gZW1iZWRkZWQgYWRkcmVzcylcbiAgICAgICAgaWYgKGVtYmVkZGVkQWRkcmVzc2VzWzFdKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBTbG90IDEgc2hvdWxkIGJlIHplcm9zLCBidXQgaGFzIGVtYmVkZGVkIGFkZHJlc3M6ICR7ZW1iZWRkZWRBZGRyZXNzZXNbMV19YCk7XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIEV4cGVjdGVkOiBbemVyb3MsIHVzZXJBZGRyZXNzXVxuICAgICAgICAvLyBTbG90IDAgc2hvdWxkIGJlIHplcm9zXG4gICAgICAgIGlmIChlbWJlZGRlZEFkZHJlc3Nlc1swXSkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgU2xvdCAwIHNob3VsZCBiZSB6ZXJvcywgYnV0IGhhcyBlbWJlZGRlZCBhZGRyZXNzOiAke2VtYmVkZGVkQWRkcmVzc2VzWzBdfWApO1xuICAgICAgICB9XG4gICAgICAgIC8vIFNsb3QgMSBzaG91bGQgaGF2ZSB1c2VyIGFkZHJlc3NcbiAgICAgICAgaWYgKGVtYmVkZGVkQWRkcmVzc2VzWzFdKSB7XG4gICAgICAgICAgZW1iZWRkZWRBZGRyZXNzZXNbMV1cbiAgICAgICAgICAgIC50b0xvd2VyQ2FzZSgpXG4gICAgICAgICAgICAuc2hvdWxkLmVxdWFsKFxuICAgICAgICAgICAgICBleHBlY3RlZFVzZXJBZGRyLFxuICAgICAgICAgICAgICBgU2xvdCAxIHNob3VsZCBoYXZlIHVzZXIgYWRkcmVzcyAoJHtleHBlY3RlZFVzZXJBZGRyfSkgYmVjYXVzZSBiaXRnbyBjb21lcyBmaXJzdCBpbiBVVFhPIG9yZGVyYFxuICAgICAgICAgICAgKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYFNsb3QgMSBzaG91bGQgaGF2ZSBlbWJlZGRlZCB1c2VyIGFkZHJlc3MsIGJ1dCBpcyBlbXB0eWApO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC8vIFRoZSBrZXkgdmVyaWZpY2F0aW9uOiBBZGRyZXNzTWFwcyBzaG91bGQgbWF0Y2ggdGhlIGNyZWRlbnRpYWwgb3JkZXJcbiAgICAgIC8vIEN1cnJlbnQgaW1wbGVtZW50YXRpb24gKFdST05HKTogQWRkcmVzc01hcHMgdXNlIHNlcXVlbnRpYWwgaW5kaWNlcyAoMCwgMSwgMi4uLilcbiAgICAgIC8vIEV4cGVjdGVkIChDT1JSRUNUKTogQWRkcmVzc01hcHMgc2hvdWxkIHVzZSBhZGRyZXNzZXNJbmRleCBsb2dpYywgbWF0Y2hpbmcgY3JlZGVudGlhbCBvcmRlclxuICAgICAgLy9cbiAgICAgIC8vIEdldCBBZGRyZXNzTWFwcyBmcm9tIHRoZSBPUklHSU5BTCB0cmFuc2FjdGlvbiAobm90IHBhcnNlZCwgYmVjYXVzZSBwYXJzZWQgQWRkcmVzc01hcCBvbmx5IGhhcyBvdXRwdXQgYWRkcmVzcylcbiAgICAgIC8vIEZvciBDLWNoYWluIGltcG9ydHMsIG9yaWdpbmFsRmxhcmVUeCBpcyBFVk1VbnNpZ25lZFR4IHdoaWNoIGhhcyBhZGRyZXNzTWFwcyBwcm9wZXJ0eVxuXG4gICAgICBjb25zdCBhZGRyZXNzTWFwcyA9IG9yaWdpbmFsQWRkcmVzc01hcHM7XG4gICAgICBhZGRyZXNzTWFwcy50b0FycmF5KCkubGVuZ3RoLnNob3VsZC5lcXVhbCgxLCAnU2hvdWxkIGhhdmUgb25lIEFkZHJlc3NNYXAgZm9yIG9uZSBpbnB1dCcpO1xuXG4gICAgICBjb25zdCBhZGRyZXNzTWFwID0gYWRkcmVzc01hcHMudG9BcnJheSgpWzBdO1xuXG4gICAgICAvLyBFeHBlY3RlZDogQmFzZWQgb24gYWRkcmVzc2VzSW5kZXggbG9naWNcbiAgICAgIC8vIElmIHVzZXIgY29tZXMgZmlyc3Q6IHNsb3QgMCA9IHVzZXIsIHNsb3QgMSA9IGJpdGdvXG4gICAgICAvLyBJZiBiaXRnbyBjb21lcyBmaXJzdDogc2xvdCAwID0gYml0Z28sIHNsb3QgMSA9IHVzZXJcbiAgICAgIGNvbnN0IGV4cGVjdGVkU2xvdDBBZGRyID0gdXNlckNvbWVzRmlyc3QgPyBwQWRkcmVzc0J5dGVzW2ZpcnN0SW5kZXhdIDogcEFkZHJlc3NCeXRlc1tiaXRnb0luZGV4XTtcbiAgICAgIGNvbnN0IGV4cGVjdGVkU2xvdDFBZGRyID0gdXNlckNvbWVzRmlyc3QgPyBwQWRkcmVzc0J5dGVzW2JpdGdvSW5kZXhdIDogcEFkZHJlc3NCeXRlc1tmaXJzdEluZGV4XTtcblxuICAgICAgLy8gQWRkcmVzc01hcCBtYXBzOiBBZGRyZXNzIC0+IHNsb3QgaW5kZXhcbiAgICAgIC8vIFdlIG5lZWQgdG8gY2hlY2sgd2hpY2ggYWRkcmVzc2VzIGFyZSBtYXBwZWQgdG8gc2xvdHMgMCBhbmQgMVxuICAgICAgLy8gQWRkcmVzc01hcC5nZXQoKSByZXR1cm5zIHRoZSBzbG90IGluZGV4IGZvciBhIGdpdmVuIGFkZHJlc3NcblxuICAgICAgLy8gVmVyaWZ5IHRoYXQgQWRkcmVzc01hcCBjb3JyZWN0bHkgbWFwcyBhZGRyZXNzZXMgYmFzZWQgb24gY3JlZGVudGlhbCBvcmRlciAoVVRYTyBvcmRlcilcbiAgICAgIC8vIFRoZSBBZGRyZXNzTWFwIHNob3VsZCBtYXAgdGhlIGFkZHJlc3NlcyB0aGF0IGFwcGVhciBpbiBjcmVkZW50aWFscyB0byB0aGUgY29ycmVjdCBzbG90c1xuICAgICAgY29uc3QgeyBBZGRyZXNzIH0gPSByZXF1aXJlKCdAZmxhcmVuZXR3b3JrL2ZsYXJlanMnKTtcbiAgICAgIGNvbnN0IGV4cGVjdGVkU2xvdDBBZGRyZXNzID0gbmV3IEFkZHJlc3MoZXhwZWN0ZWRTbG90MEFkZHIpO1xuICAgICAgY29uc3QgZXhwZWN0ZWRTbG90MUFkZHJlc3MgPSBuZXcgQWRkcmVzcyhleHBlY3RlZFNsb3QxQWRkcik7XG4gICAgICBjb25zdCBleHBlY3RlZFNsb3QwRnJvbU1hcCA9IGFkZHJlc3NNYXAuZ2V0KGV4cGVjdGVkU2xvdDBBZGRyZXNzKTtcbiAgICAgIGNvbnN0IGV4cGVjdGVkU2xvdDFGcm9tTWFwID0gYWRkcmVzc01hcC5nZXQoZXhwZWN0ZWRTbG90MUFkZHJlc3MpO1xuXG4gICAgICAvLyBWZXJpZnkgdGhhdCB0aGUgZXhwZWN0ZWQgYWRkcmVzc2VzIG1hcCB0byB0aGUgY29ycmVjdCBzbG90c1xuICAgICAgaWYgKGV4cGVjdGVkU2xvdDBGcm9tTWFwID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBBZGRyZXNzIGF0IFVUWE8gaW5kZXggJHthZGRyZXNzZXNJbmRleFtmaXJzdEluZGV4XX0gbm90IGZvdW5kIGluIEFkZHJlc3NNYXBgKTtcbiAgICAgIH1cbiAgICAgIGlmIChleHBlY3RlZFNsb3QxRnJvbU1hcCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgQWRkcmVzcyBhdCBVVFhPIGluZGV4ICR7YWRkcmVzc2VzSW5kZXhbYml0Z29JbmRleF19IG5vdCBmb3VuZCBpbiBBZGRyZXNzTWFwYCk7XG4gICAgICB9XG4gICAgICBleHBlY3RlZFNsb3QwRnJvbU1hcC5zaG91bGQuZXF1YWwoMCwgYEFkZHJlc3MgYXQgVVRYTyBpbmRleCAke2FkZHJlc3Nlc0luZGV4W2ZpcnN0SW5kZXhdfSBzaG91bGQgbWFwIHRvIHNsb3QgMGApO1xuICAgICAgZXhwZWN0ZWRTbG90MUZyb21NYXAuc2hvdWxkLmVxdWFsKDEsIGBBZGRyZXNzIGF0IFVUWE8gaW5kZXggJHthZGRyZXNzZXNJbmRleFtiaXRnb0luZGV4XX0gc2hvdWxkIG1hcCB0byBzbG90IDFgKTtcblxuICAgICAgLy8gSWYgYWRkcmVzc2VzSW5kZXggaXMgbm90IHNlcXVlbnRpYWwgKFswLCAxLCAuLi5dKSwgdmVyaWZ5IHRoYXQgc2VxdWVudGlhbCBtYXBwaW5nIGlzIE5PVCB1c2VkIGluY29ycmVjdGx5XG4gICAgICAvLyBTZXF1ZW50aWFsIG1hcHBpbmcgbWVhbnM6IHBBZGRyZXNzZXNbMF0gLT4gc2xvdCAwLCBwQWRkcmVzc2VzWzFdIC0+IHNsb3QgMSwgcmVnYXJkbGVzcyBvZiBVVFhPIG9yZGVyXG4gICAgICBjb25zdCB1c2VzU2VxdWVudGlhbE1hcHBpbmcgPSBhZGRyZXNzZXNJbmRleFswXSA9PT0gMCAmJiBhZGRyZXNzZXNJbmRleFsxXSA9PT0gMTtcblxuICAgICAgaWYgKCF1c2VzU2VxdWVudGlhbE1hcHBpbmcpIHtcbiAgICAgICAgLy8gQ2hlY2sgaWYgQWRkcmVzc01hcCB1c2VzIHNlcXVlbnRpYWwgbWFwcGluZyAoYXJyYXkgb3JkZXIpIGluc3RlYWQgb2YgVVRYTyBvcmRlclxuICAgICAgICBjb25zdCBzZXF1ZW50aWFsU2xvdDAgPSBhZGRyZXNzTWFwLmdldChuZXcgQWRkcmVzcyhwQWRkcmVzc0J5dGVzWzBdKSk7XG4gICAgICAgIGNvbnN0IHNlcXVlbnRpYWxTbG90MSA9IGFkZHJlc3NNYXAuZ2V0KG5ldyBBZGRyZXNzKHBBZGRyZXNzQnl0ZXNbMV0pKTtcblxuICAgICAgICAvLyBTZXF1ZW50aWFsIG1hcHBpbmcgd291bGQgbWFwIHBBZGRyZXNzZXNbMF0gLT4gc2xvdCAwLCBwQWRkcmVzc2VzWzFdIC0+IHNsb3QgMVxuICAgICAgICAvLyBCdXQgd2Ugd2FudCBVVFhPIG9yZGVyIG1hcHBpbmcgYmFzZWQgb24gYWRkcmVzc2VzSW5kZXhcbiAgICAgICAgY29uc3QgaXNTZXF1ZW50aWFsID0gc2VxdWVudGlhbFNsb3QwID09PSAwICYmIHNlcXVlbnRpYWxTbG90MSA9PT0gMTtcblxuICAgICAgICAvLyBDaGVjayBpZiBwQWRkcmVzc2VzWzBdIGFuZCBwQWRkcmVzc2VzWzFdIGFyZSB0aGUgZXhwZWN0ZWQgYWRkcmVzc2VzIGZvciBzbG90cyAwIGFuZCAxXG4gICAgICAgIC8vIElmIHRoZXkgYXJlLCB0aGVuIHNlcXVlbnRpYWwgbWFwcGluZyBoYXBwZW5zIHRvIGJlIGNvcnJlY3QgKGJ5IGNvaW5jaWRlbmNlKVxuICAgICAgICBjb25zdCBwQWRkcmVzczBJc0V4cGVjdGVkU2xvdDAgPVxuICAgICAgICAgIEJ1ZmZlci5jb21wYXJlKEJ1ZmZlci5mcm9tKHBBZGRyZXNzQnl0ZXNbMF0pLCBCdWZmZXIuZnJvbShleHBlY3RlZFNsb3QwQWRkcikpID09PSAwO1xuICAgICAgICBjb25zdCBwQWRkcmVzczFJc0V4cGVjdGVkU2xvdDEgPVxuICAgICAgICAgIEJ1ZmZlci5jb21wYXJlKEJ1ZmZlci5mcm9tKHBBZGRyZXNzQnl0ZXNbMV0pLCBCdWZmZXIuZnJvbShleHBlY3RlZFNsb3QxQWRkcikpID09PSAwO1xuXG4gICAgICAgIC8vIElmIHNlcXVlbnRpYWwgbWFwcGluZyBpcyB1c2VkIGJ1dCBpdCdzIE5PVCBjb3JyZWN0IChkb2Vzbid0IG1hdGNoIGV4cGVjdGVkIGFkZHJlc3NlcyksIGZhaWxcbiAgICAgICAgaWYgKGlzU2VxdWVudGlhbCAmJiAoIXBBZGRyZXNzMElzRXhwZWN0ZWRTbG90MCB8fCAhcEFkZHJlc3MxSXNFeHBlY3RlZFNsb3QxKSkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAgIGBBZGRyZXNzTWFwIHVzZXMgc2VxdWVudGlhbCBtYXBwaW5nIChhcnJheSBvcmRlcikgYnV0IHNob3VsZCB1c2UgVVRYTyBvcmRlci4gYCArXG4gICAgICAgICAgICAgIGBhZGRyZXNzZXNJbmRleDogWyR7YWRkcmVzc2VzSW5kZXguam9pbignLCAnKX1dLiBgICtcbiAgICAgICAgICAgICAgYEV4cGVjdGVkIHNsb3QgMCA9IGFkZHJlc3MgYXQgVVRYTyBpbmRleCAke2FkZHJlc3Nlc0luZGV4W2ZpcnN0SW5kZXhdfSwgc2xvdCAxID0gYWRkcmVzcyBhdCBVVFhPIGluZGV4ICR7YWRkcmVzc2VzSW5kZXhbYml0Z29JbmRleF19YFxuICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ import 'should';
2
+ //# sourceMappingURL=importInPTxBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"importInPTxBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/lib/importInPTxBuilder.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,CAAC"}