@bitgo-beta/sdk-coin-sol 2.4.3-beta.88 → 2.4.3-beta.880

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 (63) hide show
  1. package/CHANGELOG.md +922 -0
  2. package/dist/src/index.js +6 -2
  3. package/dist/src/lib/ataInitializationBuilder.d.ts.map +1 -1
  4. package/dist/src/lib/ataInitializationBuilder.js +37 -19
  5. package/dist/src/lib/closeAtaBuilder.d.ts +19 -0
  6. package/dist/src/lib/closeAtaBuilder.d.ts.map +1 -0
  7. package/dist/src/lib/closeAtaBuilder.js +69 -0
  8. package/dist/src/lib/constants.d.ts +37 -8
  9. package/dist/src/lib/constants.d.ts.map +1 -1
  10. package/dist/src/lib/constants.js +41 -10
  11. package/dist/src/lib/iface.d.ts +47 -4
  12. package/dist/src/lib/iface.d.ts.map +1 -1
  13. package/dist/src/lib/iface.js +1 -1
  14. package/dist/src/lib/index.d.ts +11 -8
  15. package/dist/src/lib/index.d.ts.map +1 -1
  16. package/dist/src/lib/index.js +44 -24
  17. package/dist/src/lib/instructionParamsFactory.d.ts +1 -1
  18. package/dist/src/lib/instructionParamsFactory.d.ts.map +1 -1
  19. package/dist/src/lib/instructionParamsFactory.js +272 -50
  20. package/dist/src/lib/keyPair.js +5 -5
  21. package/dist/src/lib/solInstructionFactory.d.ts.map +1 -1
  22. package/dist/src/lib/solInstructionFactory.js +115 -51
  23. package/dist/src/lib/stakingActivateBuilder.d.ts +9 -2
  24. package/dist/src/lib/stakingActivateBuilder.d.ts.map +1 -1
  25. package/dist/src/lib/stakingActivateBuilder.js +23 -10
  26. package/dist/src/lib/stakingAuthorizeBuilder.js +7 -7
  27. package/dist/src/lib/stakingDeactivateBuilder.d.ts +26 -1
  28. package/dist/src/lib/stakingDeactivateBuilder.d.ts.map +1 -1
  29. package/dist/src/lib/stakingDeactivateBuilder.js +106 -25
  30. package/dist/src/lib/stakingDelegateBuilder.d.ts +42 -0
  31. package/dist/src/lib/stakingDelegateBuilder.d.ts.map +1 -0
  32. package/dist/src/lib/stakingDelegateBuilder.js +120 -0
  33. package/dist/src/lib/stakingRawMsgAuthorizeBuilder.d.ts +33 -0
  34. package/dist/src/lib/stakingRawMsgAuthorizeBuilder.d.ts.map +1 -0
  35. package/dist/src/lib/stakingRawMsgAuthorizeBuilder.js +110 -0
  36. package/dist/src/lib/stakingWithdrawBuilder.js +6 -6
  37. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -1
  38. package/dist/src/lib/tokenTransferBuilder.js +32 -16
  39. package/dist/src/lib/transaction.d.ts +3 -3
  40. package/dist/src/lib/transaction.d.ts.map +1 -1
  41. package/dist/src/lib/transaction.js +93 -16
  42. package/dist/src/lib/transactionBuilder.d.ts +2 -1
  43. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  44. package/dist/src/lib/transactionBuilder.js +29 -19
  45. package/dist/src/lib/transactionBuilderFactory.d.ts +30 -9
  46. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  47. package/dist/src/lib/transactionBuilderFactory.js +46 -9
  48. package/dist/src/lib/transferBuilder.js +4 -4
  49. package/dist/src/lib/transferBuilderV2.d.ts +11 -1
  50. package/dist/src/lib/transferBuilderV2.d.ts.map +1 -1
  51. package/dist/src/lib/transferBuilderV2.js +70 -10
  52. package/dist/src/lib/utils.d.ts +15 -6
  53. package/dist/src/lib/utils.d.ts.map +1 -1
  54. package/dist/src/lib/utils.js +122 -51
  55. package/dist/src/lib/walletInitializationBuilder.js +6 -6
  56. package/dist/src/sol.d.ts +68 -25
  57. package/dist/src/sol.d.ts.map +1 -1
  58. package/dist/src/sol.js +609 -84
  59. package/dist/src/solToken.d.ts +2 -1
  60. package/dist/src/solToken.d.ts.map +1 -1
  61. package/dist/src/solToken.js +6 -3
  62. package/dist/src/tsol.js +1 -1
  63. package/package.json +10 -9
@@ -3,24 +3,50 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.validateOwnerAddress = exports.validateMintAddress = exports.getAssociatedTokenAccountAddress = exports.getSolTokenFromTokenName = exports.getSolTokenFromAddress = exports.validateAddress = exports.validateRawTransaction = exports.validateIntructionTypes = exports.getInstructionType = exports.getTransactionType = exports.matchTransactionTypeByInstructionsOrder = exports.requiresAllSignatures = exports.countNotNullSignatures = exports.Uint8ArrayTobase58 = exports.base58ToUint8Array = exports.verifySignature = exports.isValidRawTransaction = exports.isValidMemo = exports.isValidStakingAmount = exports.isValidAmount = exports.isValidTransactionId = exports.isValidSignature = exports.isValidPublicKey = exports.isValidPrivateKey = exports.isValidBlockId = exports.isValidAddress = void 0;
7
- const web3_js_1 = require("@solana/web3.js");
8
- const bs58_1 = __importDefault(require("bs58"));
9
- const bignumber_js_1 = __importDefault(require("bignumber.js"));
10
- const constants_1 = require("./constants");
6
+ exports.isValidAddress = isValidAddress;
7
+ exports.isValidBlockId = isValidBlockId;
8
+ exports.isValidPrivateKey = isValidPrivateKey;
9
+ exports.isValidPublicKey = isValidPublicKey;
10
+ exports.isValidSignature = isValidSignature;
11
+ exports.isValidTransactionId = isValidTransactionId;
12
+ exports.isValidAmount = isValidAmount;
13
+ exports.isValidStakingAmount = isValidStakingAmount;
14
+ exports.isValidMemo = isValidMemo;
15
+ exports.isValidRawTransaction = isValidRawTransaction;
16
+ exports.verifySignature = verifySignature;
17
+ exports.base58ToUint8Array = base58ToUint8Array;
18
+ exports.Uint8ArrayTobase58 = Uint8ArrayTobase58;
19
+ exports.countNotNullSignatures = countNotNullSignatures;
20
+ exports.requiresAllSignatures = requiresAllSignatures;
21
+ exports.matchTransactionTypeByInstructionsOrder = matchTransactionTypeByInstructionsOrder;
22
+ exports.getTransactionType = getTransactionType;
23
+ exports.getInstructionType = getInstructionType;
24
+ exports.validateIntructionTypes = validateIntructionTypes;
25
+ exports.validateRawMsgInstruction = validateRawMsgInstruction;
26
+ exports.validateRawTransaction = validateRawTransaction;
27
+ exports.validateAddress = validateAddress;
28
+ exports.getSolTokenFromAddress = getSolTokenFromAddress;
29
+ exports.getSolTokenFromTokenName = getSolTokenFromTokenName;
30
+ exports.getAssociatedTokenAccountAddress = getAssociatedTokenAccountAddress;
31
+ exports.validateMintAddress = validateMintAddress;
32
+ exports.validateOwnerAddress = validateOwnerAddress;
11
33
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
12
- const tweetnacl_1 = __importDefault(require("tweetnacl"));
13
- const spl_token_1 = require("@solana/spl-token");
14
34
  const statics_1 = require("@bitgo-beta/statics");
35
+ const spl_token_1 = require("@solana/spl-token");
36
+ const web3_js_1 = require("@solana/web3.js");
15
37
  const assert_1 = __importDefault(require("assert"));
38
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
39
+ const bs58_1 = __importDefault(require("bs58"));
40
+ const tweetnacl_1 = __importDefault(require("tweetnacl"));
41
+ const constants_1 = require("./constants");
16
42
  const DECODED_BLOCK_HASH_LENGTH = 32; // https://docs.solana.com/developing/programming-model/transactions#blockhash-format
17
43
  const DECODED_SIGNATURE_LENGTH = 64; // https://docs.solana.com/terminology#signature
18
44
  const BASE_58_ENCONDING_REGEX = '[1-9A-HJ-NP-Za-km-z]';
45
+ const COMPUTE_BUDGET = 'ComputeBudget111111111111111111111111111111';
19
46
  /** @inheritdoc */
20
47
  function isValidAddress(address) {
21
48
  return isValidPublicKey(address);
22
49
  }
23
- exports.isValidAddress = isValidAddress;
24
50
  /** @inheritdoc */
