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

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 (71) hide show
  1. package/dist/src/index.d.ts +5 -0
  2. package/dist/src/index.d.ts.map +1 -0
  3. package/dist/src/index.js +44 -0
  4. package/dist/src/lib/address.d.ts +8 -0
  5. package/dist/src/lib/address.d.ts.map +1 -0
  6. package/dist/src/lib/address.js +10 -0
  7. package/dist/src/lib/iface.d.ts +148 -0
  8. package/dist/src/lib/iface.d.ts.map +1 -0
  9. package/dist/src/lib/iface.js +3 -0
  10. package/dist/src/lib/index.d.ts +10 -0
  11. package/dist/src/lib/index.d.ts.map +1 -0
  12. package/dist/src/lib/index.js +51 -0
  13. package/dist/src/lib/keyPair.d.ts +40 -0
  14. package/dist/src/lib/keyPair.d.ts.map +1 -0
  15. package/dist/src/lib/keyPair.js +149 -0
  16. package/dist/src/lib/multisigUtils.d.ts +134 -0
  17. package/dist/src/lib/multisigUtils.d.ts.map +1 -0
  18. package/dist/src/lib/multisigUtils.js +1193 -0
  19. package/dist/src/lib/transaction.d.ts +119 -0
  20. package/dist/src/lib/transaction.d.ts.map +1 -0
  21. package/dist/src/lib/transaction.js +329 -0
  22. package/dist/src/lib/transactionBuilder.d.ts +171 -0
  23. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  24. package/dist/src/lib/transactionBuilder.js +453 -0
  25. package/dist/src/lib/transferBuilder.d.ts +24 -0
  26. package/dist/src/lib/transferBuilder.d.ts.map +1 -0
  27. package/dist/src/lib/transferBuilder.js +64 -0
  28. package/dist/src/lib/utils.d.ts +280 -0
  29. package/dist/src/lib/utils.d.ts.map +1 -0
  30. package/dist/src/lib/utils.js +492 -0
  31. package/dist/src/register.d.ts +3 -0
  32. package/dist/src/register.d.ts.map +1 -0
  33. package/dist/src/register.js +11 -0
  34. package/dist/src/txtz.d.ts +13 -0
  35. package/dist/src/txtz.d.ts.map +1 -0
  36. package/dist/src/txtz.js +14 -0
  37. package/dist/src/xtz.d.ts +125 -0
  38. package/dist/src/xtz.d.ts.map +1 -0
  39. package/dist/src/xtz.js +409 -0
  40. package/dist/test/fixtures.d.ts +571 -0
  41. package/dist/test/fixtures.d.ts.map +1 -0
  42. package/dist/test/fixtures.js +656 -0
  43. package/dist/test/resources.d.ts +451 -0
  44. package/dist/test/resources.d.ts.map +1 -0
  45. package/dist/test/resources.js +349 -0
  46. package/dist/test/unit/keyPair.d.ts +2 -0
  47. package/dist/test/unit/keyPair.d.ts.map +1 -0
  48. package/dist/test/unit/keyPair.js +142 -0
  49. package/dist/test/unit/offlineTransactionBuilder.d.ts +2 -0
  50. package/dist/test/unit/offlineTransactionBuilder.d.ts.map +1 -0
  51. package/dist/test/unit/offlineTransactionBuilder.js +291 -0
  52. package/dist/test/unit/transaction.d.ts +2 -0
  53. package/dist/test/unit/transaction.d.ts.map +1 -0
  54. package/dist/test/unit/transaction.js +98 -0
  55. package/dist/test/unit/transactionBuilder.d.ts +2 -0
  56. package/dist/test/unit/transactionBuilder.d.ts.map +1 -0
  57. package/dist/test/unit/transactionBuilder.js +656 -0
  58. package/dist/test/unit/transferBuilder.d.ts +2 -0
  59. package/dist/test/unit/transferBuilder.d.ts.map +1 -0
  60. package/dist/test/unit/transferBuilder.js +82 -0
  61. package/dist/test/unit/util.d.ts +2 -0
  62. package/dist/test/unit/util.d.ts.map +1 -0
  63. package/dist/test/unit/util.js +198 -0
  64. package/dist/test/unit/xtz.d.ts +2 -0
  65. package/dist/test/unit/xtz.d.ts.map +1 -0
  66. package/dist/test/unit/xtz.js +192 -0
  67. package/dist/tsconfig.tsbuildinfo +1 -0
  68. package/package.json +10 -7
  69. package/.eslintignore +0 -5
  70. package/.mocharc.yml +0 -8
  71. package/CHANGELOG.md +0 -784
