@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.397 → 1.4.3-alpha.399

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