25
51
  function isValidBlockId(hash) {
26
52
  try {
@@ -30,7 +56,6 @@ function isValidBlockId(hash) {
30
56
  return false;
31
57
  }
32
58
  }
33
- exports.isValidBlockId = isValidBlockId;
34
59
  /** @inheritdoc */
35
60
  function isValidPrivateKey(prvKey) {
36
61
  try {
@@ -41,11 +66,10 @@ function isValidPrivateKey(prvKey) {
41
66
  return false;
42
67
  }
43
68
  }
44
- exports.isValidPrivateKey = isValidPrivateKey;
45
69
  /** @inheritdoc */
46
70
  function isValidPublicKey(pubKey) {
47
71
  try {
48
- if (sdk_core_1.isValidXpub(pubKey))
72
+ if ((0, sdk_core_1.isValidXpub)(pubKey))
49
73
  return true;
50
74
  new web3_js_1.PublicKey(pubKey);
51
75
  return true;
@@ -54,7 +78,6 @@ function isValidPublicKey(pubKey) {
54
78
  return false;
55
79
  }
56
80
  }
57
- exports.isValidPublicKey = isValidPublicKey;
58
81
  /** @inheritdoc */
59
82
  function isValidSignature(signature) {
60
83
  try {
@@ -64,13 +87,11 @@ function isValidSignature(signature) {
64
87
  return false;
65
88
  }
66
89
  }
67
- exports.isValidSignature = isValidSignature;
68
90
  /** @inheritdoc */
69
91
  // TransactionId are the first signature on a Transaction
70
92
  function isValidTransactionId(txId) {
71
93
  return isValidSignature(txId);
72
94
  }
73
- exports.isValidTransactionId = isValidTransactionId;
74
95
  /**
75
96
  * Returns whether or not the string is a valid amount of lamports number
76
97
  *
@@ -81,7 +102,6 @@ function isValidAmount(amount) {
81
102
  const bigNumberAmount = new bignumber_js_1.default(amount);
82
103
  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThanOrEqualTo(0);
83
104
  }
84
- exports.isValidAmount = isValidAmount;
85
105
  /**
86
106
  * Check if the string is a valid amount of lamports number on staking
87
107
  *
@@ -92,7 +112,6 @@ function isValidStakingAmount(amount) {
92
112
  const bigNumberAmount = new bignumber_js_1.default(amount);
93
113
  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThan(0);
94
114
  }
95
- exports.isValidStakingAmount = isValidStakingAmount;
96
115
  /**
97
116
  * Check if this is a valid memo or not.
98
117
  *
@@ -102,24 +121,24 @@ exports.isValidStakingAmount = isValidStakingAmount;
102
121
  function isValidMemo(memo) {
103
122
  return Buffer.from(memo).length <= constants_1.MAX_MEMO_LENGTH;
104
123
  }
105
- exports.isValidMemo = isValidMemo;
106
124
  /**
107
125
  * Checks if raw transaction can be deserialized
108
126
  *
109
127
  * @param {string} rawTransaction - transaction in base64 string format
128
+ * @param {boolean} requireAllSignatures - require all signatures to be present
129
+ * @param {boolean} verifySignatures - verify signatures
110
130
  * @returns {boolean} - the validation result
111
131
  */
112
- function isValidRawTransaction(rawTransaction) {
132
+ function isValidRawTransaction(rawTransaction, requireAllSignatures = false, verifySignatures = false) {
113
133
  try {
114
134
  const tx = web3_js_1.Transaction.from(Buffer.from(rawTransaction, 'base64'));
115
- tx.serialize({ requireAllSignatures: false, verifySignatures: false });
135
+ tx.serialize({ requireAllSignatures, verifySignatures });
116
136
  return true;
117
137
  }
118
138
  catch (e) {
119
139
  return false;
120
140
  }
121
141
  }
122
- exports.isValidRawTransaction = isValidRawTransaction;
123
142
  /**
124
143
  * Verifies if signature for message is valid.
125
144
  *
@@ -143,7 +162,6 @@ function verifySignature(serializedTx, signature, publicKey) {
143
162
  const pub = new web3_js_1.PublicKey(publicKey);
144
163
  return tweetnacl_1.default.sign.detached.verify(msg, sig, pub.toBuffer());
145
164
  }
146
- exports.verifySignature = verifySignature;
147
165
  /**
148
166
  * Converts a base58 string into a Uint8Array.
149
167
  *
@@ -153,7 +171,6 @@ exports.verifySignature = verifySignature;
153
171
  function base58ToUint8Array(input) {
154
172
  return new Uint8Array(bs58_1.default.decode(input));
155
173
  }
156
- exports.base58ToUint8Array = base58ToUint8Array;
157
174
  /**
158
175
  * Converts a Uint8Array to a base58 string.
159
176
  *
@@ -163,7 +180,6 @@ exports.base58ToUint8Array = base58ToUint8Array;
163
180
  function Uint8ArrayTobase58(input) {
164
181
  return bs58_1.default.encode(input);
165
182
  }
166
- exports.Uint8ArrayTobase58 = Uint8ArrayTobase58;
167
183
  /**
168
184
  * Count the amount of signatures are not null.
169
185
  *
@@ -173,7 +189,6 @@ exports.Uint8ArrayTobase58 = Uint8ArrayTobase58;
173
189
  function countNotNullSignatures(signatures) {
174
190
  return signatures.filter((sig) => !!sig.signature).length;
175
191
  }
176
- exports.countNotNullSignatures = countNotNullSignatures;
177
192
  /**
178
193
  * Check if all signatures are completed.
179
194
  *
@@ -183,7 +198,6 @@ exports.countNotNullSignatures = countNotNullSignatures;
183
198
  function requiresAllSignatures(signatures) {
184
199
  return signatures.length > 0 && countNotNullSignatures(signatures) === signatures.length;
185
200
  }
186
- exports.requiresAllSignatures = requiresAllSignatures;
187
201
  /**
188
202
  * Check the transaction type matching instructions by order. Memo and AdvanceNonceAccount instructions
189
203
  * are ignored.
@@ -215,7 +229,6 @@ function matchTransactionTypeByInstructionsOrder(instructions, instructionIndexe
215
229
  }
216
230
  return true;
217
231
  }
218
- exports.matchTransactionTypeByInstructionsOrder = matchTransactionTypeByInstructionsOrder;
219
232
  /**
220
233
  * Returns the transaction Type based on the transaction instructions.
221
234
  * Wallet initialization, Transfer and Staking transactions are supported.
@@ -225,24 +238,38 @@ exports.matchTransactionTypeByInstructionsOrder = matchTransactionTypeByInstruct
225
238
  */
226
239
  function getTransactionType(transaction) {
227
240
  const { instructions } = transaction;
241
+ if (validateRawMsgInstruction(instructions)) {
242
+ return sdk_core_1.TransactionType.StakingAuthorizeRaw;
243
+ }
228
244
  validateIntructionTypes(instructions);
229
- for (const instruction of instructions) {
230
- const instructionType = getInstructionType(instruction);
231
- if (instructionType === constants_1.ValidInstructionTypesEnum.Transfer ||
232
- instructionType === constants_1.ValidInstructionTypesEnum.TokenTransfer) {
233
- return sdk_core_1.TransactionType.Send;
245
+ // check if deactivate instruction does not exist because deactivate can be include a transfer instruction
246
+ const memoInstruction = instructions.find((instruction) => getInstructionType(instruction) === 'Memo');
247
+ const memoData = memoInstruction?.data.toString('utf-8');
248
+ if (instructions.filter((instruction) => getInstructionType(instruction) === 'Deactivate').length == 0) {
249
+ for (const instruction of instructions) {
250
+ const instructionType = getInstructionType(instruction);
251
+ // Check if memo instruction is there and if it contains 'PrepareForRevoke' because Marinade staking deactivate transaction will have this
252
+ if ((instructionType === constants_1.ValidInstructionTypesEnum.Transfer && !memoData?.includes('PrepareForRevoke')) ||
253
+ instructionType === constants_1.ValidInstructionTypesEnum.TokenTransfer) {
254
+ return sdk_core_1.TransactionType.Send;
255
+ }
234
256
  }
235
257
  }
236
258
  if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.walletInitInstructionIndexes)) {
237
259
  return sdk_core_1.TransactionType.WalletInitialization;
238
260
  }
239
- else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingActivateInstructionsIndexes)) {
261
+ else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.marinadeStakingActivateInstructionsIndexes) ||
262
+ matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingActivateInstructionsIndexes)) {
240
263
  return sdk_core_1.TransactionType.StakingActivate;
241
264
  }
242
265
  else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingAuthorizeInstructionsIndexes)) {
243
266
  return sdk_core_1.TransactionType.StakingAuthorize;
244
267
  }
245
- else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingDeactivateInstructionsIndexes) ||
268
+ else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingDelegateInstructionsIndexes)) {
269
+ return sdk_core_1.TransactionType.StakingDelegate;
270
+ }
271
+ else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.marinadeStakingDeactivateInstructionsIndexes) ||
272
+ matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingDeactivateInstructionsIndexes) ||
246
273
  matchTransactionTypeByInstructionsOrder(instructions, constants_1.stakingPartialDeactivateInstructionsIndexes)) {
247
274
  return sdk_core_1.TransactionType.StakingDeactivate;
248
275
  }
@@ -252,11 +279,13 @@ function getTransactionType(transaction) {
252
279
  else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.ataInitInstructionIndexes)) {
253
280
  return sdk_core_1.TransactionType.AssociatedTokenAccountInitialization;
254
281
  }
282
+ else if (matchTransactionTypeByInstructionsOrder(instructions, constants_1.ataCloseInstructionIndexes)) {
283
+ return sdk_core_1.TransactionType.CloseAssociatedTokenAccount;
284
+ }
255
285
  else {
256
286
  throw new sdk_core_1.NotSupported('Invalid transaction, transaction not supported or invalid');
257
287
  }
258
288
  }
