@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.40 → 1.4.3-alpha.401

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 (42) hide show
  1. package/.mocharc.yml +1 -1
  2. package/CHANGELOG.md +678 -0
  3. package/package.json +12 -11
  4. package/dist/src/index.d.ts +0 -5
  5. package/dist/src/index.d.ts.map +0 -1
  6. package/dist/src/index.js +0 -30
  7. package/dist/src/lib/address.d.ts +0 -8
  8. package/dist/src/lib/address.d.ts.map +0 -1
  9. package/dist/src/lib/address.js +0 -10
  10. package/dist/src/lib/iface.d.ts +0 -115
  11. package/dist/src/lib/iface.d.ts.map +0 -1
  12. package/dist/src/lib/iface.js +0 -3
  13. package/dist/src/lib/index.d.ts +0 -10
  14. package/dist/src/lib/index.d.ts.map +0 -1
  15. package/dist/src/lib/index.js +0 -37
  16. package/dist/src/lib/keyPair.d.ts +0 -40
  17. package/dist/src/lib/keyPair.d.ts.map +0 -1
  18. package/dist/src/lib/keyPair.js +0 -135
  19. package/dist/src/lib/multisigUtils.d.ts +0 -134
  20. package/dist/src/lib/multisigUtils.d.ts.map +0 -1
  21. package/dist/src/lib/multisigUtils.js +0 -1180
  22. package/dist/src/lib/transaction.d.ts +0 -119
  23. package/dist/src/lib/transaction.d.ts.map +0 -1
  24. package/dist/src/lib/transaction.js +0 -315
  25. package/dist/src/lib/transactionBuilder.d.ts +0 -171
  26. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  27. package/dist/src/lib/transactionBuilder.js +0 -453
  28. package/dist/src/lib/transferBuilder.d.ts +0 -24
  29. package/dist/src/lib/transferBuilder.d.ts.map +0 -1
  30. package/dist/src/lib/transferBuilder.js +0 -64
  31. package/dist/src/lib/utils.d.ts +0 -265
  32. package/dist/src/lib/utils.d.ts.map +0 -1
  33. package/dist/src/lib/utils.js +0 -460
  34. package/dist/src/register.d.ts +0 -3
  35. package/dist/src/register.d.ts.map +0 -1
  36. package/dist/src/register.js +0 -11
  37. package/dist/src/txtz.d.ts +0 -13
  38. package/dist/src/txtz.d.ts.map +0 -1
  39. package/dist/src/txtz.js +0 -14
  40. package/dist/src/xtz.d.ts +0 -80
  41. package/dist/src/xtz.d.ts.map +0 -1
  42. package/dist/src/xtz.js +0 -189