@@ -0,0 +1,119 @@
1
+ import { BaseKey, BaseTransaction } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import { IndexedSignature, ParsedTransaction } from './iface';
4
+ import { KeyPair } from './keyPair';
5
+ /**
6
+ * Tezos transaction model.
7
+ */
8
+ export declare class Transaction extends BaseTransaction {
9
+ private _parsedTransaction?;
10
+ private _encodedTransaction?;
11
+ private _source;
12
+ private _delegate?;
13
+ private _forwarderDestination?;
14
+ private _publicKeyToReveal?;
15
+ private _owners;
16
+ /**
17
+ * Public constructor.
18
+ *
19
+ * @param {Readonly<CoinConfig>} coinConfig
20
+ */
21
+ constructor(coinConfig: Readonly<CoinConfig>);
22
+ /**
23
+ * Initialize the transaction fields based on another serialized transaction.
24
+ *
25
+ * @param serializedTransaction Transaction in broadcast format.
26
+ */
27
+ initFromSerializedTransaction(serializedTransaction: string): Promise<void>;
28
+ /**
29
+ * Initialize the transaction fields based on another parsed transaction.
30
+ *
31
+ * @param {ParsedTransaction} parsedTransaction A Tezos transaction object
32
+ * @param {string} transactionId The transaction id of the parsedTransaction if it is signed
33
+ */
34
+ initFromParsedTransaction(parsedTransaction: ParsedTransaction, transactionId?: string): Promise<void>;
35
+ /**
36
+ * Record the most important fields from an origination operation.
37
+ *
38
+ * @param {Operation} operation An operation object from a Tezos transaction
39
+ * @param {number} index The origination operation index in the transaction. Used to calculate the
40
+ * originated address
41
+ */
42
+ private recordOriginationOpFields;
43
+ /**
44
+ * Record the most important fields from a reveal operation.
45
+ *
46
+ * @param {RevealOp} operation A reveal operation object from a Tezos transaction
47
+ */
48
+ private recordRevealOpFields;
49
+ /**
50
+ * Record the most important fields for a Transaction operation.
51
+ *
52
+ * @param {TransactionOp} operation A transaction object from a Tezos operation
53
+ */
54
+ private recordTransactionOpFields;
55
+ /**
56
+ * Sign the transaction with the provided key. It does not check if the signer is allowed to sign
57
+ * it or not.
58
+ *
59
+ * @param {KeyPair} keyPair The key to sign the transaction with
60
+ */
61
+ sign(keyPair: KeyPair): Promise<void>;
62
+ /**
63
+ * Update the list of signatures for a multisig transaction operation.
64
+ *
65
+ * @param {IndexedSignature[]} signatures List of signatures and the index they should be put on
66
+ * in the multisig transfer
67
+ * @param {number} index The transfer index to add the signatures to
68
+ */
69
+ addTransferSignature(signatures: IndexedSignature[], index: number): Promise<void>;
70
+ /** @inheritdoc */
71
+ canSign(key: BaseKey): boolean;
72
+ /** @inheritdoc */
73
+ toJson(): ParsedTransaction;
74
+ /** @inheritdoc */
75
+ toBroadcastFormat(): string;
76
+ /**
77
+ * Get the transaction source if it is available.
78
+ *
79
+ * @returns {string} Source of the transaction
80
+ */
81
+ get source(): string;
82
+ /**
83
+ * Get the transaction delegation address if it is available.
84
+ *
85
+ * @returns {string} transaction delegation address
86
+ */
87
+ get delegate(): string | undefined;
88
+ /**
89
+ * Get the public key revealed by the transaction if it exists
90
+ *
91
+ * @returns {string} public key
92
+ */
93
+ get publicKeyToReveal(): string | undefined;
94
+ /**
95
+ * Get the destination of an address initialization transaction if it exists
96
+ *
97
+ * @returns {string} forwarder destination
98
+ */
99
+ get forwarderDestination(): string | undefined;
100
+ get owners(): string[];
101
+ /**
102
+ * Get the signatures for the given multisig transfer,
103
+ *
104
+ * @param {number} transferIndex The transfer script index in the Tezos transaction
105
+ * @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer
106
+ * script
107
+ */
108
+ getTransferSignatures(transferIndex?: number): IndexedSignature[];
109
+ /**
110
+ * Get the list of index per tezos transaction type. This is useful to locate specific operations
111
+ * within the transaction and verify or sign them.
112
+ *
113
+ * @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind
114
+ */
115
+ getIndexesByTransactionType(): {
116
+ [kind: string]: number[];
117
+ };
118
+ }
119
+ //# sourceMappingURL=transaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,eAAe,EAIhB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,gBAAgB,EAAiB,iBAAiB,EAA2B,MAAM,SAAS,CAAC;AACtG,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAUpC;;GAEG;AACH,qBAAa,WAAY,SAAQ,eAAe;IAC9C,OAAO,CAAC,kBAAkB,CAAC,CAAoB;IAC/C,OAAO,CAAC,mBAAmB,CAAC,CAAS;IACrC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,qBAAqB,CAAC,CAAS;IACvC,OAAO,CAAC,kBAAkB,CAAC,CAAS;IACpC,OAAO,CAAC,OAAO,CAAW;IAE1B;;;;OAIG;gBACS,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK5C;;;;OAIG;IACG,6BAA6B,CAAC,qBAAqB,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBjF;;;;;OAKG;IACG,yBAAyB,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC5G;;;;;;OAMG;YACW,yBAAyB;IAwBvC;;;;OAIG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;;OAIG;IACH,OAAO,CAAC,yBAAyB;IA6BjC;;;;;OAKG;IACG,IAAI,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB3C;;;;;;OAMG;IACG,oBAAoB,CAAC,UAAU,EAAE,gBAAgB,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQxF,kBAAkB;IAClB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAK9B,kBAAkB;IAClB,MAAM,IAAI,iBAAiB;IAO3B,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAO3B;;;;OAIG;IACH,IAAI,MAAM,IAAI,MAAM,CAKnB;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,MAAM,GAAG,SAAS,CAEjC;IAED;;;;OAIG;IACH,IAAI,iBAAiB,IAAI,MAAM,GAAG,SAAS,CAE1C;IAED;;;;OAIG;IACH,IAAI,oBAAoB,IAAI,MAAM,GAAG,SAAS,CAE7C;IAED,IAAI,MAAM,IAAI,MAAM,EAAE,CAErB;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,aAAa,SAAI,GAAG,gBAAgB,EAAE;IAO5D;;;;;OAKG;IACH,2BAA2B,IAAI;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE;CAW5D"}
@@ -0,0 +1,329 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.Transaction = void 0;
40
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
41
+ const local_forging_1 = require("@taquito/local-forging");
42
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
43
+ const multisigUtils_1 = require("./multisigUtils");
44
+ const Utils = __importStar(require("./utils"));
45
+ /**
46
+ * Tezos transaction model.
47
+ */
48
+ class Transaction extends sdk_core_1.BaseTransaction {
49
+ /**
50
+ * Public constructor.
51
+ *
52
+ * @param {Readonly<CoinConfig>} coinConfig
53
+ */
54
+ constructor(coinConfig) {
55
+ super(coinConfig);
56
+ this._owners = [];
57
+ }
58
+ /**
59
+ * Initialize the transaction fields based on another serialized transaction.
60
+ *
61
+ * @param serializedTransaction Transaction in broadcast format.
62
+ */
63
+ async initFromSerializedTransaction(serializedTransaction) {
64
+ this._encodedTransaction = serializedTransaction;
65
+ try {
66
+ const parsedTransaction = await local_forging_1.localForger.parse(serializedTransaction);
67
+ await this.initFromParsedTransaction(parsedTransaction);
68
+ }
69
+ catch (e) {
70
+ // If it throws, it is possible the serialized transaction is signed, which is not supported
71
+ // by local-forging. Try extracting the last 64 bytes and parse it again.
72
+ const unsignedSerializedTransaction = serializedTransaction.slice(0, -128);
73
+ const signature = serializedTransaction.slice(-128);
74
+ if (Utils.isValidSignature(signature)) {
75
+ throw new sdk_core_1.ParseTransactionError('Invalid transaction');
76
+ }
77
+ // TODO: encode the signature and save it in _signature
78
+ const parsedTransaction = await local_forging_1.localForger.parse(unsignedSerializedTransaction);
79
+ const transactionId = await Utils.calculateTransactionId(serializedTransaction);
80
+ await this.initFromParsedTransaction(parsedTransaction, transactionId);
81
+ }
82
+ }
83
+ /**
84
+ * Initialize the transaction fields based on another parsed transaction.
85
+ *
86
+ * @param {ParsedTransaction} parsedTransaction A Tezos transaction object
87
+ * @param {string} transactionId The transaction id of the parsedTransaction if it is signed
88
+ */
89
+ async initFromParsedTransaction(parsedTransaction, transactionId) {
90
+ if (!this._encodedTransaction) {
91
+ this._encodedTransaction = await local_forging_1.localForger.forge(parsedTransaction);
92
+ }
93
+ if (transactionId) {
94
+ // If the transaction id is passed, save it and clean up the entries since they will be
95
+ // recalculated
96
+ this._id = transactionId;
97
+ this._inputs = [];
98
+ this._outputs = [];
99
+ }
100
+ else {
101
+ this._id = '';
102
+ }
103
+ this._parsedTransaction = parsedTransaction;
104
+ let operationIndex = 0;
105
+ for (const operation of parsedTransaction.contents) {
106
+ if (this._source && this._source !== operation.source) {
107
+ throw new sdk_core_1.InvalidTransactionError('Source must be the same for every operation but it changed from ' + this._source + ' to ' + operation.source);
108
+ }
109
+ else {
110
+ this._source = operation.source;
111
+ }
112
+ switch (operation.kind) {
113
+ case local_forging_1.CODEC.OP_ORIGINATION:
114
+ await this.recordOriginationOpFields(operation, operationIndex);
115
+ operationIndex++;
116
+ break;
117
+ case local_forging_1.CODEC.OP_REVEAL:
118
+ this.recordRevealOpFields(operation);
119
+ break;
120
+ case local_forging_1.CODEC.OP_TRANSACTION:
121
+ this.recordTransactionOpFields(operation);
122
+ break;
123
+ default:
124
+ break;
125
+ }
126
+ }
127
+ }
128
+ /**
129
+ * Record the most important fields from an origination operation.
130
+ *
131
+ * @param {Operation} operation An operation object from a Tezos transaction
132
+ * @param {number} index The origination operation index in the transaction. Used to calculate the
133
+ * originated address
134
+ */
135
+ async recordOriginationOpFields(operation, index) {
136
+ const originationData = (0, multisigUtils_1.getOriginationDataFromOperation)(operation);
137
+ if (originationData.forwarderDestination) {
138
+ this._type = sdk_core_1.TransactionType.AddressInitialization;
139
+ this._forwarderDestination = originationData.forwarderDestination;
140
+ }
141
+ else {
142
+ this._type = sdk_core_1.TransactionType.WalletInitialization;
143
+ this._owners = (0, multisigUtils_1.getOwnersPublicKeys)(operation);
144
+ }
145
+ this._delegate = operation.delegate;
146
+ this._outputs.push({
147
+ // Kt addresses can only be calculated for signed transactions with an id
148
+ address: this._id ? await Utils.calculateOriginatedAddress(this._id, index) : '',
149
+ // Balance
150
+ value: operation.balance,
151
+ });
152
+ this._inputs.push({
153
+ address: operation.source,
154
+ // Balance + fees + max gas + max storage are paid by the source account
155
+ value: new bignumber_js_1.default(operation.balance).plus(operation.fee).toString(),
156
+ });
157
+ }
158
+ /**
159
+ * Record the most important fields from a reveal operation.
160
+ *
161
+ * @param {RevealOp} operation A reveal operation object from a Tezos transaction
162
+ */
163
+ recordRevealOpFields(operation) {
164
+ this._type = sdk_core_1.TransactionType.AccountUpdate;
165
+ this._publicKeyToReveal = operation.public_key;
166
+ this._inputs.push({
167
+ address: operation.source,
168
+ // Balance + fees + max gas + max storage are paid by the source account
169
+ value: operation.fee,
170
+ });
171
+ }
172
+ /**
173
+ * Record the most important fields for a Transaction operation.
174
+ *
175
+ * @param {TransactionOp} operation A transaction object from a Tezos operation
176
+ */
177
+ recordTransactionOpFields(operation) {
178
+ if (operation.parameters) {
179
+ this._type = sdk_core_1.TransactionType.Send;
180
+ }
181
+ else {
182
+ this._type = sdk_core_1.TransactionType.SingleSigSend;
183
+ }
184
+ const transferData = (0, multisigUtils_1.getMultisigTransferDataFromOperation)(operation);
185
+ // Fees are paid by the source account, along with the amount in the transaction
186
+ this._inputs.push({
187
+ address: operation.source,
188
+ value: new bignumber_js_1.default(transferData.fee.fee).toFixed(0),
189
+ });
190
+ if (transferData.coin === 'mutez') {
191
+ this._outputs.push({
192
+ // Kt addresses can only be calculated for signed transactions with an id
193
+ address: transferData.to,
194
+ // Balance
195
+ value: transferData.amount,
196
+ });
197
+ // The funds being transferred from the wallet
198
+ this._inputs.push({
199
+ address: transferData.from,
200
+ // Balance + fees + max gas + max storage are paid by the source account
201
+ value: transferData.amount,
202
+ });
203
+ }
204
+ }
205
+ /**
206
+ * Sign the transaction with the provided key. It does not check if the signer is allowed to sign
207
+ * it or not.
208
+ *
209
+ * @param {KeyPair} keyPair The key to sign the transaction with
210
+ */
211
+ async sign(keyPair) {
212
+ // TODO: fail if the transaction is already signed
213
+ // Check if there is a transaction to sign
214
+ if (!this._parsedTransaction) {
215
+ throw new sdk_core_1.InvalidTransactionError('Empty transaction');
216
+ }
217
+ // Get the transaction body to sign
218
+ const encodedTransaction = await local_forging_1.localForger.forge(this._parsedTransaction);
219
+ const signedTransaction = await Utils.sign(keyPair, encodedTransaction);
220
+ this._encodedTransaction = signedTransaction.sbytes;
221
+ // The transaction id can only be calculated for signed transactions
222
+ this._id = await Utils.calculateTransactionId(this._encodedTransaction);
223
+ await this.initFromParsedTransaction(this._parsedTransaction, this._id);
224
+ this._signatures.push(signedTransaction.sig);
225
+ }
226
+ /**
227
+ * Update the list of signatures for a multisig transaction operation.
228
+ *
229
+ * @param {IndexedSignature[]} signatures List of signatures and the index they should be put on
230
+ * in the multisig transfer
231
+ * @param {number} index The transfer index to add the signatures to
232
+ */
233
+ async addTransferSignature(signatures, index) {
234
+ if (!this._parsedTransaction) {
235
+ throw new sdk_core_1.InvalidTransactionError('Empty transaction');
236
+ }
237
+ (0, multisigUtils_1.updateMultisigTransferSignatures)(this._parsedTransaction.contents[index], signatures);
238
+ this._encodedTransaction = await local_forging_1.localForger.forge(this._parsedTransaction);
239
+ }
240
+ /** @inheritdoc */
241
+ canSign(key) {
242
+ // TODO: check the key belongs to the _source account in _parsedTransaction
243
+ return true;
244
+ }
245
+ /** @inheritdoc */
246
+ toJson() {
247
+ if (!this._parsedTransaction) {
248
+ throw new sdk_core_1.InvalidTransactionError('Empty transaction');
249
+ }
250
+ return this._parsedTransaction;
251
+ }
252
+ /** @inheritdoc */
253
+ toBroadcastFormat() {
254
+ if (!this._encodedTransaction) {
255
+ throw new sdk_core_1.InvalidTransactionError('Missing encoded transaction');
256
+ }
257
+ return this._encodedTransaction;
258
+ }
259
+ /**
260
+ * Get the transaction source if it is available.
261
+ *
262
+ * @returns {string} Source of the transaction
263
+ */
264
+ get source() {
265
+ if (!this._source) {
266
+ throw new sdk_core_1.InvalidTransactionError('Transaction not initialized');
267
+ }
268
+ return this._source;
269
+ }
270
+ /**
271
+ * Get the transaction delegation address if it is available.
272
+ *
273
+ * @returns {string} transaction delegation address
274
+ */
275
+ get delegate() {
276
+ return this._delegate;
277
+ }
278
+ /**
279
+ * Get the public key revealed by the transaction if it exists
280
+ *
281
+ * @returns {string} public key
282
+ */
283
+ get publicKeyToReveal() {
284
+ return this._publicKeyToReveal;
285
+ }
286
+ /**
287
+ * Get the destination of an address initialization transaction if it exists
288
+ *
289
+ * @returns {string} forwarder destination
290
+ */
291
+ get forwarderDestination() {
292
+ return this._forwarderDestination;
293
+ }
294
+ get owners() {
295
+ return this._owners;
296
+ }
297
+ /**
298
+ * Get the signatures for the given multisig transfer,
299
+ *
300
+ * @param {number} transferIndex The transfer script index in the Tezos transaction
301
+ * @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer
302
+ * script
303
+ */
304
+ getTransferSignatures(transferIndex = 0) {
305
+ if (!this._parsedTransaction) {
306
+ return [];
307
+ }
308
+ return (0, multisigUtils_1.getMultisigTransferSignatures)(this._parsedTransaction.contents[transferIndex]);
309
+ }
310
+ /**
311
+ * Get the list of index per tezos transaction type. This is useful to locate specific operations
312
+ * within the transaction and verify or sign them.
313
+ *
314
+ * @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind
315
+ */
316
+ getIndexesByTransactionType() {
317
+ if (!this._parsedTransaction) {
318
+ return {};
319
+ }
320
+ const indexes = {};
321
+ for (let i = 0; i < this._parsedTransaction.contents.length; i++) {
322
+ const kind = this._parsedTransaction.contents[i].kind;
323
+ indexes[kind] = indexes[kind] ? indexes[kind].concat([i]) : [i];
324
+ }
325
+ return indexes;
326
+ }
327
+ }
328
+ exports.Transaction = Transaction;
329
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  ParseTransactionError,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { CODEC, localForger } from '@taquito/local-forging';\nimport BigNumber from 'bignumber.js';\nimport { IndexedSignature, OriginationOp, ParsedTransaction, RevealOp, TransactionOp } from './iface';\nimport { KeyPair } from './keyPair';\nimport {\n  getMultisigTransferDataFromOperation,\n  getMultisigTransferSignatures,\n  getOriginationDataFromOperation,\n  getOwnersPublicKeys,\n  updateMultisigTransferSignatures,\n} from './multisigUtils';\nimport * as Utils from './utils';\n\n/**\n * Tezos transaction model.\n */\nexport class Transaction extends BaseTransaction {\n  private _parsedTransaction?: ParsedTransaction; // transaction in JSON format\n  private _encodedTransaction?: string; // transaction in hex format\n  private _source: string;\n  private _delegate?: string;\n  private _forwarderDestination?: string;\n  private _publicKeyToReveal?: string;\n  private _owners: string[];\n\n  /**\n   * Public constructor.\n   *\n   * @param {Readonly<CoinConfig>} coinConfig\n   */\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._owners = [];\n  }\n\n  /**\n   * Initialize the transaction fields based on another serialized transaction.\n   *\n   * @param serializedTransaction Transaction in broadcast format.\n   */\n  async initFromSerializedTransaction(serializedTransaction: string): Promise<void> {\n    this._encodedTransaction = serializedTransaction;\n    try {\n      const parsedTransaction = await localForger.parse(serializedTransaction);\n      await this.initFromParsedTransaction(parsedTransaction);\n    } catch (e) {\n      // If it throws, it is possible the serialized transaction is signed, which is not supported\n      // by local-forging. Try extracting the last 64 bytes and parse it again.\n      const unsignedSerializedTransaction = serializedTransaction.slice(0, -128);\n      const signature = serializedTransaction.slice(-128);\n      if (Utils.isValidSignature(signature)) {\n        throw new ParseTransactionError('Invalid transaction');\n      }\n      // TODO: encode the signature and save it in _signature\n      const parsedTransaction = await localForger.parse(unsignedSerializedTransaction);\n      const transactionId = await Utils.calculateTransactionId(serializedTransaction);\n      await this.initFromParsedTransaction(parsedTransaction, transactionId);\n    }\n  }\n\n  /**\n   * Initialize the transaction fields based on another parsed transaction.\n   *\n   * @param {ParsedTransaction} parsedTransaction A Tezos transaction object\n   * @param {string} transactionId The transaction id of the parsedTransaction if it is signed\n   */\n  async initFromParsedTransaction(parsedTransaction: ParsedTransaction, transactionId?: string): Promise<void> {\n    if (!this._encodedTransaction) {\n      this._encodedTransaction = await localForger.forge(parsedTransaction);\n    }\n    if (transactionId) {\n      // If the transaction id is passed, save it and clean up the entries since they will be\n      // recalculated\n      this._id = transactionId;\n      this._inputs = [];\n      this._outputs = [];\n    } else {\n      this._id = '';\n    }\n    this._parsedTransaction = parsedTransaction;\n    let operationIndex = 0;\n    for (const operation of parsedTransaction.contents) {\n      if (this._source && this._source !== operation.source) {\n        throw new InvalidTransactionError(\n          'Source must be the same for every operation but it changed from ' + this._source + ' to ' + operation.source\n        );\n      } else {\n        this._source = operation.source;\n      }\n      switch (operation.kind) {\n        case CODEC.OP_ORIGINATION:\n          await this.recordOriginationOpFields(operation as OriginationOp, operationIndex);\n          operationIndex++;\n          break;\n        case CODEC.OP_REVEAL:\n          this.recordRevealOpFields(operation as RevealOp);\n          break;\n        case CODEC.OP_TRANSACTION:\n          this.recordTransactionOpFields(operation as TransactionOp);\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  /**\n   * Record the most important fields from an origination operation.\n   *\n   * @param {Operation} operation An operation object from a Tezos transaction\n   * @param {number} index The origination operation index in the transaction. Used to calculate the\n   *      originated address\n   */\n  private async recordOriginationOpFields(operation: OriginationOp, index: number): Promise<void> {\n    const originationData = getOriginationDataFromOperation(operation);\n    if (originationData.forwarderDestination) {\n      this._type = TransactionType.AddressInitialization;\n      this._forwarderDestination = originationData.forwarderDestination;\n    } else {\n      this._type = TransactionType.WalletInitialization;\n      this._owners = getOwnersPublicKeys(operation);\n    }\n\n    this._delegate = operation.delegate;\n    this._outputs.push({\n      // Kt addresses can only be calculated for signed transactions with an id\n      address: this._id ? await Utils.calculateOriginatedAddress(this._id, index) : '',\n      // Balance\n      value: operation.balance,\n    });\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: new BigNumber(operation.balance).plus(operation.fee).toString(),\n    });\n  }\n\n  /**\n   * Record the most important fields from a reveal operation.\n   *\n   * @param {RevealOp} operation A reveal operation object from a Tezos transaction\n   */\n  private recordRevealOpFields(operation: RevealOp): void {\n    this._type = TransactionType.AccountUpdate;\n    this._publicKeyToReveal = operation.public_key;\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: operation.fee,\n    });\n  }\n\n  /**\n   * Record the most important fields for a Transaction operation.\n   *\n   * @param {TransactionOp} operation A transaction object from a Tezos operation\n   */\n  private recordTransactionOpFields(operation: TransactionOp): void {\n    if (operation.parameters) {\n      this._type = TransactionType.Send;\n    } else {\n      this._type = TransactionType.SingleSigSend;\n    }\n    const transferData = getMultisigTransferDataFromOperation(operation);\n    // Fees are paid by the source account, along with the amount in the transaction\n    this._inputs.push({\n      address: operation.source,\n      value: new BigNumber(transferData.fee.fee).toFixed(0),\n    });\n\n    if (transferData.coin === 'mutez') {\n      this._outputs.push({\n        // Kt addresses can only be calculated for signed transactions with an id\n        address: transferData.to,\n        // Balance\n        value: transferData.amount,\n      });\n      // The funds being transferred from the wallet\n      this._inputs.push({\n        address: transferData.from,\n        // Balance + fees + max gas + max storage are paid by the source account\n        value: transferData.amount,\n      });\n    }\n  }\n\n  /**\n   * Sign the transaction with the provided key. It does not check if the signer is allowed to sign\n   * it or not.\n   *\n   * @param {KeyPair} keyPair The key to sign the transaction with\n   */\n  async sign(keyPair: KeyPair): Promise<void> {\n    // TODO: fail if the transaction is already signed\n    // Check if there is a transaction to sign\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    // Get the transaction body to sign\n    const encodedTransaction = await localForger.forge(this._parsedTransaction);\n\n    const signedTransaction = await Utils.sign(keyPair, encodedTransaction);\n    this._encodedTransaction = signedTransaction.sbytes;\n\n    // The transaction id can only be calculated for signed transactions\n    this._id = await Utils.calculateTransactionId(this._encodedTransaction);\n    await this.initFromParsedTransaction(this._parsedTransaction, this._id);\n\n    this._signatures.push(signedTransaction.sig);\n  }\n\n  /**\n   * Update the list of signatures for a multisig transaction operation.\n   *\n   * @param {IndexedSignature[]} signatures List of signatures and the index they should be put on\n   *    in the multisig transfer\n   * @param {number} index The transfer index to add the signatures to\n   */\n  async addTransferSignature(signatures: IndexedSignature[], index: number): Promise<void> {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    updateMultisigTransferSignatures(this._parsedTransaction.contents[index] as TransactionOp, signatures);\n    this._encodedTransaction = await localForger.forge(this._parsedTransaction);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    // TODO: check the key belongs to the _source account in _parsedTransaction\n    return true;\n  }\n\n  /** @inheritdoc */\n  toJson(): ParsedTransaction {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this._parsedTransaction;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._encodedTransaction) {\n      throw new InvalidTransactionError('Missing encoded transaction');\n    }\n    return this._encodedTransaction;\n  }\n\n  /**\n   * Get the transaction source if it is available.\n   *\n   * @returns {string} Source of the transaction\n   */\n  get source(): string {\n    if (!this._source) {\n      throw new InvalidTransactionError('Transaction not initialized');\n    }\n    return this._source;\n  }\n\n  /**\n   * Get the transaction delegation address if it is available.\n   *\n   * @returns {string} transaction delegation address\n   */\n  get delegate(): string | undefined {\n    return this._delegate;\n  }\n\n  /**\n   * Get the public key revealed by the transaction if it exists\n   *\n   * @returns {string} public key\n   */\n  get publicKeyToReveal(): string | undefined {\n    return this._publicKeyToReveal;\n  }\n\n  /**\n   * Get the destination of an address initialization transaction if it exists\n   *\n   * @returns {string} forwarder destination\n   */\n  get forwarderDestination(): string | undefined {\n    return this._forwarderDestination;\n  }\n\n  get owners(): string[] {\n    return this._owners;\n  }\n\n  /**\n   * Get the signatures for the given multisig transfer,\n   *\n   * @param {number} transferIndex The transfer script index in the Tezos transaction\n   * @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer\n   *      script\n   */\n  getTransferSignatures(transferIndex = 0): IndexedSignature[] {\n    if (!this._parsedTransaction) {\n      return [];\n    }\n    return getMultisigTransferSignatures(this._parsedTransaction.contents[transferIndex] as TransactionOp);\n  }\n\n  /**\n   * Get the list of index per tezos transaction type. This is useful to locate specific operations\n   * within the transaction and verify or sign them.\n   *\n   * @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind\n   */\n  getIndexesByTransactionType(): { [kind: string]: number[] } {\n    if (!this._parsedTransaction) {\n      return {};\n    }\n    const indexes = {};\n    for (let i = 0; i < this._parsedTransaction.contents.length; i++) {\n      const kind = this._parsedTransaction.contents[i].kind;\n      indexes[kind] = indexes[kind] ? indexes[kind].concat([i]) : [i];\n    }\n    return indexes;\n  }\n}\n"]}
@@ -0,0 +1,171 @@
1
+ import { BaseKey, BaseTransactionBuilder, TransactionType } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import BigNumber from 'bignumber.js';
4
+ import { Address } from './address';
5
+ import { Fee, IndexedData, Key } from './iface';
6
+ import { Transaction } from './transaction';
7
+ import { TransferBuilder } from './transferBuilder';
8
+ interface DataToSignOverride extends IndexedData {
9
+ dataToSign: string;
10
+ }
11
+ /**
12
+ * Tezos transaction builder.
13
+ */
14
+ export declare class TransactionBuilder extends BaseTransactionBuilder {
15
+ private _serializedTransaction;
16
+ private _transaction;
17
+ private _type;
18
+ private _blockHeader;
19
+ private _counter;
20
+ private _fee;
21
+ private _sourceAddress;
22
+ private _sourceKeyPair?;
23
+ private _publicKeyToReveal;
24
+ private _initialBalance;
25
+ private _initialDelegate;
26
+ private _walletOwnerPublicKeys;
27
+ private _multisigSignerKeyPairs;
28
+ private _dataToSignOverride;
29
+ private _transfers;
30
+ private _forwarderDestination;
31
+ /**
32
+ * Public constructor.
33
+ *
34
+ * @param {CoinConfig} _coinConfig - coin configuration
35
+ */
36
+ constructor(_coinConfig: Readonly<CoinConfig>);
37
+ /** @inheritdoc */
38
+ protected fromImplementation(rawTransaction: string): Transaction;
39
+ /** @inheritdoc */
40
+ protected signImplementation(key: Key): Transaction;
41
+ /** @inheritdoc */
42
+ protected buildImplementation(): Promise<Transaction>;
43
+ /**
44
+ * Set the transaction branch id.
45
+ *
46
+ * @param {string} blockId A block hash to use as branch reference
47
+ */
48
+ branch(blockId: string): void;
49
+ /**
50
+ * The type of transaction being built.
51
+ *
52
+ * @param {TransactionType} type - type of the transaction
53
+ */
54
+ type(type: TransactionType): void;
55
+ /**
56
+ * Set the transaction fees. Low fees may get a transaction rejected or never picked up by bakers.
57
+ *
58
+ * @param {Fee} fee Baker fees. May also include the maximum gas and storage fees to pay
59
+ */
60
+ fee(fee: Fee): void;
61
+ /**
62
+ * Set the transaction initiator. This account will pay for the transaction fees, but it will not
63
+ * be added as an owner of a wallet in a init transaction, unless manually set as one of the
64
+ * owners.
65
+ *
66
+ * @param {string} source A Tezos address
67
+ */
68
+ source(source: string): void;
69
+ /**
70
+ * Set an amount of mutez to transfer in this transaction this transaction. This is different than
71
+ * the amount to transfer from a multisig wallet.
72
+ *
73
+ * @param {string} amount Amount in mutez (1/1000000 Tezies)
74
+ */
75
+ initialBalance(amount: string): void;
76
+ /**
77
+ * Set the transaction counter to prevent submitting repeated transactions.
78
+ *
79
+ * @param {string} counter The counter to use
80
+ */
81
+ counter(counter: string): void;
82
+ /**
83
+ * Set the destination address of a forwarder contract
84
+ * Used in forwarder contract deployment as destination address
85
+ *
86
+ * @param {string} contractAddress - contract address to use
87
+ */
88
+ forwarderDestination(contractAddress: string): void;
89
+ /**
90
+ * The public key to reveal.
91
+ *
92
+ * @param {string} publicKey A Tezos public key
93
+ */
94
+ publicKeyToReveal(publicKey: string): void;
95
+ /**
96
+ * Build a reveal operation for the source account with default fees.
97
+ *
98
+ * @returns {RevealOp} A Tezos reveal operation
99
+ */
100
+ private buildPublicKeyRevelationOperation;
101
+ /**
102
+ * Set one of the owners of the multisig wallet.
103
+ *
104
+ * @param {string} publicKey A Tezos public key
105
+ */
106
+ owner(publicKey: string): void;
107
+ /**
108
+ * Set an initial delegate to initialize this wallet to. This is different than the delegation to
109
+ * set while doing a separate delegation transaction.
110
+ *
111
+ * @param {string} delegate The address to delegate the funds to
112
+ */
113
+ initialDelegate(delegate: string): void;
114
+ /**
115
+ * Build an origination operation for a generic multisig contract.
116
+ *
117
+ * @returns {Operation} A Tezos origination operation
118
+ */
119
+ private buildWalletInitializationOperations;
120
+ /**
121
+ * Initialize a new TransferBuilder to for a singlesig or multisig transaction.
122
+ *
123
+ * @param {string} amount Amount in mutez to be transferred
124
+ * @returns {TransferBuilder} A transfer builder
125
+ */
126
+ transfer(amount: string): TransferBuilder;
127
+ /**
128
+ * Calculate the signatures for the multisig transaction.
129
+ *
130
+ * @param {string} packedData The string in hexadecimal to sign
131
+ * @returns {Promise<string[]>} List of signatures for packedData
132
+ */
133
+ private getSignatures;
134
+ /**
135
+ * Override the data to sign for a specific transfer. Used for offline signing to pass the
136
+ * respective dataToSign for transfer at a particular index.
137
+ *
138
+ * @param {DataToSignOverride} data - data to override
139
+ */
140
+ overrideDataToSign(data: DataToSignOverride): void;
141
+ /**
142
+ * Build a transaction operation for a generic multisig contract.
143
+ *
144
+ * @returns {Promise<TransactionOp[]>} A Tezos transaction operation
145
+ */
146
+ private buildSendTransactionContent;
147
+ /**
148
+ * Build a transaction operation for a forwarder contract
149
+ *
150
+ * @returns {OriginationOp} a Tezos transaction operation
151
+ */
152
+ private buildForwarderDeploymentContent;
153
+ /** @inheritdoc */
154
+ validateValue(value: BigNumber): void;
155
+ /** @inheritdoc */
156
+ validateAddress(address: Address): void;
157
+ /** @inheritdoc */
158
+ validateKey(key: BaseKey): void;
159
+ /** @inheritdoc */
160
+ validateRawTransaction(rawTransaction: any): void;
161
+ /** @inheritdoc */
162
+ validateTransaction(transaction: Transaction): void;
163
+ /** @inheritdoc */
164
+ displayName(): string;
165
+ /** @inheritdoc */
166
+ protected get transaction(): Transaction;
167
+ /** @inheritdoc */
168
+ protected set transaction(transaction: Transaction);
169
+ }
170
+ export {};
171
+ //# sourceMappingURL=transactionBuilder.d.ts.map