259
- exports.getTransactionType = getTransactionType;
260
289
  /**
261
290
  * Returns the instruction Type based on the solana instructions.
262
291
  * Throws if the solana instruction program is not supported
@@ -271,6 +300,16 @@ function getInstructionType(instruction) {
271
300
  case web3_js_1.SystemProgram.programId.toString():
272
301
  return web3_js_1.SystemInstruction.decodeInstructionType(instruction);
273
302
  case spl_token_1.TOKEN_PROGRAM_ID.toString():
303
+ try {
304
+ const decodedInstruction = (0, spl_token_1.decodeCloseAccountInstruction)(instruction);
305
+ if (decodedInstruction && decodedInstruction.data.instruction === 9) {
306
+ return 'CloseAssociatedTokenAccount';
307
+ }
308
+ }
309
+ catch (e) {
310
+ // ignore error and default to TokenTransfer
311
+ return 'TokenTransfer';
312
+ }
274
313
  return 'TokenTransfer';
275
314
  case web3_js_1.StakeProgram.programId.toString():
276
315
  return web3_js_1.StakeInstruction.decodeInstructionType(instruction);
@@ -282,11 +321,12 @@ function getInstructionType(instruction) {
282
321
  else {
283
322
  throw new sdk_core_1.NotSupported('Invalid transaction, instruction program id not supported: ' + instruction.programId.toString());
284
323
  }
324
+ case COMPUTE_BUDGET:
325
+ return 'SetPriorityFee';
285
326
  default:
286
327
  throw new sdk_core_1.NotSupported('Invalid transaction, instruction program id not supported: ' + instruction.programId.toString());
287
328
  }
288
329
  }
289
- exports.getInstructionType = getInstructionType;
290
330
  /**
291
331
  * Validate solana instructions types to see if they are supported by the builder.
292
332
  * Throws if the instruction type is invalid.
@@ -301,21 +341,58 @@ function validateIntructionTypes(instructions) {
301
341
  }
302
342
  }
303
343
  }
304
- exports.validateIntructionTypes = validateIntructionTypes;
344
+ /**
345
+ * Validate solana instructions match raw msg authorize transaction
346
+ *
347
+ * @param {TransactionInstruction} instructions - a solana instruction
348
+ * @returns {boolean} true if the instructions match the raw msg authorize transaction
349
+ */
350
+ function validateRawMsgInstruction(instructions) {
351
+ // as web3.js cannot decode authorize instruction from CLI, we need to check it manually first
352
+ if (instructions.length === 2) {
353
+ const programId1 = instructions[0].programId.toString();
354
+ const programId2 = instructions[1].programId.toString();
355
+ if (programId1 === web3_js_1.SystemProgram.programId.toString() && programId2 === web3_js_1.StakeProgram.programId.toString()) {
356
+ const instructionName1 = web3_js_1.SystemInstruction.decodeInstructionType(instructions[0]);
357
+ const data = instructions[1].data.toString('hex');
358
+ if (instructionName1 === constants_1.nonceAdvanceInstruction &&
359
+ (data === constants_1.validInstructionData || data === constants_1.validInstructionData2)) {
360
+ return true;
361
+ }
362
+ }
363
+ }
364
+ if (instructions.length === 3) {
365
+ const programId1 = instructions[0].programId.toString();
366
+ const programId2 = instructions[1].programId.toString();
367
+ const programId3 = instructions[2].programId.toString();
368
+ if (programId1 === web3_js_1.SystemProgram.programId.toString() &&
369
+ programId2 === web3_js_1.StakeProgram.programId.toString() &&
370
+ programId3 === web3_js_1.StakeProgram.programId.toString()) {
371
+ const instructionName1 = web3_js_1.SystemInstruction.decodeInstructionType(instructions[0]);
372
+ const data = instructions[1].data.toString('hex');
373
+ const data2 = instructions[2].data.toString('hex');
374
+ if (instructionName1 === constants_1.nonceAdvanceInstruction &&
375
+ (data === constants_1.validInstructionData || data === constants_1.validInstructionData2) &&
376
+ (data2 === constants_1.validInstructionData || data2 === constants_1.validInstructionData2)) {
377
+ return true;
378
+ }
379
+ }
380
+ }
381
+ return false;
382
+ }
305
383
  /**
306
384
  * Check the raw transaction has a valid format in the blockchain context, throw otherwise.
307
385
  *
308
386
  * @param {string} rawTransaction - Transaction in base64 string format
309
387
  */