@@ -1,1180 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- Object.defineProperty(exports, "__esModule", { value: true });
22
- exports.forwarderOriginationOperation = exports.getOwnersPublicKeys = exports.genericMultisigOriginationOperation = exports.revealOperation = exports.genericMultisigDataToSign = exports.getMultisigTransferSignatures = exports.updateMultisigTransferSignatures = exports.multisigTransactionOperation = exports.singlesigTransactionOperation = exports.getOriginationDataFromOperation = exports.getMultisigTransferDataFromOperation = void 0;
23
- const _ = __importStar(require("lodash"));
24
- const utils_1 = require("./utils");
25
- // Default n of m for multisig wallets
26
- const DEFAULT_N = 2;
27
- const DEFAULT_M = 3;
28
- /**
29
- * Helper method to get the transfer details from a generic multisig transaction operation.
30
- *
31
- * @param {TransactionOp} operation A transaction operation JSON
32
- * @returns {TransferData} Information about the destination, token and transfer amount
33
- */
34
- function getMultisigTransferDataFromOperation(operation) {
35
- const fee = {
36
- fee: operation.fee,
37
- gasLimit: operation.gas_limit,
38
- storageLimit: operation.storage_limit,
39
- };
40
- if (!operation.parameters) {
41
- // Singlesig transaction
42
- return {
43
- coin: 'mutez',
44
- from: operation.source,
45
- to: operation.destination,
46
- amount: operation.amount,
47
- fee,
48
- };
49
- }
50
- // These follow the structure from the response of genericMultisigTransferParams()
51
- const transferArgs = operation.parameters.value.args[0].args[1].args[0];
52
- const accountType = transferArgs[3].prim;
53
- const counter = operation.parameters.value.args[0].args[0].int;
54
- // In multisig transactions, the wallet contract is the destination
55
- const from = operation.destination;
56
- let accountTypeIndex;
57
- switch (accountType) {
58
- case 'IMPLICIT_ACCOUNT':
59
- accountTypeIndex = 4;
60
- break;
61
- case 'CONTRACT':
62
- accountTypeIndex = 5;
63
- break;
64
- default:
65
- throw new Error('Invalid contract parameters');
66
- }
67
- return {
68
- coin: transferArgs[accountTypeIndex].args[0].prim,
69
- from,
70
- to: transferArgs[2].args[1].string,
71
- amount: transferArgs[accountTypeIndex].args[1].int,
72
- fee,
73
- counter,
74
- };
75
- }
76
- exports.getMultisigTransferDataFromOperation = getMultisigTransferDataFromOperation;
77
- /**
78
- * Helper method to get the wallet or address initialization tx from an origination operation
79
- *
80
- * @param {OriginationOp} operation
81
- * @returns {OriginationData} Information about the wallet contract creating a forwarder contract
82
- */
83
- function getOriginationDataFromOperation(operation) {
84
- const fee = {
85
- fee: operation.fee,
86
- gasLimit: operation.gas_limit,
87
- storageLimit: operation.storage_limit,
88
- };
89
- const { source: from, counter, balance } = operation;
90
- // Transactions initializing a forwarder contract contain the address of the wallet contract
91
- const forwarderDestination = _.get(operation, 'script.code[2].args[0][3].args[0][0].args[1].string');
92
- return {
93
- fee,
94
- counter,
95
- balance,
96
- from,
97
- forwarderDestination,
98
- };
99
- }
100
- exports.getOriginationDataFromOperation = getOriginationDataFromOperation;
101
- /**
102
- * Helper method to build a singlesig transaction operation.
103
- *
104
- * @param {string} counter Source account next counter
105
- * @param {string} source The account that will pay for fees, and in singlesig transactions, where
106
- * the funds are taken from
107
- * @param {string} amount The amount in mutez to be transferred
108
- * @param {string} destination The account address to send the funds to
109
- * @param {string} fee Fees in mutez to pay by the source account
110
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
111
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
112
- * @returns {TransactionOp}A Tezos transaction operation
113
- */
114
- function singlesigTransactionOperation(counter, source, amount, destination, fee = utils_1.DEFAULT_FEE.TRANSFER.toString(), gasLimit = utils_1.DEFAULT_GAS_LIMIT.TRANSFER.toString(), storageLimit = utils_1.DEFAULT_STORAGE_LIMIT.TRANSFER.toString()) {
115
- return {
116
- kind: 'transaction',
117
- source,
118
- fee,
119
- counter,
120
- gas_limit: gasLimit,
121
- storage_limit: storageLimit,
122
- amount,
123
- destination,
124
- };
125
- }
126
- exports.singlesigTransactionOperation = singlesigTransactionOperation;
127
- /**
128
- * Create a multisig wallet transaction operation.
129
- *
130
- * @see {@link transactionOperation}
131
- * @param {string} counter Source account next counter
132
- * @param {string} source The account that will pay for fees, and in singlesig transactions, where
133
- * the funds are taken from
134
- * @param {string} amount The amount in mutez to be transferred
135
- * @param {string} contractAddress If it is a multisig transfer, the smart contract address with the
136
- * funds to be transferred from
137
- * @param {string} contractCounter If it is a multisig transfer, the smart contract counter to use
138
- * in the next transaction
139
- * @param {string} destinationAddress An implicit or originated address to transfer fudns to
140
- * @param {string[]} signatures signatures List of signatures authorizing the funds transfer form
141
- * the multisig wallet
142
- * @param {string} fee Fees in mutez to pay by the source account
143
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
144
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
145
- * @param {number} m The number of signers (owners) for the multisig wallet being used. Default is 3
146
- * @returns {TransactionOp} A Tezos operation with a generic multisig transfer
147
- */
148
- function multisigTransactionOperation(counter, source, amount, contractAddress, contractCounter, destinationAddress, signatures, fee = utils_1.DEFAULT_FEE.TRANSFER.toString(), gasLimit = utils_1.DEFAULT_GAS_LIMIT.TRANSFER.toString(), storageLimit = utils_1.DEFAULT_STORAGE_LIMIT.TRANSFER.toString(), m = DEFAULT_M) {
149
- return {
150
- kind: 'transaction',
151
- source,
152
- fee,
153
- counter,
154
- gas_limit: gasLimit,
155
- storage_limit: storageLimit,
156
- amount: '0',
157
- destination: contractAddress,
158
- parameters: genericMultisigTransferParams(destinationAddress, amount, contractCounter, signatures, m),
159
- };
160
- }
161
- exports.multisigTransactionOperation = multisigTransactionOperation;
162
- /**
163
- * Helper function to build the parameters to call the generic multisig smart contract with.
164
- *
165
- * @param {string} destinationAddress An implicit or originated address
166
- * @param {number} amount Number of Mutez to be transferred
167
- * @param {string} contractCounter Multisig contract counter number
168
- * @param {IndexedSignature[]} signatures List of transactions and their order
169
- * @param {number} m The multisig wallet total number of signers (owners)
170
- * @returns The parameters object
171
- */
172
- function genericMultisigTransferParams(destinationAddress, amount, contractCounter, signatures, m) {
173
- const transactionSignatures = buildSignatures(signatures);
174
- return {
175
- entrypoint: 'main',
176
- value: {
177
- prim: 'Pair',
178
- args: [
179
- {
180
- prim: 'Pair',
181
- args: [{ int: contractCounter }, { prim: 'Left', args: [transferToAccount(destinationAddress, amount)] }],
182
- },
183
- transactionSignatures,
184
- ],
185
- },
186
- };
187
- }
188
- /**
189
- * Replace the signatures in a multisig transaction operation with new ones.
190
- *
191
- * @param {TransactionOp} transaction Transaction to mutate
192
- * @param {IndexedSignature[]} signatures List of transactions and their order
193
- */
194
- function updateMultisigTransferSignatures(transaction, signatures) {
195
- transaction.parameters.value.args[1] = buildSignatures(signatures, transaction.parameters.value.args[1]);
196
- }
197
- exports.updateMultisigTransferSignatures = updateMultisigTransferSignatures;
198
- /**
199
- * Ge the list if multisig signatures if any in a convenient format.
200
- *
201
- * @param {TransactionOp} transaction The transaction to search the signatures in
202
- * @returns {IndexedSignature[]} A list of signatures and their order in teh transfer script
203
- */
204
- function getMultisigTransferSignatures(transaction) {
205
- const signatures = [];
206
- if (!transaction.parameters && !transaction.parameters.value && !transaction.parameters.value) {
207
- return [];
208
- }
209
- const rawSignatures = transaction.parameters.value.args[1];
210
- for (let i = 0; i < rawSignatures.length; i++) {
211
- if (rawSignatures[i].prim === 'Some') {
212
- signatures.push({
213
- signature: rawSignatures[i].args[0].string,
214
- index: i,
215
- });
216
- }
217
- }
218
- return signatures;
219
- }
220
- exports.getMultisigTransferSignatures = getMultisigTransferSignatures;
221
- /**
222
- * Build a list of ordered signatures, putting a None primitive for the missing indexes.
223
- *
224
- * @param {IndexedSignature[]} signatures List of transactions and their order
225
- * @param {number} m Size of the signature list
226
- * @param {any[]} existingSignatures List of existing signatures to merge with the generated ones
227
- * @returns {any[]} List of signatures in the right order
228
- */
229
- function buildSignatures(signatures, existingSignatures = [], m = DEFAULT_M) {
230
- // Initialize the array with the existing signatures and/or empty objects
231
- const transactionSignatures = existingSignatures;
232
- const size = existingSignatures.length;
233
- if (size > m) {
234
- throw new Error('Too many signatures. Expected less than ' + m + ' got ' + size);
235
- }
236
- for (let i = size; i < m; i++) {
237
- transactionSignatures.push({ prim: 'None' });
238
- }
239
- // Replace the empty signatures for the real ones based on the right index
240
- signatures.forEach((s) => {
241
- if (s.index) {
242
- transactionSignatures[s.index] = { prim: 'Some', args: [{ string: s.signature }] };
243
- }
244
- else {
245
- for (let i = 0; i < transactionSignatures.length; i++) {
246
- // Search for the first "null" signature
247
- if (transactionSignatures[i].prim === 'None') {
248
- transactionSignatures[i] = { prim: 'Some', args: [{ string: s.signature }] };
249
- break;
250
- }
251
- }
252
- }
253
- });
254
- return transactionSignatures;
255
- }
256
- /**
257
- * Helper function to build the Michelson script to be signed to transfer funds from a multisig
258
- * wallet.
259
- *
260
- * @param contractAddress The multisig smart contract address
261
- * @param {string} destinationAddress The destination account address (implicit or originated)
262
- * @param {number} amount Number of mutez to transfer
263
- * @param {string} contractCounter Wallet counter to use in the transaction
264
- * @returns A JSON representation of the Michelson script to sign and approve a transfer
265
- */
266
- function genericMultisigDataToSign(contractAddress, destinationAddress, amount, contractCounter) {
267
- const data = {
268
- prim: 'Pair',
269
- args: [
270
- { int: contractCounter },
271
- {
272
- prim: 'Left',
273
- args: [transferToAccount(destinationAddress, amount)],
274
- },
275
- ],
276
- };
277
- const type = {
278
- prim: 'pair',
279
- args: [
280
- {
281
- prim: 'nat',
282
- annots: ['%counter'],
283
- },
284
- {
285
- prim: 'or',
286
- args: [
287
- {
288
- prim: 'lambda',
289
- args: [
290
- { prim: 'unit' },
291
- {
292
- prim: 'list',
293
- args: [{ prim: 'operation' }],
294
- },
295
- ],
296
- annots: ['%operation'],
297
- },
298
- {
299
- prim: 'pair',
300
- args: [
301
- {
302
- prim: 'nat',
303
- annots: ['%threshold'],
304
- },
305
- {
306
- prim: 'list',
307
- args: [{ prim: 'key' }],
308
- annots: ['%keys'],
309
- },
310
- ],
311
- annots: ['%change_keys'],
312
- },
313
- ],
314
- annots: [':action'],
315
- },
316
- ],
317
- annots: [':payload'],
318
- };
319
- return buildPair(data, type, contractAddress);
320
- }
321
- exports.genericMultisigDataToSign = genericMultisigDataToSign;
322
- /**
323
- * Util function to build a Michelson Pair object.
324
- *
325
- * @param data
326
- * @param type
327
- * @param contractAddress
328
- */
329
- function buildPair(data, type, contractAddress) {
330
- return {
331
- data: {
332
- prim: 'Pair',
333
- args: [{ string: contractAddress }, data],
334
- },
335
- type: {
336
- prim: 'pair',
337
- args: [{ prim: 'address' }, type],
338
- },
339
- };
340
- }
341
- /**
342
- * Build the lambda for the multisig transaction transfer to an implicit or originated account.
343
- *
344
- * @param {string} address Account address to send the funds to
345
- * @param {string} amount The amount in mutez to transfer
346
- * @see {@link https://tezostaquito.io/docs/making_transfers#transfer-000005-50-mutez-tokens-from-a-kt1-address-to-a-tz1-address}
347
- */
348
- function transferToAccount(address, amount) {
349
- if (utils_1.isValidKey(address, utils_1.hashTypes.KT)) {
350
- return transferToOriginatedAccount(address, amount);
351
- }
352
- // Lambda to transfer to an implicit account
353
- return [
354
- { prim: 'DROP' },
355
- { prim: 'NIL', args: [{ prim: 'operation' }] },
356
- {
357
- prim: 'PUSH',
358
- args: [{ prim: 'key_hash' }, { string: address }],
359
- },
360
- { prim: 'IMPLICIT_ACCOUNT' },
361
- {
362
- prim: 'PUSH',
363
- args: [{ prim: 'mutez' }, { int: amount }],
364
- },
365
- { prim: 'UNIT' },
366
- { prim: 'TRANSFER_TOKENS' },
367
- { prim: 'CONS' },
368
- ];
369
- }
370
- /**
371
- * Build the lambda for the multisig transaction transfer to an originated account.
372
- *
373
- * @param {string} address Originated account address to send the funds to
374
- * @param {string} amount The amount in mutez to transfer
375
- * @see {@link https://tezostaquito.io/docs/making_transfers#transfer-0000001-1-mutez-tokens-from-a-kt1-address-to-a-kt1-address}
376
- */
377
- function transferToOriginatedAccount(address, amount) {
378
- return [
379
- { prim: 'DROP' },
380
- { prim: 'NIL', args: [{ prim: 'operation' }] },
381
- {
382
- prim: 'PUSH',
383
- args: [{ prim: 'address' }, { string: address }],
384
- },
385
- { prim: 'CONTRACT', args: [{ prim: 'unit' }] },
386
- [
387
- {
388
- prim: 'IF_NONE',
389
- args: [[[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]], []],
390
- },
391
- ],
392
- {
393
- prim: 'PUSH',
394
- args: [{ prim: 'mutez' }, { int: amount }],
395
- },
396
- { prim: 'UNIT' },
397
- { prim: 'TRANSFER_TOKENS' },
398
- { prim: 'CONS' },
399
- ];
400
- }
401
- /**
402
- * Create a reveal operation for a public key.
403
- *
404
- * @param {string} counter Source account next counter
405
- * @param {string} source Source account address
406
- * @param {string} pubKey The public key to reveal
407
- * @param {string} fee Fees in mutez to pay by the source account
408
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
409
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
410
- * @returns An origination operation
411
- */
412
- function revealOperation(counter, source, pubKey, fee = utils_1.DEFAULT_FEE.REVEAL.toString(), gasLimit = utils_1.DEFAULT_GAS_LIMIT.REVEAL.toString(), storageLimit = utils_1.DEFAULT_STORAGE_LIMIT.REVEAL.toString()) {
413
- return {
414
- kind: 'reveal',
415
- counter,
416
- source,
417
- fee,
418
- gas_limit: gasLimit,
419
- storage_limit: storageLimit,
420
- public_key: pubKey,
421
- };
422
- }
423
- exports.revealOperation = revealOperation;
424
- /**
425
- * Create an origination operation for the generic multisg contract. It does not create a reveal
426
- * operation for the source account.
427
- *
428
- * @param {string} counter Valid source account counter to use
429
- * @param {string} source Source account address
430
- * @param {string} fee Fees in mutez to pay by the source account
431
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
432
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
433
- * @param {string} balance New multisig account initial balance taken from the source account
434
- * @param {string[]} pubKeys List of public keys of the multisig owner
435
- * @param {string} delegate Optional implicit address to delegate the wallet funds to
436
- * @param {number} threshold Minimum number of signatures required to authorize a multisig operation
437
- * @returns An origination operation
438
- */
439
- function genericMultisigOriginationOperation(counter, source, fee, gasLimit, storageLimit, balance, pubKeys, delegate, threshold = DEFAULT_N) {
440
- const walletPublicKeys = [];
441
- pubKeys.forEach((pk) => walletPublicKeys.push({ string: pk }));
442
- const originationOp = {
443
- kind: 'origination',
444
- counter,
445
- source,
446
- fee,
447
- gas_limit: gasLimit,
448
- storage_limit: storageLimit,
449
- balance,
450
- script: {
451
- code: genericMultisig,
452
- storage: {
453
- prim: 'Pair',
454
- args: [
455
- {
456
- int: '0',
457
- },
458
- {
459
- prim: 'Pair',
460
- args: [
461
- {
462
- int: threshold.toString(),
463
- },
464
- walletPublicKeys,
465
- ],
466
- },
467
- ],
468
- },
469
- },
470
- };
471
- if (delegate) {
472
- originationOp.delegate = delegate;
473
- }
474
- return originationOp;
475
- }
476
- exports.genericMultisigOriginationOperation = genericMultisigOriginationOperation;
477
- /**
478
- * Get the public key of each owner of an multisig wallet origination contract.
479
- *
480
- * @param {OriginationOp} operation An operation with the generic multisig wallet origination
481
- * @returns {string[]} List of all the owners set in the origination transaction
482
- */
483
- function getOwnersPublicKeys(operation) {
484
- const ownersArgs = _.get(operation, 'script.storage.args[1].args[1]');
485
- if (!ownersArgs) {
486
- return [];
487
- }
488
- return ownersArgs.map((o) => o.string);
489
- }
490
- exports.getOwnersPublicKeys = getOwnersPublicKeys;
491
- /**
492
- * Generic Multisig contract from https://github.com/murbard/smart-contracts/blob/master/multisig/michelson/generic.tz
493
- */
494
- const genericMultisig = [
495
- {
496
- prim: 'parameter',
497
- args: [
498
- {
499
- prim: 'or',
500
- args: [
501
- { prim: 'unit', annots: ['%default'] },
502
- {
503
- prim: 'pair',
504
- args: [
505
- {
506
- prim: 'pair',
507
- args: [
508
- {
509
- prim: 'nat',
510
- annots: ['%counter'],
511
- },
512
- {
513
- prim: 'or',
514
- args: [
515
- {
516
- prim: 'lambda',
517
- args: [
518
- { prim: 'unit' },
519
- {
520
- prim: 'list',
521
- args: [
522
- {
523
- prim: 'operation',
524
- },
525
- ],
526
- },
527
- ],
528
- annots: ['%operation'],
529
- },
530
- {
531
- prim: 'pair',
532
- args: [
533
- {
534
- prim: 'nat',
535
- annots: ['%threshold'],
536
- },
537
- {
538
- prim: 'list',
539
- args: [{ prim: 'key' }],
540
- annots: ['%keys'],
541
- },
542
- ],
543
- annots: ['%change_keys'],
544
- },
545
- ],
546
- annots: [':action'],
547
- },
548
- ],
549
- annots: [':payload'],
550
- },
551
- {
552
- prim: 'list',
553
- args: [
554
- {
555
- prim: 'option',
556
- args: [{ prim: 'signature' }],
557
- },
558
- ],
559
- annots: ['%sigs'],
560
- },
561
- ],
562
- annots: ['%main'],
563
- },
564
- ],
565
- },
566
- ],
567
- },
568
- {
569
- prim: 'storage',
570
- args: [
571
- {
572
- prim: 'pair',
573
- args: [
574
- {
575
- prim: 'nat',
576
- annots: ['%stored_counter'],
577
- },
578
- {
579
- prim: 'pair',
580
- args: [
581
- {
582
- prim: 'nat',
583
- annots: ['%threshold'],
584
- },
585
- {
586
- prim: 'list',
587
- args: [{ prim: 'key' }],
588
- annots: ['%keys'],
589
- },
590
- ],
591
- },
592
- ],
593
- },
594
- ],
595
- },
596
- {
597
- prim: 'code',
598
- args: [
599
- [
600
- [
601
- [
602
- { prim: 'DUP' },
603
- { prim: 'CAR' },
604
- {
605
- prim: 'DIP',
606
- args: [[{ prim: 'CDR' }]],
607
- },
608
- ],
609
- ],
610
- {
611
- prim: 'IF_LEFT',
612
- args: [
613
- [
614
- { prim: 'DROP' },
615
- {
616
- prim: 'NIL',
617
- args: [{ prim: 'operation' }],
618
- },
619
- { prim: 'PAIR' },
620
- ],
621
- [
622
- {
623
- prim: 'PUSH',
624
- args: [{ prim: 'mutez' }, { int: '0' }],
625
- },
626
- { prim: 'AMOUNT' },
627
- [
628
- [{ prim: 'COMPARE' }, { prim: 'EQ' }],
629
- {
630
- prim: 'IF',
631
- args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]],
632
- },
633
- ],
634
- { prim: 'SWAP' },
635
- { prim: 'DUP' },
636
- {
637
- prim: 'DIP',
638
- args: [[{ prim: 'SWAP' }]],
639
- },
640
- {
641
- prim: 'DIP',
642
- args: [
643
- [
644
- [
645
- [
646
- { prim: 'DUP' },
647
- { prim: 'CAR' },
648
- {
649
- prim: 'DIP',
650
- args: [[{ prim: 'CDR' }]],
651
- },
652
- ],
653
- ],
654
- { prim: 'DUP' },
655
- { prim: 'SELF' },
656
- { prim: 'ADDRESS' },
657
- { prim: 'PAIR' },
658
- { prim: 'PACK' },
659
- {
660
- prim: 'DIP',
661
- args: [
662
- [
663
- [
664
- [
665
- { prim: 'DUP' },
666
- {
667
- prim: 'CAR',
668
- annots: ['@counter'],
669
- },
670
- {
671
- prim: 'DIP',
672
- args: [
673
- [
674
- {
675
- prim: 'CDR',
676
- },
677
- ],
678
- ],
679
- },
680
- ],
681
- ],
682
- {
683
- prim: 'DIP',
684
- args: [[{ prim: 'SWAP' }]],
685
- },
686
- ],
687
- ],
688
- },
689
- { prim: 'SWAP' },
690
- ],
691
- ],
692
- },
693
- [
694
- [
695
- { prim: 'DUP' },
696
- {
697
- prim: 'CAR',
698
- annots: ['@stored_counter'],
699
- },
700
- {
701
- prim: 'DIP',
702
- args: [[{ prim: 'CDR' }]],
703
- },
704
- ],
705
- ],
706
- {
707
- prim: 'DIP',
708
- args: [[{ prim: 'SWAP' }]],
709
- },
710
- [
711
- [{ prim: 'COMPARE' }, { prim: 'EQ' }],
712
- {
713
- prim: 'IF',
714
- args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]],
715
- },
716
- ],
717
- {
718
- prim: 'DIP',
719
- args: [[{ prim: 'SWAP' }]],
720
- },
721
- [
722
- [
723
- { prim: 'DUP' },
724
- {
725
- prim: 'CAR',
726
- annots: ['@threshold'],
727
- },
728
- {
729
- prim: 'DIP',
730
- args: [
731
- [
732
- {
733
- prim: 'CDR',
734
- annots: ['@keys'],
735
- },
736
- ],
737
- ],
738
- },
739
- ],
740
- ],
741
- {
742
- prim: 'DIP',
743
- args: [
744
- [
745
- {
746
- prim: 'PUSH',
747
- args: [{ prim: 'nat' }, { int: '0' }],
748
- annots: ['@valid'],
749
- },
750
- { prim: 'SWAP' },
751
- {
752
- prim: 'ITER',
753
- args: [
754
- [
755
- {
756
- prim: 'DIP',
757
- args: [[{ prim: 'SWAP' }]],
758
- },
759
- { prim: 'SWAP' },
760
- {
761
- prim: 'IF_CONS',
762
- args: [
763
- [
764
- [
765
- {
766
- prim: 'IF_NONE',
767
- args: [
768
- [
769
- {
770
- prim: 'SWAP',
771
- },
772
- {
773
- prim: 'DROP',
774
- },
775
- ],
776
- [
777
- {
778
- prim: 'SWAP',
779
- },
780
- {
781
- prim: 'DIP',
782
- args: [
783
- [
784
- {
785
- prim: 'SWAP',
786
- },
787
- {
788
- prim: 'DIP',
789
- args: [
790
- {
791
- int: '2',
792
- },
793
- [
794
- [
795
- {
796
- prim: 'DIP',
797
- args: [
798
- [
799
- {
800
- prim: 'DUP',
801
- },
802
- ],
803
- ],
804
- },
805
- {
806
- prim: 'SWAP',
807
- },
808
- ],
809
- ],
810
- ],
811
- },
812
- [
813
- [
814
- {
815
- prim: 'DIP',
816
- args: [
817
- {
818
- int: '2',
819
- },
820
- [
821
- {
822
- prim: 'DUP',
823
- },
824
- ],
825
- ],
826
- },
827
- {
828
- prim: 'DIG',
829
- args: [
830
- {
831
- int: '3',
832
- },
833
- ],
834
- },
835
- ],
836
- {
837
- prim: 'DIP',
838
- args: [
839
- [
840
- {
841
- prim: 'CHECK_SIGNATURE',
842
- },
843
- ],
844
- ],
845
- },
846
- {
847
- prim: 'SWAP',
848
- },
849
- {
850
- prim: 'IF',
851
- args: [
852
- [
853
- {
854
- prim: 'DROP',
855
- },
856
- ],
857
- [
858
- {
859
- prim: 'FAILWITH',
860
- },
861
- ],
862
- ],
863
- },
864
- ],
865
- {
866
- prim: 'PUSH',
867
- args: [
868
- {
869
- prim: 'nat',
870
- },
871
- {
872
- int: '1',
873
- },
874
- ],
875
- },
876
- {
877
- prim: 'ADD',
878
- annots: ['@valid'],
879
- },
880
- ],
881
- ],
882
- },
883
- ],
884
- ],
885
- },
886
- ],
887
- ],
888
- [
889
- [
890
- {
891
- prim: 'UNIT',
892
- },
893
- {
894
- prim: 'FAILWITH',
895
- },
896
- ],
897
- ],
898
- ],
899
- },
900
- { prim: 'SWAP' },
901
- ],
902
- ],
903
- },
904
- ],
905
- ],
906
- },
907
- [
908
- [{ prim: 'COMPARE' }, { prim: 'LE' }],
909
- {
910
- prim: 'IF',
911
- args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]],
912
- },
913
- ],
914
- {
915
- prim: 'IF_CONS',
916
- args: [[[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]], []],
917
- },
918
- { prim: 'DROP' },
919
- {
920
- prim: 'DIP',
921
- args: [
922
- [
923
- [
924
- [
925
- { prim: 'DUP' },
926
- { prim: 'CAR' },
927
- {
928
- prim: 'DIP',
929
- args: [[{ prim: 'CDR' }]],
930
- },
931
- ],
932
- ],
933
- {
934
- prim: 'PUSH',
935
- args: [{ prim: 'nat' }, { int: '1' }],
936
- },
937
- {
938
- prim: 'ADD',
939
- annots: ['@new_counter'],
940
- },
941
- { prim: 'PAIR' },
942
- ],
943
- ],
944
- },
945
- {
946
- prim: 'IF_LEFT',
947
- args: [
948
- [{ prim: 'UNIT' }, { prim: 'EXEC' }],
949
- [
950
- {
951
- prim: 'DIP',
952
- args: [[{ prim: 'CAR' }]],
953
- },
954
- { prim: 'SWAP' },
955
- { prim: 'PAIR' },
956
- {
957
- prim: 'NIL',
958
- args: [{ prim: 'operation' }],
959
- },
960
- ],
961
- ],
962
- },
963
- { prim: 'PAIR' },
964
- ],
965
- ],
966
- },
967
- ],
968
- ],
969
- },
970
- ];
971
- /**
972
- * Add contract address to forwarder contract template and return contract Michelson code as JSON
973
- *
974
- * @param {string} contractAddress - multisig contractAddress that will receive forwarded funds
975
- * @returns {object[]} Michelson code for the origination operation
976
- */
977
- function createForwarder(contractAddress) {
978
- return [
979
- {
980
- prim: 'parameter',
981
- args: [
982
- {
983
- prim: 'or',
984
- args: [
985
- { prim: 'unit', annots: ['%default'] },
986
- {
987
- prim: 'pair',
988
- args: [
989
- { prim: 'nat' },
990
- {
991
- prim: 'contract',
992
- args: [
993
- {
994
- prim: 'pair',
995
- args: [
996
- { prim: 'address', annots: [':from'] },
997
- {
998
- prim: 'pair',
999
- args: [
1000
- { prim: 'address', annots: [':to'] },
1001
- { prim: 'nat', annots: [':value'] },
1002
- ],
1003
- },
1004
- ],
1005
- },
1006
- ],
1007
- },
1008
- ],
1009
- annots: ['%flush'],
1010
- },
1011
- ],
1012
- },
1013
- ],
1014
- },
1015
- { prim: 'storage', args: [{ prim: 'unit' }] },
1016
- {
1017
- prim: 'code',
1018
- args: [
1019
- [
1020
- {
1021
- prim: 'CAST',
1022
- args: [
1023
- {
1024
- prim: 'pair',
1025
- args: [
1026
- {
1027
- prim: 'or',
1028
- args: [
1029
- { prim: 'unit' },
1030
- {
1031
- prim: 'pair',
1032
- args: [
1033
- { prim: 'nat' },
1034
- {
1035
- prim: 'contract',
1036
- args: [
1037
- {
1038
- prim: 'pair',
1039
- args: [
1040
- { prim: 'address' },
1041
- { prim: 'pair', args: [{ prim: 'address' }, { prim: 'nat' }] },
1042
- ],
1043
- },
1044
- ],
1045
- },
1046
- ],
1047
- },
1048
- ],
1049
- },
1050
- { prim: 'unit' },
1051
- ],
1052
- },
1053
- ],
1054
- },
1055
- { prim: 'CAR' },
1056
- {
1057
- prim: 'IF_LEFT',
1058
- args: [
1059
- [
1060
- { prim: 'DROP' },
1061
- {
1062
- prim: 'NONE',
1063
- args: [
1064
- {
1065
- prim: 'pair',
1066
- args: [
1067
- { prim: 'nat' },
1068
- {
1069
- prim: 'contract',
1070
- args: [
1071
- {
1072
- prim: 'pair',
1073
- args: [
1074
- { prim: 'address' },
1075
- { prim: 'pair', args: [{ prim: 'address' }, { prim: 'nat' }] },
1076
- ],
1077
- },
1078
- ],
1079
- },
1080
- ],
1081
- },
1082
- ],
1083
- },
1084
- ],
1085
- [{ prim: 'SOME' }],
1086
- ],
1087
- },
1088
- { prim: 'DIP', args: [[{ prim: 'PUSH', args: [{ prim: 'address' }, { string: contractAddress }] }]] },
1089
- {
1090
- prim: 'IF_NONE',
1091
- args: [
1092
- [{ prim: 'NIL', args: [{ prim: 'operation' }] }],
1093
- [
1094
- { prim: 'DIP', args: [[{ prim: 'DUP' }]] },
1095
- { prim: 'DUP' },
1096
- { prim: 'CAR' },
1097
- { prim: 'DIP', args: [[{ prim: 'CDR' }]] },
1098
- { prim: 'DIG', args: [{ int: '2' }] },
1099
- { prim: 'PAIR' },
1100
- { prim: 'SELF' },
1101
- { prim: 'ADDRESS' },
1102
- { prim: 'PAIR' },
1103
- { prim: 'DIP', args: [[{ prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '0' }] }]] },
1104
- { prim: 'TRANSFER_TOKENS' },
1105
- { prim: 'DIP', args: [[{ prim: 'NIL', args: [{ prim: 'operation' }] }]] },
1106
- { prim: 'CONS' },
1107
- ],
1108
- ],
1109
- },
1110
- { prim: 'BALANCE' },
1111
- { prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '0' }] },
1112
- { prim: 'COMPARE' },
1113
- { prim: 'EQ' },
1114
- {
1115
- prim: 'IF',
1116
- args: [
1117
- [{ prim: 'DIP', args: [[{ prim: 'DROP' }]] }],
1118
- [
1119
- {
1120
- prim: 'DIP',
1121
- args: [
1122
- [
1123
- { prim: 'CONTRACT', args: [{ prim: 'unit' }] },
1124
- {
1125
- prim: 'IF_NONE',
1126
- args: [
1127
- [
1128
- { prim: 'PUSH', args: [{ prim: 'string' }, { string: 'not a wallet' }] },
1129
- { prim: 'FAILWITH' },
1130
- ],
1131
- [],
1132
- ],
1133
- },
1134
- { prim: 'BALANCE' },
1135
- { prim: 'UNIT' },
1136
- { prim: 'TRANSFER_TOKENS' },
1137
- ],
1138
- ],
1139
- },
1140
- { prim: 'SWAP' },
1141
- { prim: 'CONS' },
1142
- ],
1143
- ],
1144
- },
1145
- { prim: 'DIP', args: [[{ prim: 'UNIT' }]] },
1146
- { prim: 'PAIR' },
1147
- ],
1148
- ],
1149
- },
1150
- ];
1151
- }
1152
- /**
1153
- * Create an origination operation for a forwarder contract
1154
- *
1155
- * @param {string} contractAddress originated multisig address to forward funds
1156
- * @param {string} counter Valid source account counter to use
1157
- * @param {string} source Source account address
1158
- * @param {string} fee Fees in mutez to pay by the source account
1159
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
1160
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
1161
- * @param {string} balance New multisig account initial balance taken from the source account
1162
- * @returns {OriginationOp} the operation
1163
- */
1164
- function forwarderOriginationOperation(contractAddress, counter, source, fee, gasLimit, storageLimit, balance) {
1165
- return {
1166
- kind: 'origination',
1167
- counter,
1168
- source,
1169
- fee,
1170
- gas_limit: gasLimit,
1171
- storage_limit: storageLimit,
1172
- balance,
1173
- script: {
1174
- code: createForwarder(contractAddress),
1175
- storage: { prim: 'Unit' },
1176
- },
1177
- };
1178
- }
1179
- exports.forwarderOriginationOperation = forwarderOriginationOperation;
1180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multisigUtils.js","sourceRoot":"","sources":["../../../src/lib/multisigUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as _ from 'lodash';\nimport { IndexedSignature, OriginationData, OriginationOp, RevealOp, TransactionOp, TransferData } from './iface';\nimport { DEFAULT_FEE, DEFAULT_GAS_LIMIT, DEFAULT_STORAGE_LIMIT, hashTypes, isValidKey } from './utils';\n\n// Default n of m for multisig wallets\nconst DEFAULT_N = 2;\nconst DEFAULT_M = 3;\n\n/**\n * Helper method to get the transfer details from a generic multisig transaction operation.\n *\n * @param {TransactionOp} operation A transaction operation JSON\n * @returns {TransferData} Information about the destination, token and transfer amount\n */\nexport function getMultisigTransferDataFromOperation(operation: TransactionOp): TransferData {\n  const fee = {\n    fee: operation.fee,\n    gasLimit: operation.gas_limit,\n    storageLimit: operation.storage_limit,\n  };\n\n  if (!operation.parameters) {\n    // Singlesig transaction\n    return {\n      coin: 'mutez',\n      from: operation.source,\n      to: operation.destination,\n      amount: operation.amount,\n      fee,\n    };\n  }\n  // These follow the structure from the response of genericMultisigTransferParams()\n  const transferArgs = operation.parameters.value.args[0].args[1].args[0];\n  const accountType = transferArgs[3].prim;\n  const counter = operation.parameters.value.args[0].args[0].int;\n  // In multisig transactions, the wallet contract is the destination\n  const from = operation.destination;\n\n  let accountTypeIndex;\n  switch (accountType) {\n    case 'IMPLICIT_ACCOUNT':\n      accountTypeIndex = 4;\n      break;\n    case 'CONTRACT':\n      accountTypeIndex = 5;\n      break;\n    default:\n      throw new Error('Invalid contract parameters');\n  }\n\n  return {\n    coin: transferArgs[accountTypeIndex].args[0].prim,\n    from,\n    to: transferArgs[2].args[1].string,\n    amount: transferArgs[accountTypeIndex].args[1].int,\n    fee,\n    counter,\n  };\n}\n\n/**\n *  Helper method to get the wallet or address initialization tx from an origination operation\n *\n * @param {OriginationOp} operation\n * @returns {OriginationData} Information about the wallet contract creating a forwarder contract\n */\nexport function getOriginationDataFromOperation(operation: OriginationOp): OriginationData {\n  const fee = {\n    fee: operation.fee,\n    gasLimit: operation.gas_limit,\n    storageLimit: operation.storage_limit,\n  };\n\n  const { source: from, counter, balance } = operation;\n\n  // Transactions initializing a forwarder contract contain the address of the wallet contract\n  const forwarderDestination: string = _.get(operation, 'script.code[2].args[0][3].args[0][0].args[1].string');\n\n  return {\n    fee,\n    counter,\n    balance,\n    from,\n    forwarderDestination,\n  };\n}\n/**\n * Helper method to build a singlesig transaction operation.\n *\n * @param {string} counter Source account next counter\n * @param {string} source The account that will pay for fees, and in singlesig transactions, where\n *        the funds are taken from\n * @param {string} amount The amount in mutez to be transferred\n * @param {string} destination The account address to send the funds to\n * @param {string} fee Fees in mutez to pay by the source account\n * @param {string} gasLimit Maximum amount in mutez to spend in gas fees\n * @param {string} storageLimit Maximum amount in mutez to spend in storage fees\n * @returns {TransactionOp}A Tezos transaction operation\n */\nexport function singlesigTransactionOperation(\n  counter: string,\n  source: string,\n  amount: string,\n  destination: string,\n  fee: string = DEFAULT_FEE.TRANSFER.toString(),\n  gasLimit: string = DEFAULT_GAS_LIMIT.TRANSFER.toString(),\n  storageLimit: string = DEFAULT_STORAGE_LIMIT.TRANSFER.toString()\n): TransactionOp {\n  return {\n    kind: 'transaction',\n    source,\n    fee,\n    counter,\n    gas_limit: gasLimit,\n    storage_limit: storageLimit,\n    amount,\n    destination,\n  };\n}\n\n/**\n * Create a multisig wallet transaction operation.\n *\n * @see {@link transactionOperation}\n * @param {string} counter Source account next counter\n * @param {string} source The account that will pay for fees, and in singlesig transactions, where\n *        the funds are taken from\n * @param {string} amount The amount in mutez to be transferred\n * @param {string} contractAddress If it is a multisig transfer, the smart contract address with the\n *        funds to be transferred from\n * @param {string} contractCounter If it is a multisig transfer, the smart contract counter to use\n *        in the next transaction\n * @param {string} destinationAddress An implicit or originated address to transfer fudns to\n * @param {string[]} signatures signatures List of signatures authorizing the funds transfer form\n *        the multisig wallet\n * @param {string} fee Fees in mutez to pay by the source account\n * @param {string} gasLimit Maximum amount in mutez to spend in gas fees\n * @param {string} storageLimit Maximum amount in mutez to spend in storage fees\n * @param {number} m The number of signers (owners) for the multisig wallet being used. Default is 3\n * @returns {TransactionOp} A Tezos operation with a generic multisig transfer\n */\nexport function multisigTransactionOperation(\n  counter: string,\n  source: string,\n  amount: string,\n  contractAddress: string,\n  contractCounter: string,\n  destinationAddress: string,\n  signatures: IndexedSignature[],\n  fee: string = DEFAULT_FEE.TRANSFER.toString(),\n  gasLimit: string = DEFAULT_GAS_LIMIT.TRANSFER.toString(),\n  storageLimit: string = DEFAULT_STORAGE_LIMIT.TRANSFER.toString(),\n  m: number = DEFAULT_M\n): TransactionOp {\n  return {\n    kind: 'transaction',\n    source,\n    fee,\n    counter,\n    gas_limit: gasLimit,\n    storage_limit: storageLimit,\n    amount: '0', // Don't transfer any funds from he source account to the contract in multisig txs\n    destination: contractAddress,\n    parameters: genericMultisigTransferParams(destinationAddress, amount, contractCounter, signatures, m),\n  };\n}\n\n/**\n * Helper function to build the parameters to call the generic multisig smart contract with.\n *\n * @param {string} destinationAddress An implicit or originated address\n * @param {number} amount Number of Mutez to be transferred\n * @param {string} contractCounter Multisig contract counter number\n * @param {IndexedSignature[]} signatures List of transactions and their order\n * @param {number} m The multisig wallet total number of signers (owners)\n * @returns The parameters object\n */\nfunction genericMultisigTransferParams(\n  destinationAddress: string,\n  amount: string,\n  contractCounter: string,\n  signatures: IndexedSignature[],\n  m: number\n) {\n  const transactionSignatures: any[] = buildSignatures(signatures);\n  return {\n    entrypoint: 'main',\n    value: {\n      prim: 'Pair',\n      args: [\n        {\n          prim: 'Pair',\n          args: [{ int: contractCounter }, { prim: 'Left', args: [transferToAccount(destinationAddress, amount)] }],\n        },\n        transactionSignatures,\n      ],\n    },\n  };\n}\n\n/**\n * Replace the signatures in a multisig transaction operation with new ones.\n *\n * @param {TransactionOp} transaction Transaction to mutate\n * @param {IndexedSignature[]} signatures List of transactions and their order\n */\nexport function updateMultisigTransferSignatures(transaction: TransactionOp, signatures: IndexedSignature[]) {\n  transaction.parameters.value.args[1] = buildSignatures(signatures, transaction.parameters.value.args[1]);\n}\n\n/**\n * Ge the list if multisig signatures if any in a convenient format.\n *\n * @param {TransactionOp} transaction The transaction to search the signatures in\n * @returns {IndexedSignature[]} A list of signatures and their order in teh transfer script\n */\nexport function getMultisigTransferSignatures(transaction: TransactionOp): IndexedSignature[] {\n  const signatures: IndexedSignature[] = [];\n  if (!transaction.parameters && !transaction.parameters.value && !transaction.parameters.value) {\n    return [];\n  }\n  const rawSignatures = transaction.parameters.value.args[1];\n  for (let i = 0; i < rawSignatures.length; i++) {\n    if (rawSignatures[i].prim === 'Some') {\n      signatures.push({\n        signature: rawSignatures[i].args[0].string,\n        index: i,\n      });\n    }\n  }\n  return signatures;\n}\n\n/**\n * Build a list of ordered signatures, putting a None primitive for the missing indexes.\n *\n * @param {IndexedSignature[]} signatures List of transactions and their order\n * @param {number} m Size of the signature list\n * @param {any[]} existingSignatures List of existing signatures to merge with the generated ones\n * @returns {any[]} List of signatures in the right order\n */\nfunction buildSignatures(signatures: IndexedSignature[], existingSignatures = [], m: number = DEFAULT_M) {\n  // Initialize the array with the existing signatures and/or empty objects\n  const transactionSignatures: any[] = existingSignatures;\n  const size = existingSignatures.length;\n  if (size > m) {\n    throw new Error('Too many signatures. Expected less than ' + m + ' got ' + size);\n  }\n  for (let i = size; i < m; i++) {\n    transactionSignatures.push({ prim: 'None' });\n  }\n  // Replace the empty signatures for the real ones based on the right index\n  signatures.forEach((s) => {\n    if (s.index) {\n      transactionSignatures[s.index] = { prim: 'Some', args: [{ string: s.signature }] };\n    } else {\n      for (let i = 0; i < transactionSignatures.length; i++) {\n        // Search for the first \"null\" signature\n        if (transactionSignatures[i].prim === 'None') {\n          transactionSignatures[i] = { prim: 'Some', args: [{ string: s.signature }] };\n          break;\n        }\n      }\n    }\n  });\n  return transactionSignatures;\n}\n\n/**\n * Helper function to build the Michelson script to be signed to transfer funds from a multisig\n * wallet.\n *\n * @param contractAddress The multisig smart contract address\n * @param {string} destinationAddress The destination account address (implicit or originated)\n * @param {number} amount Number of mutez to transfer\n * @param {string} contractCounter Wallet counter to use in the transaction\n * @returns A JSON representation of the Michelson script to sign and approve a transfer\n */\nexport function genericMultisigDataToSign(\n  contractAddress: string,\n  destinationAddress: string,\n  amount: string,\n  contractCounter: string\n) {\n  const data = {\n    prim: 'Pair',\n    args: [\n      { int: contractCounter },\n      {\n        prim: 'Left',\n        args: [transferToAccount(destinationAddress, amount)],\n      },\n    ],\n  };\n  const type = {\n    prim: 'pair',\n    args: [\n      {\n        prim: 'nat',\n        annots: ['%counter'],\n      },\n      {\n        prim: 'or',\n        args: [\n          {\n            prim: 'lambda',\n            args: [\n              { prim: 'unit' },\n              {\n                prim: 'list',\n                args: [{ prim: 'operation' }],\n              },\n            ],\n            annots: ['%operation'],\n          },\n          {\n            prim: 'pair',\n            args: [\n              {\n                prim: 'nat',\n                annots: ['%threshold'],\n              },\n              {\n                prim: 'list',\n                args: [{ prim: 'key' }],\n                annots: ['%keys'],\n              },\n            ],\n            annots: ['%change_keys'],\n          },\n        ],\n        annots: [':action'],\n      },\n    ],\n    annots: [':payload'],\n  };\n  return buildPair(data, type, contractAddress);\n}\n\n/**\n * Util function to build a Michelson Pair object.\n *\n * @param data\n * @param type\n * @param contractAddress\n */\nfunction buildPair(data: any, type: any, contractAddress: any) {\n  return {\n    data: {\n      prim: 'Pair',\n      args: [{ string: contractAddress }, data],\n    },\n    type: {\n      prim: 'pair',\n      args: [{ prim: 'address' }, type],\n    },\n  };\n}\n\n/**\n * Build the lambda for the multisig transaction transfer to an implicit or originated account.\n *\n * @param {string} address Account address to send the funds to\n * @param {string} amount The amount in mutez to transfer\n * @see {@link https://tezostaquito.io/docs/making_transfers#transfer-000005-50-mutez-tokens-from-a-kt1-address-to-a-tz1-address}\n */\nfunction transferToAccount(address: string, amount: string) {\n  if (isValidKey(address, hashTypes.KT)) {\n    return transferToOriginatedAccount(address, amount);\n  }\n  // Lambda to transfer to an implicit account\n  return [\n    { prim: 'DROP' },\n    { prim: 'NIL', args: [{ prim: 'operation' }] },\n    {\n      prim: 'PUSH',\n      args: [{ prim: 'key_hash' }, { string: address }],\n    },\n    { prim: 'IMPLICIT_ACCOUNT' },\n    {\n      prim: 'PUSH',\n      args: [{ prim: 'mutez' }, { int: amount }],\n    },\n    { prim: 'UNIT' },\n    { prim: 'TRANSFER_TOKENS' },\n    { prim: 'CONS' },\n  ];\n}\n\n/**\n * Build the lambda for the multisig transaction transfer to an originated account.\n *\n * @param {string} address Originated account address to send the funds to\n * @param {string} amount The amount in mutez to transfer\n * @see {@link https://tezostaquito.io/docs/making_transfers#transfer-0000001-1-mutez-tokens-from-a-kt1-address-to-a-kt1-address}\n */\nfunction transferToOriginatedAccount(address: string, amount: string) {\n  return [\n    { prim: 'DROP' },\n    { prim: 'NIL', args: [{ prim: 'operation' }] },\n    {\n      prim: 'PUSH',\n      args: [{ prim: 'address' }, { string: address }],\n    },\n    { prim: 'CONTRACT', args: [{ prim: 'unit' }] },\n    [\n      {\n        prim: 'IF_NONE',\n        args: [[[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]], []],\n      },\n    ],\n    {\n      prim: 'PUSH',\n      args: [{ prim: 'mutez' }, { int: amount }],\n    },\n    { prim: 'UNIT' },\n    { prim: 'TRANSFER_TOKENS' },\n    { prim: 'CONS' },\n  ];\n}\n\n/**\n * Create a reveal operation for a public key.\n *\n * @param {string} counter Source account next counter\n * @param {string} source Source account address\n * @param {string} pubKey The public key to reveal\n * @param {string} fee Fees in mutez to pay by the source account\n * @param {string} gasLimit Maximum amount in mutez to spend in gas fees\n * @param {string} storageLimit Maximum amount in mutez to spend in storage fees\n * @returns An origination operation\n */\nexport function revealOperation(\n  counter: string,\n  source: string,\n  pubKey: string,\n  fee: string = DEFAULT_FEE.REVEAL.toString(),\n  gasLimit: string = DEFAULT_GAS_LIMIT.REVEAL.toString(),\n  storageLimit: string = DEFAULT_STORAGE_LIMIT.REVEAL.toString()\n): RevealOp {\n  return {\n    kind: 'reveal',\n    counter,\n    source,\n    fee,\n    gas_limit: gasLimit,\n    storage_limit: storageLimit,\n    public_key: pubKey,\n  };\n}\n\n/**\n * Create an origination operation for the generic multisg contract. It does not create a reveal\n * operation for the source account.\n *\n * @param {string} counter Valid source account counter to use\n * @param {string} source Source account address\n * @param {string} fee Fees in mutez to pay by the source account\n * @param {string} gasLimit Maximum amount in mutez to spend in gas fees\n * @param {string} storageLimit Maximum amount in mutez to spend in storage fees\n * @param {string} balance New multisig account initial balance taken from the source account\n * @param {string[]} pubKeys List of public keys of the multisig owner\n * @param {string} delegate Optional implicit address to delegate the wallet funds to\n * @param {number} threshold Minimum number of signatures required to authorize a multisig operation\n * @returns An origination operation\n */\nexport function genericMultisigOriginationOperation(\n  counter: string,\n  source: string,\n  fee: string,\n  gasLimit: string,\n  storageLimit: string,\n  balance: string,\n  pubKeys: string[],\n  delegate?: string,\n  threshold: number = DEFAULT_N\n): OriginationOp {\n  const walletPublicKeys: any[] = [];\n  pubKeys.forEach((pk) => walletPublicKeys.push({ string: pk }));\n  const originationOp: OriginationOp = {\n    kind: 'origination',\n    counter,\n    source,\n    fee,\n    gas_limit: gasLimit,\n    storage_limit: storageLimit,\n    balance,\n    script: {\n      code: genericMultisig,\n      storage: {\n        prim: 'Pair',\n        args: [\n          {\n            int: '0',\n          },\n          {\n            prim: 'Pair',\n            args: [\n              {\n                int: threshold.toString(),\n              },\n              walletPublicKeys,\n            ],\n          },\n        ],\n      },\n    },\n  };\n  if (delegate) {\n    originationOp.delegate = delegate;\n  }\n  return originationOp;\n}\n\n/**\n * Get the public key of each owner of an multisig wallet origination contract.\n *\n * @param {OriginationOp} operation An operation with the generic multisig wallet origination\n * @returns {string[]} List of all the owners set in the origination transaction\n */\nexport function getOwnersPublicKeys(operation: OriginationOp): string[] {\n  const ownersArgs = _.get(operation, 'script.storage.args[1].args[1]');\n  if (!ownersArgs) {\n    return [];\n  }\n  return ownersArgs.map((o) => o.string);\n}\n\n/**\n * Generic Multisig contract from https://github.com/murbard/smart-contracts/blob/master/multisig/michelson/generic.tz\n */\nconst genericMultisig = [\n  {\n    prim: 'parameter',\n    args: [\n      {\n        prim: 'or',\n        args: [\n          { prim: 'unit', annots: ['%default'] },\n          {\n            prim: 'pair',\n            args: [\n              {\n                prim: 'pair',\n                args: [\n                  {\n                    prim: 'nat',\n                    annots: ['%counter'],\n                  },\n                  {\n                    prim: 'or',\n                    args: [\n                      {\n                        prim: 'lambda',\n                        args: [\n                          { prim: 'unit' },\n                          {\n                            prim: 'list',\n                            args: [\n                              {\n                                prim: 'operation',\n                              },\n                            ],\n                          },\n                        ],\n                        annots: ['%operation'],\n                      },\n                      {\n                        prim: 'pair',\n                        args: [\n                          {\n                            prim: 'nat',\n                            annots: ['%threshold'],\n                          },\n                          {\n                            prim: 'list',\n                            args: [{ prim: 'key' }],\n                            annots: ['%keys'],\n                          },\n                        ],\n                        annots: ['%change_keys'],\n                      },\n                    ],\n                    annots: [':action'],\n                  },\n                ],\n                annots: [':payload'],\n              },\n              {\n                prim: 'list',\n                args: [\n                  {\n                    prim: 'option',\n                    args: [{ prim: 'signature' }],\n                  },\n                ],\n                annots: ['%sigs'],\n              },\n            ],\n            annots: ['%main'],\n          },\n        ],\n      },\n    ],\n  },\n  {\n    prim: 'storage',\n    args: [\n      {\n        prim: 'pair',\n        args: [\n          {\n            prim: 'nat',\n            annots: ['%stored_counter'],\n          },\n          {\n            prim: 'pair',\n            args: [\n              {\n                prim: 'nat',\n                annots: ['%threshold'],\n              },\n              {\n                prim: 'list',\n                args: [{ prim: 'key' }],\n                annots: ['%keys'],\n              },\n            ],\n          },\n        ],\n      },\n    ],\n  },\n  {\n    prim: 'code',\n    args: [\n      [\n        [\n          [\n            { prim: 'DUP' },\n            { prim: 'CAR' },\n            {\n              prim: 'DIP',\n              args: [[{ prim: 'CDR' }]],\n            },\n          ],\n        ],\n        {\n          prim: 'IF_LEFT',\n          args: [\n            [\n              { prim: 'DROP' },\n              {\n                prim: 'NIL',\n                args: [{ prim: 'operation' }],\n              },\n              { prim: 'PAIR' },\n            ],\n            [\n              {\n                prim: 'PUSH',\n                args: [{ prim: 'mutez' }, { int: '0' }],\n              },\n              { prim: 'AMOUNT' },\n              [\n                [{ prim: 'COMPARE' }, { prim: 'EQ' }],\n                {\n                  prim: 'IF',\n                  args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]],\n                },\n              ],\n              { prim: 'SWAP' },\n              { prim: 'DUP' },\n              {\n                prim: 'DIP',\n                args: [[{ prim: 'SWAP' }]],\n              },\n              {\n                prim: 'DIP',\n                args: [\n                  [\n                    [\n                      [\n                        { prim: 'DUP' },\n                        { prim: 'CAR' },\n                        {\n                          prim: 'DIP',\n                          args: [[{ prim: 'CDR' }]],\n                        },\n                      ],\n                    ],\n                    { prim: 'DUP' },\n                    { prim: 'SELF' },\n                    { prim: 'ADDRESS' },\n                    { prim: 'PAIR' },\n                    { prim: 'PACK' },\n                    {\n                      prim: 'DIP',\n                      args: [\n                        [\n                          [\n                            [\n                              { prim: 'DUP' },\n                              {\n                                prim: 'CAR',\n                                annots: ['@counter'],\n                              },\n                              {\n                                prim: 'DIP',\n                                args: [\n                                  [\n                                    {\n                                      prim: 'CDR',\n                                    },\n                                  ],\n                                ],\n                              },\n                            ],\n                          ],\n                          {\n                            prim: 'DIP',\n                            args: [[{ prim: 'SWAP' }]],\n                          },\n                        ],\n                      ],\n                    },\n                    { prim: 'SWAP' },\n                  ],\n                ],\n              },\n              [\n                [\n                  { prim: 'DUP' },\n                  {\n                    prim: 'CAR',\n                    annots: ['@stored_counter'],\n                  },\n                  {\n                    prim: 'DIP',\n                    args: [[{ prim: 'CDR' }]],\n                  },\n                ],\n              ],\n              {\n                prim: 'DIP',\n                args: [[{ prim: 'SWAP' }]],\n              },\n              [\n                [{ prim: 'COMPARE' }, { prim: 'EQ' }],\n                {\n                  prim: 'IF',\n                  args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]],\n                },\n              ],\n              {\n                prim: 'DIP',\n                args: [[{ prim: 'SWAP' }]],\n              },\n              [\n                [\n                  { prim: 'DUP' },\n                  {\n                    prim: 'CAR',\n                    annots: ['@threshold'],\n                  },\n                  {\n                    prim: 'DIP',\n                    args: [\n                      [\n                        {\n                          prim: 'CDR',\n                          annots: ['@keys'],\n                        },\n                      ],\n                    ],\n                  },\n                ],\n              ],\n              {\n                prim: 'DIP',\n                args: [\n                  [\n                    {\n                      prim: 'PUSH',\n                      args: [{ prim: 'nat' }, { int: '0' }],\n                      annots: ['@valid'],\n                    },\n                    { prim: 'SWAP' },\n                    {\n                      prim: 'ITER',\n                      args: [\n                        [\n                          {\n                            prim: 'DIP',\n                            args: [[{ prim: 'SWAP' }]],\n                          },\n                          { prim: 'SWAP' },\n                          {\n                            prim: 'IF_CONS',\n                            args: [\n                              [\n                                [\n                                  {\n                                    prim: 'IF_NONE',\n                                    args: [\n                                      [\n                                        {\n                                          prim: 'SWAP',\n                                        },\n                                        {\n                                          prim: 'DROP',\n                                        },\n                                      ],\n                                      [\n                                        {\n                                          prim: 'SWAP',\n                                        },\n                                        {\n                                          prim: 'DIP',\n                                          args: [\n                                            [\n                                              {\n                                                prim: 'SWAP',\n                                              },\n                                              {\n                                                prim: 'DIP',\n                                                args: [\n                                                  {\n                                                    int: '2',\n                                                  },\n                                                  [\n                                                    [\n                                                      {\n                                                        prim: 'DIP',\n                                                        args: [\n                                                          [\n                                                            {\n                                                              prim: 'DUP',\n                                                            },\n                                                          ],\n                                                        ],\n                                                      },\n                                                      {\n                                                        prim: 'SWAP',\n                                                      },\n                                                    ],\n                                                  ],\n                                                ],\n                                              },\n                                              [\n                                                [\n                                                  {\n                                                    prim: 'DIP',\n                                                    args: [\n                                                      {\n                                                        int: '2',\n                                                      },\n                                                      [\n                                                        {\n                                                          prim: 'DUP',\n                                                        },\n                                                      ],\n                                                    ],\n                                                  },\n                                                  {\n                                                    prim: 'DIG',\n                                                    args: [\n                                                      {\n                                                        int: '3',\n                                                      },\n                                                    ],\n                                                  },\n                                                ],\n                                                {\n                                                  prim: 'DIP',\n                                                  args: [\n                                                    [\n                                                      {\n                                                        prim: 'CHECK_SIGNATURE',\n                                                      },\n                                                    ],\n                                                  ],\n                                                },\n                                                {\n                                                  prim: 'SWAP',\n                                                },\n                                                {\n                                                  prim: 'IF',\n                                                  args: [\n                                                    [\n                                                      {\n                                                        prim: 'DROP',\n                                                      },\n                                                    ],\n                                                    [\n                                                      {\n                                                        prim: 'FAILWITH',\n                                                      },\n                                                    ],\n                                                  ],\n                                                },\n                                              ],\n                                              {\n                                                prim: 'PUSH',\n                                                args: [\n                                                  {\n                                                    prim: 'nat',\n                                                  },\n                                                  {\n                                                    int: '1',\n                                                  },\n                                                ],\n                                              },\n                                              {\n                                                prim: 'ADD',\n                                                annots: ['@valid'],\n                                              },\n                                            ],\n                                          ],\n                                        },\n                                      ],\n                                    ],\n                                  },\n                                ],\n                              ],\n                              [\n                                [\n                                  {\n                                    prim: 'UNIT',\n                                  },\n                                  {\n                                    prim: 'FAILWITH',\n                                  },\n                                ],\n                              ],\n                            ],\n                          },\n                          { prim: 'SWAP' },\n                        ],\n                      ],\n                    },\n                  ],\n                ],\n              },\n              [\n                [{ prim: 'COMPARE' }, { prim: 'LE' }],\n                {\n                  prim: 'IF',\n                  args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]],\n                },\n              ],\n              {\n                prim: 'IF_CONS',\n                args: [[[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]], []],\n              },\n              { prim: 'DROP' },\n              {\n                prim: 'DIP',\n                args: [\n                  [\n                    [\n                      [\n                        { prim: 'DUP' },\n                        { prim: 'CAR' },\n                        {\n                          prim: 'DIP',\n                          args: [[{ prim: 'CDR' }]],\n                        },\n                      ],\n                    ],\n                    {\n                      prim: 'PUSH',\n                      args: [{ prim: 'nat' }, { int: '1' }],\n                    },\n                    {\n                      prim: 'ADD',\n                      annots: ['@new_counter'],\n                    },\n                    { prim: 'PAIR' },\n                  ],\n                ],\n              },\n              {\n                prim: 'IF_LEFT',\n                args: [\n                  [{ prim: 'UNIT' }, { prim: 'EXEC' }],\n                  [\n                    {\n                      prim: 'DIP',\n                      args: [[{ prim: 'CAR' }]],\n                    },\n                    { prim: 'SWAP' },\n                    { prim: 'PAIR' },\n                    {\n                      prim: 'NIL',\n                      args: [{ prim: 'operation' }],\n                    },\n                  ],\n                ],\n              },\n              { prim: 'PAIR' },\n            ],\n          ],\n        },\n      ],\n    ],\n  },\n];\n\n/**\n * Add contract address to forwarder contract template and return contract Michelson code as JSON\n *\n * @param {string} contractAddress - multisig contractAddress that will receive forwarded funds\n * @returns {object[]} Michelson code for the origination operation\n */\nfunction createForwarder(contractAddress: string) {\n  return [\n    {\n      prim: 'parameter',\n      args: [\n        {\n          prim: 'or',\n          args: [\n            { prim: 'unit', annots: ['%default'] },\n            {\n              prim: 'pair',\n              args: [\n                { prim: 'nat' },\n                {\n                  prim: 'contract',\n                  args: [\n                    {\n                      prim: 'pair',\n                      args: [\n                        { prim: 'address', annots: [':from'] },\n                        {\n                          prim: 'pair',\n                          args: [\n                            { prim: 'address', annots: [':to'] },\n                            { prim: 'nat', annots: [':value'] },\n                          ],\n                        },\n                      ],\n                    },\n                  ],\n                },\n              ],\n              annots: ['%flush'],\n            },\n          ],\n        },\n      ],\n    },\n    { prim: 'storage', args: [{ prim: 'unit' }] },\n    {\n      prim: 'code',\n      args: [\n        [\n          {\n            prim: 'CAST',\n            args: [\n              {\n                prim: 'pair',\n                args: [\n                  {\n                    prim: 'or',\n                    args: [\n                      { prim: 'unit' },\n                      {\n                        prim: 'pair',\n                        args: [\n                          { prim: 'nat' },\n                          {\n                            prim: 'contract',\n                            args: [\n                              {\n                                prim: 'pair',\n                                args: [\n                                  { prim: 'address' },\n                                  { prim: 'pair', args: [{ prim: 'address' }, { prim: 'nat' }] },\n                                ],\n                              },\n                            ],\n                          },\n                        ],\n                      },\n                    ],\n                  },\n                  { prim: 'unit' },\n                ],\n              },\n            ],\n          },\n          { prim: 'CAR' },\n          {\n            prim: 'IF_LEFT',\n            args: [\n              [\n                { prim: 'DROP' },\n                {\n                  prim: 'NONE',\n                  args: [\n                    {\n                      prim: 'pair',\n                      args: [\n                        { prim: 'nat' },\n                        {\n                          prim: 'contract',\n                          args: [\n                            {\n                              prim: 'pair',\n                              args: [\n                                { prim: 'address' },\n                                { prim: 'pair', args: [{ prim: 'address' }, { prim: 'nat' }] },\n                              ],\n                            },\n                          ],\n                        },\n                      ],\n                    },\n                  ],\n                },\n              ],\n              [{ prim: 'SOME' }],\n            ],\n          },\n          { prim: 'DIP', args: [[{ prim: 'PUSH', args: [{ prim: 'address' }, { string: contractAddress }] }]] },\n          {\n            prim: 'IF_NONE',\n            args: [\n              [{ prim: 'NIL', args: [{ prim: 'operation' }] }],\n              [\n                { prim: 'DIP', args: [[{ prim: 'DUP' }]] },\n                { prim: 'DUP' },\n                { prim: 'CAR' },\n                { prim: 'DIP', args: [[{ prim: 'CDR' }]] },\n                { prim: 'DIG', args: [{ int: '2' }] },\n                { prim: 'PAIR' },\n                { prim: 'SELF' },\n                { prim: 'ADDRESS' },\n                { prim: 'PAIR' },\n                { prim: 'DIP', args: [[{ prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '0' }] }]] },\n                { prim: 'TRANSFER_TOKENS' },\n                { prim: 'DIP', args: [[{ prim: 'NIL', args: [{ prim: 'operation' }] }]] },\n                { prim: 'CONS' },\n              ],\n            ],\n          },\n          { prim: 'BALANCE' },\n          { prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '0' }] },\n          { prim: 'COMPARE' },\n          { prim: 'EQ' },\n          {\n            prim: 'IF',\n            args: [\n              [{ prim: 'DIP', args: [[{ prim: 'DROP' }]] }],\n              [\n                {\n                  prim: 'DIP',\n                  args: [\n                    [\n                      { prim: 'CONTRACT', args: [{ prim: 'unit' }] },\n                      {\n                        prim: 'IF_NONE',\n                        args: [\n                          [\n                            { prim: 'PUSH', args: [{ prim: 'string' }, { string: 'not a wallet' }] },\n                            { prim: 'FAILWITH' },\n                          ],\n                          [],\n                        ],\n                      },\n                      { prim: 'BALANCE' },\n                      { prim: 'UNIT' },\n                      { prim: 'TRANSFER_TOKENS' },\n                    ],\n                  ],\n                },\n                { prim: 'SWAP' },\n                { prim: 'CONS' },\n              ],\n            ],\n          },\n          { prim: 'DIP', args: [[{ prim: 'UNIT' }]] },\n          { prim: 'PAIR' },\n        ],\n      ],\n    },\n  ];\n}\n\n/**\n * Create an origination operation for a forwarder contract\n *\n * @param {string} contractAddress originated multisig address to forward funds\n * @param {string} counter Valid source account counter to use\n * @param {string} source Source account address\n * @param {string} fee Fees in mutez to pay by the source account\n * @param {string} gasLimit Maximum amount in mutez to spend in gas fees\n * @param {string} storageLimit Maximum amount in mutez to spend in storage fees\n * @param {string} balance New multisig account initial balance taken from the source account\n * @returns {OriginationOp} the operation\n */\nexport function forwarderOriginationOperation(\n  contractAddress: string,\n  counter: string,\n  source: string,\n  fee: string,\n  gasLimit: string,\n  storageLimit: string,\n  balance: string\n): OriginationOp {\n  return {\n    kind: 'origination',\n    counter,\n    source,\n    fee,\n    gas_limit: gasLimit,\n    storage_limit: storageLimit,\n    balance,\n    script: {\n      code: createForwarder(contractAddress),\n      storage: { prim: 'Unit' },\n    },\n  };\n}\n"]}