310
- function validateRawTransaction(rawTransaction) {
388
+ function validateRawTransaction(rawTransaction, requireAllSignatures = false, verifySignatures = false) {
311
389
  if (!rawTransaction) {
312
390
  throw new sdk_core_1.ParseTransactionError('Invalid raw transaction: Undefined');
313
391
  }
314
- if (!isValidRawTransaction(rawTransaction)) {
392
+ if (!isValidRawTransaction(rawTransaction, requireAllSignatures, verifySignatures)) {
315
393
  throw new sdk_core_1.ParseTransactionError('Invalid raw transaction');
316
394
  }
317
395
  }
318
- exports.validateRawTransaction = validateRawTransaction;
319
396
  /**
320
397
  * Validates address to check if it exists and is a valid Solana public key
321
398
  *
@@ -327,7 +404,6 @@ function validateAddress(address, fieldName) {
327
404
  throw new sdk_core_1.BuildTransactionError(`Invalid or missing ${fieldName}, got: ${address}`);
328
405
  }
329
406
  }
330
- exports.validateAddress = validateAddress;
331
407
  /**
332
408
  * Get the statics coin object matching a given Solana token address if it exists
333
409
  *
@@ -345,12 +421,11 @@ function getSolTokenFromAddress(tokenAddress, network) {
345
421
  const tokensArray = tokens.map((token) => token);
346
422
  if (tokensArray.length >= 1) {
347
423
  // there should never be two tokens with the same contract address, so we assert that here
348
- assert_1.default(tokensArray.length === 1);
424
+ (0, assert_1.default)(tokensArray.length === 1);
349
425
  return tokensArray[0];
350
426
  }
351
427
  return undefined;
352
428
  }
353
- exports.getSolTokenFromAddress = getSolTokenFromAddress;
354
429
  /**
355
430
  * Get the solana token object from token name
356
431
  * @param tokenName The token name to match against
@@ -370,33 +445,29 @@ function getSolTokenFromTokenName(tokenName) {
370
445
  return undefined;
371
446
  }
372
447
  }
373
- exports.getSolTokenFromTokenName = getSolTokenFromTokenName;
374
448
  /**
375
449
  * Get the solana associated token account address
376
- * @param tokenAddress The token address
450
+ * @param tokenAddress token mint address
377
451
  * @param ownerAddress The owner of the associated token account
378
452
  * @returns The associated token account address
379
453
  * */
380
- async function getAssociatedTokenAccountAddress(tokenAddress, ownerAddress) {
454
+ async function getAssociatedTokenAccountAddress(tokenMintAddress, ownerAddress, allowOwnerOffCurve = false) {
381
455
  const ownerPublicKey = new web3_js_1.PublicKey(ownerAddress);
382
456
  // tokenAddress are not on ed25519 curve, so they can't be used as ownerAddress
383
- if (!web3_js_1.PublicKey.isOnCurve(ownerPublicKey.toBuffer())) {
457
+ if (!allowOwnerOffCurve && !web3_js_1.PublicKey.isOnCurve(ownerPublicKey.toBuffer())) {
384
458
  throw new sdk_core_1.UtilsError('Invalid ownerAddress - address off ed25519 curve, got: ' + ownerAddress);
385
459
  }
386
- const ataAddress = await spl_token_1.getAssociatedTokenAddress(new web3_js_1.PublicKey(tokenAddress), ownerPublicKey);
460
+ const ataAddress = await (0, spl_token_1.getAssociatedTokenAddress)(new web3_js_1.PublicKey(tokenMintAddress), ownerPublicKey, allowOwnerOffCurve);
387
461
  return ataAddress.toString();
388
462
  }
389
- exports.getAssociatedTokenAccountAddress = getAssociatedTokenAccountAddress;
390
463
  function validateMintAddress(mintAddress) {
391
464
  if (!mintAddress || !isValidAddress(mintAddress)) {
392
465
  throw new sdk_core_1.BuildTransactionError('Invalid or missing mintAddress, got: ' + mintAddress);
393
466
  }
394
467
  }
395
- exports.validateMintAddress = validateMintAddress;
396
468
  function validateOwnerAddress(ownerAddress) {
397
469
  if (!ownerAddress || !isValidAddress(ownerAddress)) {
398
470
  throw new sdk_core_1.BuildTransactionError('Invalid or missing ownerAddress, got: ' + ownerAddress);
399
471
  }
400
472
  }
401
- exports.validateOwnerAddress = validateOwnerAddress;
402
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Keypair,\n  PublicKey,\n  SignaturePubkeyPair,\n  StakeInstruction,\n  StakeProgram,\n  SystemInstruction,\n  SystemProgram,\n  Transaction as SolTransaction,\n  TransactionInstruction,\n} from '@solana/web3.js';\nimport bs58 from 'bs58';\nimport BigNumber from 'bignumber.js';\nimport {\n  ataInitInstructionIndexes,\n  MAX_MEMO_LENGTH,\n  MEMO_PROGRAM_PK,\n  stakingActivateInstructionsIndexes,\n  stakingDeactivateInstructionsIndexes,\n  stakingPartialDeactivateInstructionsIndexes,\n  stakingWithdrawInstructionsIndexes,\n  stakingAuthorizeInstructionsIndexes,\n  VALID_SYSTEM_INSTRUCTION_TYPES,\n  ValidInstructionTypesEnum,\n  walletInitInstructionIndexes,\n} from './constants';\nimport {\n  BuildTransactionError,\n  isValidXpub,\n  NotSupported,\n  ParseTransactionError,\n  TransactionType,\n  UtilsError,\n} from '@bitgo-beta/sdk-core';\nimport { ValidInstructionTypes } from './iface';\nimport nacl from 'tweetnacl';\nimport { ASSOCIATED_TOKEN_PROGRAM_ID, TOKEN_PROGRAM_ID, getAssociatedTokenAddress } from '@solana/spl-token';\nimport { BaseCoin, BaseNetwork, CoinNotDefinedError, coins, SolCoin } from '@bitgo-beta/statics';\nimport assert from 'assert';\n\nconst DECODED_BLOCK_HASH_LENGTH = 32; // https://docs.solana.com/developing/programming-model/transactions#blockhash-format\nconst DECODED_SIGNATURE_LENGTH = 64; // https://docs.solana.com/terminology#signature\nconst BASE_58_ENCONDING_REGEX = '[1-9A-HJ-NP-Za-km-z]';\n\n/** @inheritdoc */\nexport function isValidAddress(address: string): boolean {\n  return isValidPublicKey(address);\n}\n\n/** @inheritdoc */\nexport function isValidBlockId(hash: string): boolean {\n  try {\n    return (\n      !!hash && new RegExp(BASE_58_ENCONDING_REGEX).test(hash) && bs58.decode(hash).length === DECODED_BLOCK_HASH_LENGTH\n    );\n  } catch (e) {\n    return false;\n  }\n}\n\n/** @inheritdoc */\nexport function isValidPrivateKey(prvKey: string | Uint8Array): boolean {\n  try {\n    const key: Uint8Array = typeof prvKey === 'string' ? base58ToUint8Array(prvKey) : prvKey;\n    return !!Keypair.fromSecretKey(key);\n  } catch (e) {\n    return false;\n  }\n}\n\n/** @inheritdoc */\nexport function isValidPublicKey(pubKey: string): boolean {\n  try {\n    if (isValidXpub(pubKey)) return true;\n    new PublicKey(pubKey);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/** @inheritdoc */\nexport function isValidSignature(signature: string): boolean {\n  try {\n    return !!signature && bs58.decode(signature).length === DECODED_SIGNATURE_LENGTH;\n  } catch (e) {\n    return false;\n  }\n}\n\n/** @inheritdoc */\n// TransactionId are the first signature on a Transaction\nexport function isValidTransactionId(txId: string): boolean {\n  return isValidSignature(txId);\n}\n\n/**\n * Returns whether or not the string is a valid amount of lamports number\n *\n * @param {string} amount - the string to validate\n * @returns {boolean} - the validation result\n */\nexport function isValidAmount(amount: string): boolean {\n  const bigNumberAmount = new BigNumber(amount);\n  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThanOrEqualTo(0);\n}\n\n/**\n * Check if the string is a valid amount of lamports number on staking\n *\n * @param {string} amount - the string to validate\n * @returns {boolean} - the validation result\n */\nexport function isValidStakingAmount(amount: string): boolean {\n  const bigNumberAmount = new BigNumber(amount);\n  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThan(0);\n}\n\n/**\n * Check if this is a valid memo or not.\n *\n * @param memo - the memo string\n * @returns {boolean} - the validation result\n */\nexport function isValidMemo(memo: string): boolean {\n  return Buffer.from(memo).length <= MAX_MEMO_LENGTH;\n}\n\n/**\n * Checks if raw transaction can be deserialized\n *\n * @param {string} rawTransaction - transaction in base64 string format\n * @returns {boolean} - the validation result\n */\nexport function isValidRawTransaction(rawTransaction: string): boolean {\n  try {\n    const tx = SolTransaction.from(Buffer.from(rawTransaction, 'base64'));\n    tx.serialize({ requireAllSignatures: false, verifySignatures: false });\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Verifies if signature for message is valid.\n *\n * @param {Buffer} serializedTx - tx as a base64 string\n * @param {string} signature - signature as a string\n * @param {string} publicKey - public key as base 58\n * @returns {Boolean} true if signature is valid.\n */\nexport function verifySignature(serializedTx: string, signature: string, publicKey: string): boolean {\n  if (!isValidRawTransaction(serializedTx)) {\n    throw new UtilsError('Invalid serializedTx');\n  }\n  if (!isValidPublicKey(publicKey)) {\n    throw new UtilsError('Invalid publicKey');\n  }\n  if (!isValidSignature(signature)) {\n    throw new UtilsError('Invalid signature');\n  }\n  const msg = SolTransaction.from(Buffer.from(serializedTx, 'base64')).serializeMessage();\n  const sig = base58ToUint8Array(signature);\n  const pub = new PublicKey(publicKey);\n  return nacl.sign.detached.verify(msg, sig, pub.toBuffer());\n}\n\n/**\n * Converts a base58 string into a Uint8Array.\n *\n * @param {string} input - a string in base58\n * @returns {Uint8Array} - an Uint8Array\n */\nexport function base58ToUint8Array(input: string): Uint8Array {\n  return new Uint8Array(bs58.decode(input));\n}\n\n/**\n * Converts a Uint8Array to a base58 string.\n *\n * @param {Uint8Array} input - an Uint8Array\n * @returns {string} - a string in base58\n */\nexport function Uint8ArrayTobase58(input: Uint8Array): string {\n  return bs58.encode(input);\n}\n\n/**\n * Count the amount of signatures are not null.\n *\n * @param {SignaturePubkeyPair[]} signatures - an array of SignaturePubkeyPair\n * @returns {number} - the amount of valid signatures\n */\nexport function countNotNullSignatures(signatures: SignaturePubkeyPair[]): number {\n  return signatures.filter((sig) => !!sig.signature).length;\n}\n\n/**\n * Check if all signatures are completed.\n *\n * @param {SignaturePubkeyPair[]} signatures - signatures\n * @returns {boolean}\n */\nexport function requiresAllSignatures(signatures: SignaturePubkeyPair[]): boolean {\n  return signatures.length > 0 && countNotNullSignatures(signatures) === signatures.length;\n}\n\n/**\n * Check the transaction type matching instructions by order. Memo and AdvanceNonceAccount instructions\n * are ignored.\n *\n * @param {TransactionInstruction[]} instructions - the array of supported Solana instructions to be parsed\n * @param {Record<string, number>} instructionIndexes - the instructions indexes of the current transaction\n * @returns true if it matches by order.\n */\nexport function matchTransactionTypeByInstructionsOrder(\n  instructions: TransactionInstruction[],\n  instructionIndexes: Record<string, number>\n): boolean {\n  const instructionsCopy = [...instructions]; // Make a copy since we may modify the array below\n  // AdvanceNonceAccount is optional and the first instruction added, it does not matter to match the type\n  if (instructionsCopy.length > 0) {\n    if (getInstructionType(instructions[0]) === 'AdvanceNonceAccount') {\n      instructionsCopy.shift();\n    }\n  }\n\n  // Memo is optional and the last instruction added, it does not matter to match the type\n  // Why have it in instructionKeys if we are going to ignore it?\n  const instructionsKeys = Object.keys(instructionIndexes);\n  if (instructionsKeys[instructionsKeys.length - 1] === 'Memo') {\n    instructionsKeys.pop();\n  }\n\n  // Check instructions by order using the index.\n  for (const keyName of instructionsKeys) {\n    const result = getInstructionType(instructionsCopy[instructionIndexes[keyName]]);\n    if (result !== keyName) {\n      return false;\n    }\n  }\n  return true;\n}\n\n/**\n * Returns the transaction Type based on the  transaction instructions.\n * Wallet initialization, Transfer and Staking transactions are supported.\n *\n * @param {SolTransaction} transaction - the solana transaction\n * @returns {TransactionType} - the type of transaction\n */\nexport function getTransactionType(transaction: SolTransaction): TransactionType {\n  const { instructions } = transaction;\n  validateIntructionTypes(instructions);\n  for (const instruction of instructions) {\n    const instructionType = getInstructionType(instruction);\n    if (\n      instructionType === ValidInstructionTypesEnum.Transfer ||\n      instructionType === ValidInstructionTypesEnum.TokenTransfer\n    ) {\n      return TransactionType.Send;\n    }\n  }\n  if (matchTransactionTypeByInstructionsOrder(instructions, walletInitInstructionIndexes)) {\n    return TransactionType.WalletInitialization;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, stakingActivateInstructionsIndexes)) {\n    return TransactionType.StakingActivate;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, stakingAuthorizeInstructionsIndexes)) {\n    return TransactionType.StakingAuthorize;\n  } else if (\n    matchTransactionTypeByInstructionsOrder(instructions, stakingDeactivateInstructionsIndexes) ||\n    matchTransactionTypeByInstructionsOrder(instructions, stakingPartialDeactivateInstructionsIndexes)\n  ) {\n    return TransactionType.StakingDeactivate;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, stakingWithdrawInstructionsIndexes)) {\n    return TransactionType.StakingWithdraw;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, ataInitInstructionIndexes)) {\n    return TransactionType.AssociatedTokenAccountInitialization;\n  } else {\n    throw new NotSupported('Invalid transaction, transaction not supported or invalid');\n  }\n}\n\n/**\n * Returns the instruction Type based on the solana instructions.\n * Throws if the solana instruction program is not supported\n *\n * @param {TransactionInstruction} instruction - a solana instruction\n * @returns {ValidInstructionTypes} - a solana instruction type\n */\nexport function getInstructionType(instruction: TransactionInstruction): ValidInstructionTypes {\n  switch (instruction.programId.toString()) {\n    case new PublicKey(MEMO_PROGRAM_PK).toString():\n      return 'Memo';\n    case SystemProgram.programId.toString():\n      return SystemInstruction.decodeInstructionType(instruction);\n    case TOKEN_PROGRAM_ID.toString():\n      return 'TokenTransfer';\n    case StakeProgram.programId.toString():\n      return StakeInstruction.decodeInstructionType(instruction);\n    case ASSOCIATED_TOKEN_PROGRAM_ID.toString():\n      // TODO: change this when @spl-token supports decoding associated token instructions\n      if (instruction.data.length === 0) {\n        return 'InitializeAssociatedTokenAccount';\n      } else {\n        throw new NotSupported(\n          'Invalid transaction, instruction program id not supported: ' + instruction.programId.toString()\n        );\n      }\n    default:\n      throw new NotSupported(\n        'Invalid transaction, instruction program id not supported: ' + instruction.programId.toString()\n      );\n  }\n}\n\n/**\n * Validate solana instructions types to see if they are supported by the builder.\n * Throws if the instruction type is invalid.\n *\n * @param {TransactionInstruction} instructions - a solana instruction\n * @returns {void}\n */\nexport function validateIntructionTypes(instructions: TransactionInstruction[]): void {\n  for (const instruction of instructions) {\n    if (!VALID_SYSTEM_INSTRUCTION_TYPES.includes(getInstructionType(instruction))) {\n      throw new NotSupported('Invalid transaction, instruction type not supported: ' + getInstructionType(instruction));\n    }\n  }\n}\n\n/**\n * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n *\n * @param {string} rawTransaction - Transaction in base64 string  format\n */\nexport function validateRawTransaction(rawTransaction: string): void {\n  if (!rawTransaction) {\n    throw new ParseTransactionError('Invalid raw transaction: Undefined');\n  }\n  if (!isValidRawTransaction(rawTransaction)) {\n    throw new ParseTransactionError('Invalid raw transaction');\n  }\n}\n\n/**\n * Validates address to check if it exists and is a valid Solana public key\n *\n * @param {string} address The address to be validated\n * @param {string} fieldName Name of the field to validate, its needed to return which field is failing on case of error.\n */\nexport function validateAddress(address: string, fieldName: string): void {\n  if (!address || !isValidPublicKey(address)) {\n    throw new BuildTransactionError(`Invalid or missing ${fieldName}, got: ${address}`);\n  }\n}\n\n/**\n * Get the statics coin object matching a given Solana token address if it exists\n *\n * @param tokenAddress The token address to match against\n * @param network Solana Mainnet or Testnet\n * @returns statics BaseCoin object for the matching token\n */\nexport function getSolTokenFromAddress(tokenAddress: string, network: BaseNetwork): Readonly<BaseCoin> | undefined {\n  const tokens = coins.filter((coin) => {\n    if (coin instanceof SolCoin) {\n      return coin.network.type === network.type && coin.tokenAddress.toLowerCase() === tokenAddress.toLowerCase();\n    }\n    return false;\n  });\n  const tokensArray = tokens.map((token) => token);\n  if (tokensArray.length >= 1) {\n    // there should never be two tokens with the same contract address, so we assert that here\n    assert(tokensArray.length === 1);\n    return tokensArray[0];\n  }\n  return undefined;\n}\n\n/**\n * Get the solana token object from token name\n * @param tokenName The token name to match against\n * */\nexport function getSolTokenFromTokenName(tokenName: string): Readonly<SolCoin> | undefined {\n  try {\n    const token = coins.get(tokenName);\n    if (!(token.isToken && token instanceof SolCoin)) {\n      return undefined;\n    }\n    return token;\n  } catch (e) {\n    if (!(e instanceof CoinNotDefinedError)) {\n      throw e;\n    }\n    return undefined;\n  }\n}\n\n/**\n * Get the solana associated token account address\n * @param tokenAddress The token address\n * @param ownerAddress The owner of the associated token account\n * @returns The associated token account address\n * */\nexport async function getAssociatedTokenAccountAddress(tokenAddress: string, ownerAddress: string): Promise<string> {\n  const ownerPublicKey = new PublicKey(ownerAddress);\n\n  // tokenAddress are not on ed25519 curve, so they can't be used as ownerAddress\n  if (!PublicKey.isOnCurve(ownerPublicKey.toBuffer())) {\n    throw new UtilsError('Invalid ownerAddress - address off ed25519 curve, got: ' + ownerAddress);\n  }\n  const ataAddress = await getAssociatedTokenAddress(new PublicKey(tokenAddress), ownerPublicKey);\n  return ataAddress.toString();\n}\n\nexport function validateMintAddress(mintAddress: string) {\n  if (!mintAddress || !isValidAddress(mintAddress)) {\n    throw new BuildTransactionError('Invalid or missing mintAddress, got: ' + mintAddress);\n  }\n}\n\nexport function validateOwnerAddress(ownerAddress: string) {\n  if (!ownerAddress || !isValidAddress(ownerAddress)) {\n    throw new BuildTransactionError('Invalid or missing ownerAddress, got: ' + ownerAddress);\n  }\n}\n"]}
473
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BuildTransactionError,\n  isValidXpub,\n  NotSupported,\n  ParseTransactionError,\n  TransactionType,\n  UtilsError,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin, BaseNetwork, CoinNotDefinedError, coins, SolCoin } from '@bitgo-beta/statics';\nimport {\n  ASSOCIATED_TOKEN_PROGRAM_ID,\n  decodeCloseAccountInstruction,\n  getAssociatedTokenAddress,\n  TOKEN_PROGRAM_ID,\n} from '@solana/spl-token';\nimport {\n  Keypair,\n  PublicKey,\n  SignaturePubkeyPair,\n  Transaction as SolTransaction,\n  StakeInstruction,\n  StakeProgram,\n  SystemInstruction,\n  SystemProgram,\n  TransactionInstruction,\n} from '@solana/web3.js';\nimport assert from 'assert';\nimport BigNumber from 'bignumber.js';\nimport bs58 from 'bs58';\nimport nacl from 'tweetnacl';\nimport {\n  ataCloseInstructionIndexes,\n  ataInitInstructionIndexes,\n  MAX_MEMO_LENGTH,\n  MEMO_PROGRAM_PK,\n  nonceAdvanceInstruction,\n  stakingActivateInstructionsIndexes,\n  marinadeStakingActivateInstructionsIndexes,\n  stakingAuthorizeInstructionsIndexes,\n  stakingDeactivateInstructionsIndexes,\n  marinadeStakingDeactivateInstructionsIndexes,\n  stakingDelegateInstructionsIndexes,\n  stakingPartialDeactivateInstructionsIndexes,\n  stakingWithdrawInstructionsIndexes,\n  VALID_SYSTEM_INSTRUCTION_TYPES,\n  validInstructionData,\n  validInstructionData2,\n  ValidInstructionTypesEnum,\n  walletInitInstructionIndexes,\n} from './constants';\nimport { ValidInstructionTypes } from './iface';\n\nconst DECODED_BLOCK_HASH_LENGTH = 32; // https://docs.solana.com/developing/programming-model/transactions#blockhash-format\nconst DECODED_SIGNATURE_LENGTH = 64; // https://docs.solana.com/terminology#signature\nconst BASE_58_ENCONDING_REGEX = '[1-9A-HJ-NP-Za-km-z]';\nconst COMPUTE_BUDGET = 'ComputeBudget111111111111111111111111111111';\n\n/** @inheritdoc */\nexport function isValidAddress(address: string): boolean {\n  return isValidPublicKey(address);\n}\n\n/** @inheritdoc */\nexport function isValidBlockId(hash: string): boolean {\n  try {\n    return (\n      !!hash && new RegExp(BASE_58_ENCONDING_REGEX).test(hash) && bs58.decode(hash).length === DECODED_BLOCK_HASH_LENGTH\n    );\n  } catch (e) {\n    return false;\n  }\n}\n\n/** @inheritdoc */\nexport function isValidPrivateKey(prvKey: string | Uint8Array): boolean {\n  try {\n    const key: Uint8Array = typeof prvKey === 'string' ? base58ToUint8Array(prvKey) : prvKey;\n    return !!Keypair.fromSecretKey(key);\n  } catch (e) {\n    return false;\n  }\n}\n\n/** @inheritdoc */\nexport function isValidPublicKey(pubKey: string): boolean {\n  try {\n    if (isValidXpub(pubKey)) return true;\n    new PublicKey(pubKey);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/** @inheritdoc */\nexport function isValidSignature(signature: string): boolean {\n  try {\n    return !!signature && bs58.decode(signature).length === DECODED_SIGNATURE_LENGTH;\n  } catch (e) {\n    return false;\n  }\n}\n\n/** @inheritdoc */\n// TransactionId are the first signature on a Transaction\nexport function isValidTransactionId(txId: string): boolean {\n  return isValidSignature(txId);\n}\n\n/**\n * Returns whether or not the string is a valid amount of lamports number\n *\n * @param {string} amount - the string to validate\n * @returns {boolean} - the validation result\n */\nexport function isValidAmount(amount: string): boolean {\n  const bigNumberAmount = new BigNumber(amount);\n  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThanOrEqualTo(0);\n}\n\n/**\n * Check if the string is a valid amount of lamports number on staking\n *\n * @param {string} amount - the string to validate\n * @returns {boolean} - the validation result\n */\nexport function isValidStakingAmount(amount: string): boolean {\n  const bigNumberAmount = new BigNumber(amount);\n  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThan(0);\n}\n\n/**\n * Check if this is a valid memo or not.\n *\n * @param memo - the memo string\n * @returns {boolean} - the validation result\n */\nexport function isValidMemo(memo: string): boolean {\n  return Buffer.from(memo).length <= MAX_MEMO_LENGTH;\n}\n\n/**\n * Checks if raw transaction can be deserialized\n *\n * @param {string} rawTransaction - transaction in base64 string format\n * @param {boolean} requireAllSignatures - require all signatures to be present\n * @param {boolean} verifySignatures - verify signatures\n * @returns {boolean} - the validation result\n */\nexport function isValidRawTransaction(\n  rawTransaction: string,\n  requireAllSignatures = false,\n  verifySignatures = false\n): boolean {\n  try {\n    const tx = SolTransaction.from(Buffer.from(rawTransaction, 'base64'));\n    tx.serialize({ requireAllSignatures, verifySignatures });\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Verifies if signature for message is valid.\n *\n * @param {Buffer} serializedTx - tx as a base64 string\n * @param {string} signature - signature as a string\n * @param {string} publicKey - public key as base 58\n * @returns {Boolean} true if signature is valid.\n */\nexport function verifySignature(serializedTx: string, signature: string, publicKey: string): boolean {\n  if (!isValidRawTransaction(serializedTx)) {\n    throw new UtilsError('Invalid serializedTx');\n  }\n  if (!isValidPublicKey(publicKey)) {\n    throw new UtilsError('Invalid publicKey');\n  }\n  if (!isValidSignature(signature)) {\n    throw new UtilsError('Invalid signature');\n  }\n  const msg = SolTransaction.from(Buffer.from(serializedTx, 'base64')).serializeMessage();\n  const sig = base58ToUint8Array(signature);\n  const pub = new PublicKey(publicKey);\n  return nacl.sign.detached.verify(msg, sig, pub.toBuffer());\n}\n\n/**\n * Converts a base58 string into a Uint8Array.\n *\n * @param {string} input - a string in base58\n * @returns {Uint8Array} - an Uint8Array\n */\nexport function base58ToUint8Array(input: string): Uint8Array {\n  return new Uint8Array(bs58.decode(input));\n}\n\n/**\n * Converts a Uint8Array to a base58 string.\n *\n * @param {Uint8Array} input - an Uint8Array\n * @returns {string} - a string in base58\n */\nexport function Uint8ArrayTobase58(input: Uint8Array): string {\n  return bs58.encode(input);\n}\n\n/**\n * Count the amount of signatures are not null.\n *\n * @param {SignaturePubkeyPair[]} signatures - an array of SignaturePubkeyPair\n * @returns {number} - the amount of valid signatures\n */\nexport function countNotNullSignatures(signatures: SignaturePubkeyPair[]): number {\n  return signatures.filter((sig) => !!sig.signature).length;\n}\n\n/**\n * Check if all signatures are completed.\n *\n * @param {SignaturePubkeyPair[]} signatures - signatures\n * @returns {boolean}\n */\nexport function requiresAllSignatures(signatures: SignaturePubkeyPair[]): boolean {\n  return signatures.length > 0 && countNotNullSignatures(signatures) === signatures.length;\n}\n\n/**\n * Check the transaction type matching instructions by order. Memo and AdvanceNonceAccount instructions\n * are ignored.\n *\n * @param {TransactionInstruction[]} instructions - the array of supported Solana instructions to be parsed\n * @param {Record<string, number>} instructionIndexes - the instructions indexes of the current transaction\n * @returns true if it matches by order.\n */\nexport function matchTransactionTypeByInstructionsOrder(\n  instructions: TransactionInstruction[],\n  instructionIndexes: Record<string, number>\n): boolean {\n  const instructionsCopy = [...instructions]; // Make a copy since we may modify the array below\n  // AdvanceNonceAccount is optional and the first instruction added, it does not matter to match the type\n  if (instructionsCopy.length > 0) {\n    if (getInstructionType(instructions[0]) === 'AdvanceNonceAccount') {\n      instructionsCopy.shift();\n    }\n  }\n\n  // Memo is optional and the last instruction added, it does not matter to match the type\n  // Why have it in instructionKeys if we are going to ignore it?\n  const instructionsKeys = Object.keys(instructionIndexes);\n  if (instructionsKeys[instructionsKeys.length - 1] === 'Memo') {\n    instructionsKeys.pop();\n  }\n\n  // Check instructions by order using the index.\n  for (const keyName of instructionsKeys) {\n    const result = getInstructionType(instructionsCopy[instructionIndexes[keyName]]);\n    if (result !== keyName) {\n      return false;\n    }\n  }\n  return true;\n}\n\n/**\n * Returns the transaction Type based on the  transaction instructions.\n * Wallet initialization, Transfer and Staking transactions are supported.\n *\n * @param {SolTransaction} transaction - the solana transaction\n * @returns {TransactionType} - the type of transaction\n */\nexport function getTransactionType(transaction: SolTransaction): TransactionType {\n  const { instructions } = transaction;\n  if (validateRawMsgInstruction(instructions)) {\n    return TransactionType.StakingAuthorizeRaw;\n  }\n  validateIntructionTypes(instructions);\n  // check if deactivate instruction does not exist because deactivate can be include a transfer instruction\n  const memoInstruction = instructions.find((instruction) => getInstructionType(instruction) === 'Memo');\n  const memoData = memoInstruction?.data.toString('utf-8');\n  if (instructions.filter((instruction) => getInstructionType(instruction) === 'Deactivate').length == 0) {\n    for (const instruction of instructions) {\n      const instructionType = getInstructionType(instruction);\n      // Check if memo instruction is there and if it contains 'PrepareForRevoke' because Marinade staking deactivate transaction will have this\n      if (\n        (instructionType === ValidInstructionTypesEnum.Transfer && !memoData?.includes('PrepareForRevoke')) ||\n        instructionType === ValidInstructionTypesEnum.TokenTransfer\n      ) {\n        return TransactionType.Send;\n      }\n    }\n  }\n  if (matchTransactionTypeByInstructionsOrder(instructions, walletInitInstructionIndexes)) {\n    return TransactionType.WalletInitialization;\n  } else if (\n    matchTransactionTypeByInstructionsOrder(instructions, marinadeStakingActivateInstructionsIndexes) ||\n    matchTransactionTypeByInstructionsOrder(instructions, stakingActivateInstructionsIndexes)\n  ) {\n    return TransactionType.StakingActivate;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, stakingAuthorizeInstructionsIndexes)) {\n    return TransactionType.StakingAuthorize;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, stakingDelegateInstructionsIndexes)) {\n    return TransactionType.StakingDelegate;\n  } else if (\n    matchTransactionTypeByInstructionsOrder(instructions, marinadeStakingDeactivateInstructionsIndexes) ||\n    matchTransactionTypeByInstructionsOrder(instructions, stakingDeactivateInstructionsIndexes) ||\n    matchTransactionTypeByInstructionsOrder(instructions, stakingPartialDeactivateInstructionsIndexes)\n  ) {\n    return TransactionType.StakingDeactivate;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, stakingWithdrawInstructionsIndexes)) {\n    return TransactionType.StakingWithdraw;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, ataInitInstructionIndexes)) {\n    return TransactionType.AssociatedTokenAccountInitialization;\n  } else if (matchTransactionTypeByInstructionsOrder(instructions, ataCloseInstructionIndexes)) {\n    return TransactionType.CloseAssociatedTokenAccount;\n  } else {\n    throw new NotSupported('Invalid transaction, transaction not supported or invalid');\n  }\n}\n\n/**\n * Returns the instruction Type based on the solana instructions.\n * Throws if the solana instruction program is not supported\n *\n * @param {TransactionInstruction} instruction - a solana instruction\n * @returns {ValidInstructionTypes} - a solana instruction type\n */\nexport function getInstructionType(instruction: TransactionInstruction): ValidInstructionTypes {\n  switch (instruction.programId.toString()) {\n    case new PublicKey(MEMO_PROGRAM_PK).toString():\n      return 'Memo';\n    case SystemProgram.programId.toString():\n      return SystemInstruction.decodeInstructionType(instruction);\n    case TOKEN_PROGRAM_ID.toString():\n      try {\n        const decodedInstruction = decodeCloseAccountInstruction(instruction);\n        if (decodedInstruction && decodedInstruction.data.instruction === 9) {\n          return 'CloseAssociatedTokenAccount';\n        }\n      } catch (e) {\n        // ignore error and default to TokenTransfer\n        return 'TokenTransfer';\n      }\n      return 'TokenTransfer';\n    case StakeProgram.programId.toString():\n      return StakeInstruction.decodeInstructionType(instruction);\n    case ASSOCIATED_TOKEN_PROGRAM_ID.toString():\n      // TODO: change this when @spl-token supports decoding associated token instructions\n      if (instruction.data.length === 0) {\n        return 'InitializeAssociatedTokenAccount';\n      } else {\n        throw new NotSupported(\n          'Invalid transaction, instruction program id not supported: ' + instruction.programId.toString()\n        );\n      }\n    case COMPUTE_BUDGET:\n      return 'SetPriorityFee';\n    default:\n      throw new NotSupported(\n        'Invalid transaction, instruction program id not supported: ' + instruction.programId.toString()\n      );\n  }\n}\n\n/**\n * Validate solana instructions types to see if they are supported by the builder.\n * Throws if the instruction type is invalid.\n *\n * @param {TransactionInstruction} instructions - a solana instruction\n * @returns {void}\n */\nexport function validateIntructionTypes(instructions: TransactionInstruction[]): void {\n  for (const instruction of instructions) {\n    if (!VALID_SYSTEM_INSTRUCTION_TYPES.includes(getInstructionType(instruction))) {\n      throw new NotSupported('Invalid transaction, instruction type not supported: ' + getInstructionType(instruction));\n    }\n  }\n}\n\n/**\n * Validate solana instructions match raw msg authorize transaction\n *\n * @param {TransactionInstruction} instructions - a solana instruction\n * @returns {boolean} true if the instructions match the raw msg authorize transaction\n */\nexport function validateRawMsgInstruction(instructions: TransactionInstruction[]): boolean {\n  // as web3.js cannot decode authorize instruction from CLI, we need to check it manually first\n  if (instructions.length === 2) {\n    const programId1 = instructions[0].programId.toString();\n    const programId2 = instructions[1].programId.toString();\n    if (programId1 === SystemProgram.programId.toString() && programId2 === StakeProgram.programId.toString()) {\n      const instructionName1 = SystemInstruction.decodeInstructionType(instructions[0]);\n      const data = instructions[1].data.toString('hex');\n      if (\n        instructionName1 === nonceAdvanceInstruction &&\n        (data === validInstructionData || data === validInstructionData2)\n      ) {\n        return true;\n      }\n    }\n  }\n  if (instructions.length === 3) {\n    const programId1 = instructions[0].programId.toString();\n    const programId2 = instructions[1].programId.toString();\n    const programId3 = instructions[2].programId.toString();\n    if (\n      programId1 === SystemProgram.programId.toString() &&\n      programId2 === StakeProgram.programId.toString() &&\n      programId3 === StakeProgram.programId.toString()\n    ) {\n      const instructionName1 = SystemInstruction.decodeInstructionType(instructions[0]);\n      const data = instructions[1].data.toString('hex');\n      const data2 = instructions[2].data.toString('hex');\n      if (\n        instructionName1 === nonceAdvanceInstruction &&\n        (data === validInstructionData || data === validInstructionData2) &&\n        (data2 === validInstructionData || data2 === validInstructionData2)\n      ) {\n        return true;\n      }\n    }\n  }\n  return false;\n}\n/**\n * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n *\n * @param {string} rawTransaction - Transaction in base64 string  format\n */\nexport function validateRawTransaction(\n  rawTransaction: string,\n  requireAllSignatures = false,\n  verifySignatures = false\n): void {\n  if (!rawTransaction) {\n    throw new ParseTransactionError('Invalid raw transaction: Undefined');\n  }\n  if (!isValidRawTransaction(rawTransaction, requireAllSignatures, verifySignatures)) {\n    throw new ParseTransactionError('Invalid raw transaction');\n  }\n}\n\n/**\n * Validates address to check if it exists and is a valid Solana public key\n *\n * @param {string} address The address to be validated\n * @param {string} fieldName Name of the field to validate, its needed to return which field is failing on case of error.\n */\nexport function validateAddress(address: string, fieldName: string): void {\n  if (!address || !isValidPublicKey(address)) {\n    throw new BuildTransactionError(`Invalid or missing ${fieldName}, got: ${address}`);\n  }\n}\n\n/**\n * Get the statics coin object matching a given Solana token address if it exists\n *\n * @param tokenAddress The token address to match against\n * @param network Solana Mainnet or Testnet\n * @returns statics BaseCoin object for the matching token\n */\nexport function getSolTokenFromAddress(tokenAddress: string, network: BaseNetwork): Readonly<BaseCoin> | undefined {\n  const tokens = coins.filter((coin) => {\n    if (coin instanceof SolCoin) {\n      return coin.network.type === network.type && coin.tokenAddress.toLowerCase() === tokenAddress.toLowerCase();\n    }\n    return false;\n  });\n  const tokensArray = tokens.map((token) => token);\n  if (tokensArray.length >= 1) {\n    // there should never be two tokens with the same contract address, so we assert that here\n    assert(tokensArray.length === 1);\n    return tokensArray[0];\n  }\n  return undefined;\n}\n\n/**\n * Get the solana token object from token name\n * @param tokenName The token name to match against\n * */\nexport function getSolTokenFromTokenName(tokenName: string): Readonly<SolCoin> | undefined {\n  try {\n    const token = coins.get(tokenName);\n    if (!(token.isToken && token instanceof SolCoin)) {\n      return undefined;\n    }\n    return token;\n  } catch (e) {\n    if (!(e instanceof CoinNotDefinedError)) {\n      throw e;\n    }\n    return undefined;\n  }\n}\n\n/**\n * Get the solana associated token account address\n * @param tokenAddress token mint address\n * @param ownerAddress The owner of the associated token account\n * @returns The associated token account address\n * */\nexport async function getAssociatedTokenAccountAddress(\n  tokenMintAddress: string,\n  ownerAddress: string,\n  allowOwnerOffCurve = false\n): Promise<string> {\n  const ownerPublicKey = new PublicKey(ownerAddress);\n\n  // tokenAddress are not on ed25519 curve, so they can't be used as ownerAddress\n  if (!allowOwnerOffCurve && !PublicKey.isOnCurve(ownerPublicKey.toBuffer())) {\n    throw new UtilsError('Invalid ownerAddress - address off ed25519 curve, got: ' + ownerAddress);\n  }\n  const ataAddress = await getAssociatedTokenAddress(\n    new PublicKey(tokenMintAddress),\n    ownerPublicKey,\n    allowOwnerOffCurve\n  );\n  return ataAddress.toString();\n}\n\nexport function validateMintAddress(mintAddress: string) {\n  if (!mintAddress || !isValidAddress(mintAddress)) {\n    throw new BuildTransactionError('Invalid or missing mintAddress, got: ' + mintAddress);\n  }\n}\n\nexport function validateOwnerAddress(ownerAddress: string) {\n  if (!ownerAddress || !isValidAddress(ownerAddress)) {\n    throw new BuildTransactionError('Invalid or missing ownerAddress, got: ' + ownerAddress);\n  }\n}\n"]}
@@ -34,7 +34,7 @@ class WalletInitializationBuilder extends transactionBuilder_1.TransactionBuilde
34
34
  * @param amount amount in lamports to fund the nonce account
35
35
  */
36
36
  amount(amount) {
37
- if (!amount || !utils_1.isValidAmount(amount)) {
37
+ if (!amount || !(0, utils_1.isValidAmount)(amount)) {
38
38
  throw new sdk_core_1.BuildTransactionError('Invalid or missing amount, got: ' + amount);
39
39
  }
40
40
  this._amount = amount;
@@ -45,15 +45,15 @@ class WalletInitializationBuilder extends transactionBuilder_1.TransactionBuilde
45
45
  * @param nonceAddress address of the new nonce account
46
46
  */
47
47
  address(nonceAddress) {
48
- utils_1.validateAddress(nonceAddress, 'nonceAddress');
48
+ (0, utils_1.validateAddress)(nonceAddress, 'nonceAddress');
49
49
  this._nonceAddress = nonceAddress;
50
50
  return this;
51
51
  }
52
52
  /** @inheritdoc */
53
53
  async buildImplementation() {
54
- assert_1.default(this._sender, 'Sender must be set before building the transaction');
55
- assert_1.default(this._amount, 'Amount must be set before building the transaction');
56
- assert_1.default(this._nonceAddress, 'Nonce Address must be set before building the transaction');
54
+ (0, assert_1.default)(this._sender, 'Sender must be set before building the transaction');
55
+ (0, assert_1.default)(this._amount, 'Amount must be set before building the transaction');
56
+ (0, assert_1.default)(this._nonceAddress, 'Nonce Address must be set before building the transaction');
57
57
  const walletInitData = {
58
58
  type: constants_1.InstructionBuilderTypes.CreateNonceAccount,
59
59
  params: {
@@ -68,4 +68,4 @@ class WalletInitializationBuilder extends transactionBuilder_1.TransactionBuilde
68
68
  }
69
69
  }
70
70
  exports.WalletInitializationBuilder = WalletInitializationBuilder;
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2FsbGV0SW5pdGlhbGl6YXRpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi93YWxsZXRJbml0aWFsaXphdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsb0RBQTRCO0FBRzVCLG1EQUE4RTtBQUU5RSw2REFBMEQ7QUFDMUQsbUNBQXlEO0FBRXpELDJDQUFzRDtBQUV0RCxNQUFhLDJCQUE0QixTQUFRLHVDQUFrQjtJQUlqRSxZQUFZLFdBQWlDO1FBQzNDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNyQixDQUFDO0lBQ0QsSUFBYyxlQUFlO1FBQzNCLE9BQU8sMEJBQWUsQ0FBQyxvQkFBb0IsQ0FBQztJQUM5QyxDQUFDO0lBRUQsa0JBQWtCO0lBQ2xCLFdBQVcsQ0FBQyxFQUFlO1FBQ3pCLEtBQUssQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFdEIsS0FBSyxNQUFNLFdBQVcsSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUU7WUFDaEQsSUFBSSxXQUFXLENBQUMsSUFBSSxLQUFLLG1DQUF1QixDQUFDLGtCQUFrQixFQUFFO2dCQUNuRSxNQUFNLHFCQUFxQixHQUFlLFdBQVcsQ0FBQztnQkFFdEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7Z0JBQ3hELElBQUksQ0FBQyxNQUFNLENBQUMscUJBQXFCLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2dCQUNqRCxJQUFJLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQzthQUN2RDtTQUNGO0lBQ0gsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsTUFBYztRQUNuQixJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMscUJBQWEsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUNyQyxNQUFNLElBQUksZ0NBQXFCLENBQUMsa0NBQWtDLEdBQUcsTUFBTSxDQUFDLENBQUM7U0FDOUU7UUFFRCxJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUN0QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRDs7O09BR0c7SUFDSCxPQUFPLENBQUMsWUFBb0I7UUFDMUIsdUJBQWUsQ0FBQyxZQUFZLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFDOUMsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUM7UUFFbEMsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsa0JBQWtCO0lBQ1IsS0FBSyxDQUFDLG1CQUFtQjtRQUNqQyxnQkFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsb0RBQW9ELENBQUMsQ0FBQztRQUMzRSxnQkFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsb0RBQW9ELENBQUMsQ0FBQztRQUMzRSxnQkFBTSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsMkRBQTJELENBQUMsQ0FBQztRQUV4RixNQUFNLGNBQWMsR0FBZTtZQUNqQyxJQUFJLEVBQUUsbUNBQXVCLENBQUMsa0JBQWtCO1lBQ2hELE1BQU0sRUFBRTtnQkFDTixXQUFXLEVBQUUsSUFBSSxDQUFDLE9BQU87Z0JBQ3pCLFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYTtnQkFDaEMsV0FBVyxFQUFFLElBQUksQ0FBQyxPQUFPO2dCQUN6QixNQUFNLEVBQUUsSUFBSSxDQUFDLE9BQU87YUFDckI7U0FDRixDQUFDO1FBQ0YsSUFBSSxDQUFDLGlCQUFpQixHQUFHLENBQUMsY0FBYyxDQUFDLENBQUM7UUFFMUMsT0FBTyxNQUFNLEtBQUssQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO0lBQzNDLENBQUM7Q0FDRjtBQXRFRCxrRUFzRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCB7IEJhc2VDb2luIGFzIENvaW5Db25maWcgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7IEJ1aWxkVHJhbnNhY3Rpb25FcnJvciwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vdHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IGlzVmFsaWRBbW91bnQsIHZhbGlkYXRlQWRkcmVzcyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgV2FsbGV0SW5pdCB9IGZyb20gJy4vaWZhY2UnO1xuaW1wb3J0IHsgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRJbml0aWFsaXphdGlvbkJ1aWxkZXIgZXh0ZW5kcyBUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICBwcml2YXRlIF9ub25jZUFkZHJlc3M6IHN0cmluZztcbiAgcHJpdmF0ZSBfYW1vdW50OiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoX2NvaW5Db25maWc6IFJlYWRvbmx5PENvaW5Db25maWc+KSB7XG4gICAgc3VwZXIoX2NvaW5Db25maWcpO1xuICB9XG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5XYWxsZXRJbml0aWFsaXphdGlvbjtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICBpbml0QnVpbGRlcih0eDogVHJhbnNhY3Rpb24pOiB2b2lkIHtcbiAgICBzdXBlci5pbml0QnVpbGRlcih0eCk7XG5cbiAgICBmb3IgKGNvbnN0IGluc3RydWN0aW9uIG9mIHRoaXMuX2luc3RydWN0aW9uc0RhdGEpIHtcbiAgICAgIGlmIChpbnN0cnVjdGlvbi50eXBlID09PSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5DcmVhdGVOb25jZUFjY291bnQpIHtcbiAgICAgICAgY29uc3Qgd2FsbGV0SW5pdEluc3RydWN0aW9uOiBXYWxsZXRJbml0ID0gaW5zdHJ1Y3Rpb247XG5cbiAgICAgICAgdGhpcy5hZGRyZXNzKHdhbGxldEluaXRJbnN0cnVjdGlvbi5wYXJhbXMubm9uY2VBZGRyZXNzKTtcbiAgICAgICAgdGhpcy5hbW91bnQod2FsbGV0SW5pdEluc3RydWN0aW9uLnBhcmFtcy5hbW91bnQpO1xuICAgICAgICB0aGlzLnNlbmRlcih3YWxsZXRJbml0SW5zdHJ1Y3Rpb24ucGFyYW1zLmF1dGhBZGRyZXNzKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgYW1vdW50IHRvIGZ1bmQgdGhlIG5vbmNlIGFjY291bnRcbiAgICpcbiAgICogQHBhcmFtIGFtb3VudCBhbW91bnQgaW4gbGFtcG9ydHMgdG8gZnVuZCB0aGUgbm9uY2UgYWNjb3VudFxuICAgKi9cbiAgYW1vdW50KGFtb3VudDogc3RyaW5nKTogdGhpcyB7XG4gICAgaWYgKCFhbW91bnQgfHwgIWlzVmFsaWRBbW91bnQoYW1vdW50KSkge1xuICAgICAgdGhyb3cgbmV3IEJ1aWxkVHJhbnNhY3Rpb25FcnJvcignSW52YWxpZCBvciBtaXNzaW5nIGFtb3VudCwgZ290OiAnICsgYW1vdW50KTtcbiAgICB9XG5cbiAgICB0aGlzLl9hbW91bnQgPSBhbW91bnQ7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgYWRkcmVzcyBmb3IgdGhlIG5vbmNlIGFjY291bnRcbiAgICogQHBhcmFtIG5vbmNlQWRkcmVzcyBhZGRyZXNzIG9mIHRoZSBuZXcgbm9uY2UgYWNjb3VudFxuICAgKi9cbiAgYWRkcmVzcyhub25jZUFkZHJlc3M6IHN0cmluZyk6IHRoaXMge1xuICAgIHZhbGlkYXRlQWRkcmVzcyhub25jZUFkZHJlc3MsICdub25jZUFkZHJlc3MnKTtcbiAgICB0aGlzLl9ub25jZUFkZHJlc3MgPSBub25jZUFkZHJlc3M7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBwcm90ZWN0ZWQgYXN5bmMgYnVpbGRJbXBsZW1lbnRhdGlvbigpOiBQcm9taXNlPFRyYW5zYWN0aW9uPiB7XG4gICAgYXNzZXJ0KHRoaXMuX3NlbmRlciwgJ1NlbmRlciBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgYXNzZXJ0KHRoaXMuX2Ftb3VudCwgJ0Ftb3VudCBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgYXNzZXJ0KHRoaXMuX25vbmNlQWRkcmVzcywgJ05vbmNlIEFkZHJlc3MgbXVzdCBiZSBzZXQgYmVmb3JlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvbicpO1xuXG4gICAgY29uc3Qgd2FsbGV0SW5pdERhdGE6IFdhbGxldEluaXQgPSB7XG4gICAgICB0eXBlOiBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5DcmVhdGVOb25jZUFjY291bnQsXG4gICAgICBwYXJhbXM6IHtcbiAgICAgICAgZnJvbUFkZHJlc3M6IHRoaXMuX3NlbmRlcixcbiAgICAgICAgbm9uY2VBZGRyZXNzOiB0aGlzLl9ub25jZUFkZHJlc3MsXG4gICAgICAgIGF1dGhBZGRyZXNzOiB0aGlzLl9zZW5kZXIsXG4gICAgICAgIGFtb3VudDogdGhpcy5fYW1vdW50LFxuICAgICAgfSxcbiAgICB9O1xuICAgIHRoaXMuX2luc3RydWN0aW9uc0RhdGEgPSBbd2FsbGV0SW5pdERhdGFdO1xuXG4gICAgcmV0dXJuIGF3YWl0IHN1cGVyLmJ1aWxkSW1wbGVtZW50YXRpb24oKTtcbiAgfVxufVxuIl19
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2FsbGV0SW5pdGlhbGl6YXRpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi93YWxsZXRJbml0aWFsaXphdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsb0RBQTRCO0FBRzVCLG1EQUE4RTtBQUU5RSw2REFBMEQ7QUFDMUQsbUNBQXlEO0FBRXpELDJDQUFzRDtBQUV0RCxNQUFhLDJCQUE0QixTQUFRLHVDQUFrQjtJQUlqRSxZQUFZLFdBQWlDO1FBQzNDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNyQixDQUFDO0lBQ0QsSUFBYyxlQUFlO1FBQzNCLE9BQU8sMEJBQWUsQ0FBQyxvQkFBb0IsQ0FBQztJQUM5QyxDQUFDO0lBRUQsa0JBQWtCO0lBQ2xCLFdBQVcsQ0FBQyxFQUFlO1FBQ3pCLEtBQUssQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFdEIsS0FBSyxNQUFNLFdBQVcsSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUNqRCxJQUFJLFdBQVcsQ0FBQyxJQUFJLEtBQUssbUNBQXVCLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztnQkFDcEUsTUFBTSxxQkFBcUIsR0FBZSxXQUFXLENBQUM7Z0JBRXRELElBQUksQ0FBQyxPQUFPLENBQUMscUJBQXFCLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO2dCQUN4RCxJQUFJLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFDakQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDeEQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyxNQUFjO1FBQ25CLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFBLHFCQUFhLEVBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUN0QyxNQUFNLElBQUksZ0NBQXFCLENBQUMsa0NBQWtDLEdBQUcsTUFBTSxDQUFDLENBQUM7UUFDL0UsQ0FBQztRQUVELElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO1FBQ3RCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILE9BQU8sQ0FBQyxZQUFvQjtRQUMxQixJQUFBLHVCQUFlLEVBQUMsWUFBWSxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBQzlDLElBQUksQ0FBQyxhQUFhLEdBQUcsWUFBWSxDQUFDO1FBRWxDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELGtCQUFrQjtJQUNSLEtBQUssQ0FBQyxtQkFBbUI7UUFDakMsSUFBQSxnQkFBTSxFQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsb0RBQW9ELENBQUMsQ0FBQztRQUMzRSxJQUFBLGdCQUFNLEVBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxvREFBb0QsQ0FBQyxDQUFDO1FBQzNFLElBQUEsZ0JBQU0sRUFBQyxJQUFJLENBQUMsYUFBYSxFQUFFLDJEQUEyRCxDQUFDLENBQUM7UUFFeEYsTUFBTSxjQUFjLEdBQWU7WUFDakMsSUFBSSxFQUFFLG1DQUF1QixDQUFDLGtCQUFrQjtZQUNoRCxNQUFNLEVBQUU7Z0JBQ04sV0FBVyxFQUFFLElBQUksQ0FBQyxPQUFPO2dCQUN6QixZQUFZLEVBQUUsSUFBSSxDQUFDLGFBQWE7Z0JBQ2hDLFdBQVcsRUFBRSxJQUFJLENBQUMsT0FBTztnQkFDekIsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPO2FBQ3JCO1NBQ0YsQ0FBQztRQUNGLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRTFDLE9BQU8sTUFBTSxLQUFLLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztJQUMzQyxDQUFDO0NBQ0Y7QUF0RUQsa0VBc0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuXG5pbXBvcnQgeyBCYXNlQ29pbiBhcyBDb2luQ29uZmlnIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgeyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IsIFRyYW5zYWN0aW9uVHlwZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbic7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgeyBpc1ZhbGlkQW1vdW50LCB2YWxpZGF0ZUFkZHJlc3MgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IFdhbGxldEluaXQgfSBmcm9tICcuL2lmYWNlJztcbmltcG9ydCB7IEluc3RydWN0aW9uQnVpbGRlclR5cGVzIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuXG5leHBvcnQgY2xhc3MgV2FsbGV0SW5pdGlhbGl6YXRpb25CdWlsZGVyIGV4dGVuZHMgVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgcHJpdmF0ZSBfbm9uY2VBZGRyZXNzOiBzdHJpbmc7XG4gIHByaXZhdGUgX2Ftb3VudDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgfVxuICBwcm90ZWN0ZWQgZ2V0IHRyYW5zYWN0aW9uVHlwZSgpOiBUcmFuc2FjdGlvblR5cGUge1xuICAgIHJldHVybiBUcmFuc2FjdGlvblR5cGUuV2FsbGV0SW5pdGlhbGl6YXRpb247XG4gIH1cblxuICAvKiogQGluaGVyaXREb2MgKi9cbiAgaW5pdEJ1aWxkZXIodHg6IFRyYW5zYWN0aW9uKTogdm9pZCB7XG4gICAgc3VwZXIuaW5pdEJ1aWxkZXIodHgpO1xuXG4gICAgZm9yIChjb25zdCBpbnN0cnVjdGlvbiBvZiB0aGlzLl9pbnN0cnVjdGlvbnNEYXRhKSB7XG4gICAgICBpZiAoaW5zdHJ1Y3Rpb24udHlwZSA9PT0gSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQ3JlYXRlTm9uY2VBY2NvdW50KSB7XG4gICAgICAgIGNvbnN0IHdhbGxldEluaXRJbnN0cnVjdGlvbjogV2FsbGV0SW5pdCA9IGluc3RydWN0aW9uO1xuXG4gICAgICAgIHRoaXMuYWRkcmVzcyh3YWxsZXRJbml0SW5zdHJ1Y3Rpb24ucGFyYW1zLm5vbmNlQWRkcmVzcyk7XG4gICAgICAgIHRoaXMuYW1vdW50KHdhbGxldEluaXRJbnN0cnVjdGlvbi5wYXJhbXMuYW1vdW50KTtcbiAgICAgICAgdGhpcy5zZW5kZXIod2FsbGV0SW5pdEluc3RydWN0aW9uLnBhcmFtcy5hdXRoQWRkcmVzcyk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGFtb3VudCB0byBmdW5kIHRoZSBub25jZSBhY2NvdW50XG4gICAqXG4gICAqIEBwYXJhbSBhbW91bnQgYW1vdW50IGluIGxhbXBvcnRzIHRvIGZ1bmQgdGhlIG5vbmNlIGFjY291bnRcbiAgICovXG4gIGFtb3VudChhbW91bnQ6IHN0cmluZyk6IHRoaXMge1xuICAgIGlmICghYW1vdW50IHx8ICFpc1ZhbGlkQW1vdW50KGFtb3VudCkpIHtcbiAgICAgIHRocm93IG5ldyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IoJ0ludmFsaWQgb3IgbWlzc2luZyBhbW91bnQsIGdvdDogJyArIGFtb3VudCk7XG4gICAgfVxuXG4gICAgdGhpcy5fYW1vdW50ID0gYW1vdW50O1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGFkZHJlc3MgZm9yIHRoZSBub25jZSBhY2NvdW50XG4gICAqIEBwYXJhbSBub25jZUFkZHJlc3MgYWRkcmVzcyBvZiB0aGUgbmV3IG5vbmNlIGFjY291bnRcbiAgICovXG4gIGFkZHJlc3Mobm9uY2VBZGRyZXNzOiBzdHJpbmcpOiB0aGlzIHtcbiAgICB2YWxpZGF0ZUFkZHJlc3Mobm9uY2VBZGRyZXNzLCAnbm9uY2VBZGRyZXNzJyk7XG4gICAgdGhpcy5fbm9uY2VBZGRyZXNzID0gbm9uY2VBZGRyZXNzO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGJ1aWxkSW1wbGVtZW50YXRpb24oKTogUHJvbWlzZTxUcmFuc2FjdGlvbj4ge1xuICAgIGFzc2VydCh0aGlzLl9zZW5kZXIsICdTZW5kZXIgbXVzdCBiZSBzZXQgYmVmb3JlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvbicpO1xuICAgIGFzc2VydCh0aGlzLl9hbW91bnQsICdBbW91bnQgbXVzdCBiZSBzZXQgYmVmb3JlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvbicpO1xuICAgIGFzc2VydCh0aGlzLl9ub25jZUFkZHJlc3MsICdOb25jZSBBZGRyZXNzIG11c3QgYmUgc2V0IGJlZm9yZSBidWlsZGluZyB0aGUgdHJhbnNhY3Rpb24nKTtcblxuICAgIGNvbnN0IHdhbGxldEluaXREYXRhOiBXYWxsZXRJbml0ID0ge1xuICAgICAgdHlwZTogSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQ3JlYXRlTm9uY2VBY2NvdW50LFxuICAgICAgcGFyYW1zOiB7XG4gICAgICAgIGZyb21BZGRyZXNzOiB0aGlzLl9zZW5kZXIsXG4gICAgICAgIG5vbmNlQWRkcmVzczogdGhpcy5fbm9uY2VBZGRyZXNzLFxuICAgICAgICBhdXRoQWRkcmVzczogdGhpcy5fc2VuZGVyLFxuICAgICAgICBhbW91bnQ6IHRoaXMuX2Ftb3VudCxcbiAgICAgIH0sXG4gICAgfTtcbiAgICB0aGlzLl9pbnN0cnVjdGlvbnNEYXRhID0gW3dhbGxldEluaXREYXRhXTtcblxuICAgIHJldHVybiBhd2FpdCBzdXBlci5idWlsZEltcGxlbWVudGF0aW9uKCk7XG4gIH1cbn1cbiJdfQ==