@bitgo-beta/sdk-coin-ton 1.0.1-beta.76 → 1.0.1-beta.761
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.
- package/CHANGELOG.md +565 -0
- package/dist/src/index.js +6 -2
- package/dist/src/lib/iface.d.ts +5 -0
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.js +23 -9
- package/dist/src/lib/keyPair.js +24 -10
- package/dist/src/lib/singleNominatorWithdrawBuilder.d.ts +11 -0
- package/dist/src/lib/singleNominatorWithdrawBuilder.d.ts.map +1 -0
- package/dist/src/lib/singleNominatorWithdrawBuilder.js +26 -0
- package/dist/src/lib/transaction.d.ts +13 -5
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +63 -26
- package/dist/src/lib/transactionBuilder.d.ts +23 -1
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +43 -2
- package/dist/src/lib/transactionBuilderFactory.d.ts +5 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +29 -4
- package/dist/src/lib/transactionExplanation.d.ts +14 -0
- package/dist/src/lib/transactionExplanation.d.ts.map +1 -0
- package/dist/src/lib/transactionExplanation.js +3 -0
- package/dist/src/lib/utils.d.ts +13 -1
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +51 -4
- package/dist/src/ton.d.ts +22 -2
- package/dist/src/ton.d.ts.map +1 -1
- package/dist/src/ton.js +274 -16
- package/dist/src/tton.js +1 -1
- package/package.json +8 -8
package/dist/src/ton.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
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);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
11
15
|
}) : function(o, v) {
|
|
12
16
|
o["default"] = v;
|
|
13
17
|
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
};
|
|
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
|
+
})();
|
|
21
35
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
37
|
};
|
|
@@ -30,6 +44,8 @@ const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
|
30
44
|
const _ = __importStar(require("lodash"));
|
|
31
45
|
const lib_1 = require("./lib");
|
|
32
46
|
const tonweb_1 = __importDefault(require("tonweb"));
|
|
47
|
+
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
48
|
+
const utils_1 = require("./lib/utils");
|
|
33
49
|
class Ton extends sdk_core_1.BaseCoin {
|
|
34
50
|
constructor(bitgo, staticsCoin) {
|
|
35
51
|
super(bitgo);
|
|
@@ -60,14 +76,31 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
60
76
|
supportsTss() {
|
|
61
77
|
return true;
|
|
62
78
|
}
|
|
79
|
+
/** inherited doc */
|
|
80
|
+
getDefaultMultisigType() {
|
|
81
|
+
return sdk_core_1.multisigTypes.tss;
|
|
82
|
+
}
|
|
63
83
|
getMPCAlgorithm() {
|
|
64
84
|
return 'eddsa';
|
|
65
85
|
}
|
|
66
86
|
allowsAccountConsolidations() {
|
|
67
87
|
return true;
|
|
68
88
|
}
|
|
89
|
+
getAddressDetails(address) {
|
|
90
|
+
const addressComponents = address.split('?memoId=');
|
|
91
|
+
if (addressComponents.length > 1) {
|
|
92
|
+
return {
|
|
93
|
+
address: addressComponents[0],
|
|
94
|
+
memoId: addressComponents[1],
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
return {
|
|
99
|
+
address: addressComponents[0],
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
69
103
|
async verifyTransaction(params) {
|
|
70
|
-
var _a;
|
|
71
104
|
const coinConfig = statics_1.coins.get(this.getChain());
|
|
72
105
|
const { txPrebuild: txPrebuild, txParams: txParams } = params;
|
|
73
106
|
const transaction = new lib_1.Transaction(coinConfig);
|
|
@@ -78,13 +111,19 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
78
111
|
transaction.fromRawTransaction(Buffer.from(rawTx, 'hex').toString('base64'));
|
|
79
112
|
const explainedTx = transaction.explainTransaction();
|
|
80
113
|
if (txParams.recipients !== undefined) {
|
|
81
|
-
const filteredRecipients =
|
|
114
|
+
const filteredRecipients = txParams.recipients?.map((recipient) => {
|
|
115
|
+
const destination = this.getAddressDetails(recipient.address);
|
|
82
116
|
return {
|
|
83
|
-
address: new tonweb_1.default.Address(
|
|
84
|
-
amount: recipient.amount,
|
|
117
|
+
address: new tonweb_1.default.Address(destination.address).toString(true, true, true),
|
|
118
|
+
amount: BigInt(recipient.amount),
|
|
119
|
+
};
|
|
120
|
+
});
|
|
121
|
+
const filteredOutputs = explainedTx.outputs.map((output) => {
|
|
122
|
+
return {
|
|
123
|
+
address: new tonweb_1.default.Address(output.address).toString(true, true, true),
|
|
124
|
+
amount: BigInt(output.amount),
|
|
85
125
|
};
|
|
86
126
|
});
|
|
87
|
-
const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount']));
|
|
88
127
|
if (!_.isEqual(filteredOutputs, filteredRecipients)) {
|
|
89
128
|
throw new Error('Tx outputs does not match with expected txParams recipients');
|
|
90
129
|
}
|
|
@@ -107,12 +146,16 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
107
146
|
throw new Error('missing required param keychains');
|
|
108
147
|
}
|
|
109
148
|
for (const keychain of keychains) {
|
|
149
|
+
const [address, memoId] = newAddress.split('?memoId=');
|
|
110
150
|
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
|
|
111
151
|
const commonKeychain = keychain.commonKeychain;
|
|
112
152
|
const derivationPath = 'm/' + index;
|
|
113
153
|
const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);
|
|
114
154
|
const expectedAddress = await lib_1.Utils.default.getAddressFromPublicKey(derivedPublicKey);
|
|
115
|
-
if (
|
|
155
|
+
if (memoId) {
|
|
156
|
+
return memoId === `${index}`;
|
|
157
|
+
}
|
|
158
|
+
if (address !== expectedAddress) {
|
|
116
159
|
return false;
|
|
117
160
|
}
|
|
118
161
|
}
|
|
@@ -121,6 +164,12 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
121
164
|
async parseTransaction(params) {
|
|
122
165
|
const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
123
166
|
const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));
|
|
167
|
+
if (typeof params.toAddressBounceable === 'boolean') {
|
|
168
|
+
transactionBuilder.toAddressBounceable(params.toAddressBounceable);
|
|
169
|
+
}
|
|
170
|
+
if (typeof params.fromAddressBounceable === 'boolean') {
|
|
171
|
+
transactionBuilder.fromAddressBounceable(params.fromAddressBounceable);
|
|
172
|
+
}
|
|
124
173
|
const rebuiltTransaction = await transactionBuilder.build();
|
|
125
174
|
const parsedTransaction = rebuiltTransaction.toJson();
|
|
126
175
|
return {
|
|
@@ -155,7 +204,7 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
155
204
|
isValidAddress(address) {
|
|
156
205
|
try {
|
|
157
206
|
const addressBase64 = address.replace(/\+/g, '-').replace(/\//g, '_');
|
|
158
|
-
const buf = Buffer.from(addressBase64, 'base64');
|
|
207
|
+
const buf = Buffer.from(addressBase64.split('?memoId=')[0], 'base64');
|
|
159
208
|
return buf.length === 36;
|
|
160
209
|
}
|
|
161
210
|
catch {
|
|
@@ -176,6 +225,13 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
176
225
|
try {
|
|
177
226
|
const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
178
227
|
const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));
|
|
228
|
+
const { toAddressBounceable, fromAddressBounceable } = params;
|
|
229
|
+
if (typeof toAddressBounceable === 'boolean') {
|
|
230
|
+
transactionBuilder.toAddressBounceable(toAddressBounceable);
|
|
231
|
+
}
|
|
232
|
+
if (typeof fromAddressBounceable === 'boolean') {
|
|
233
|
+
transactionBuilder.fromAddressBounceable(fromAddressBounceable);
|
|
234
|
+
}
|
|
179
235
|
const rebuiltTransaction = await transactionBuilder.build();
|
|
180
236
|
return rebuiltTransaction.explainTransaction();
|
|
181
237
|
}
|
|
@@ -183,6 +239,208 @@ class Ton extends sdk_core_1.BaseCoin {
|
|
|
183
239
|
throw new Error('Invalid transaction');
|
|
184
240
|
}
|
|
185
241
|
}
|
|
242
|
+
getPublicNodeUrl() {
|
|
243
|
+
return sdk_core_1.Environments[this.bitgo.getEnv()].tonNodeUrl;
|
|
244
|
+
}
|
|
245
|
+
getBuilder() {
|
|
246
|
+
return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
247
|
+
}
|
|
248
|
+
async recover(params) {
|
|
249
|
+
if (!params.bitgoKey) {
|
|
250
|
+
throw new Error('missing bitgoKey');
|
|
251
|
+
}
|
|
252
|
+
if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
|
|
253
|
+
throw new Error('invalid recoveryDestination');
|
|
254
|
+
}
|
|
255
|
+
if (!params.apiKey) {
|
|
256
|
+
throw new Error('missing apiKey');
|
|
257
|
+
}
|
|
258
|
+
const bitgoKey = params.bitgoKey.replace(/\s/g, '');
|
|
259
|
+
const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;
|
|
260
|
+
// Build the transaction
|
|
261
|
+
const tonweb = new tonweb_1.default(new tonweb_1.default.HttpProvider(this.getPublicNodeUrl(), { apiKey: params.apiKey }));
|
|
262
|
+
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
|
|
263
|
+
const index = params.index || 0;
|
|
264
|
+
const currPath = params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) + `/${index}` : `m/${index}`;
|
|
265
|
+
const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);
|
|
266
|
+
const senderAddr = await lib_1.Utils.default.getAddressFromPublicKey(accountId);
|
|
267
|
+
const balance = await tonweb.getBalance(senderAddr);
|
|
268
|
+
if (new bignumber_js_1.default(balance).isEqualTo(0)) {
|
|
269
|
+
throw Error('Did not find address with funds to recover');
|
|
270
|
+
}
|
|
271
|
+
const WalletClass = tonweb.wallet.all['v4R2'];
|
|
272
|
+
const wallet = new WalletClass(tonweb.provider, {
|
|
273
|
+
publicKey: tonweb.utils.hexToBytes(accountId),
|
|
274
|
+
wc: 0,
|
|
275
|
+
});
|
|
276
|
+
let seqno = await wallet.methods.seqno().call();
|
|
277
|
+
if (seqno === null) {
|
|
278
|
+
seqno = 0;
|
|
279
|
+
}
|
|
280
|
+
const feeEstimate = await (0, utils_1.getFeeEstimate)(wallet, params.recoveryDestination, balance, seqno);
|
|
281
|
+
const totalFeeEstimate = Math.round((feeEstimate.source_fees.in_fwd_fee +
|
|
282
|
+
feeEstimate.source_fees.storage_fee +
|
|
283
|
+
feeEstimate.source_fees.gas_fee +
|
|
284
|
+
feeEstimate.source_fees.fwd_fee) *
|
|
285
|
+
1.5);
|
|
286
|
+
if (new bignumber_js_1.default(totalFeeEstimate).gt(balance)) {
|
|
287
|
+
throw Error('Did not find address with funds to recover');
|
|
288
|
+
}
|
|
289
|
+
const factory = this.getBuilder();
|
|
290
|
+
const expireAt = Math.floor(Date.now() / 1e3) + 60 * 60 * 24 * 7; // 7 days
|
|
291
|
+
const txBuilder = factory
|
|
292
|
+
.getTransferBuilder()
|
|
293
|
+
.sender(senderAddr)
|
|
294
|
+
.sequenceNumber(seqno)
|
|
295
|
+
.publicKey(accountId)
|
|
296
|
+
.expireTime(expireAt);
|
|
297
|
+
txBuilder.send({
|
|
298
|
+
address: params.recoveryDestination,
|
|
299
|
+
amount: new bignumber_js_1.default(balance).minus(new bignumber_js_1.default(totalFeeEstimate)).toString(),
|
|
300
|
+
});
|
|
301
|
+
const unsignedTransaction = await txBuilder.build();
|
|
302
|
+
if (!isUnsignedSweep) {
|
|
303
|
+
if (!params.userKey) {
|
|
304
|
+
throw new Error('missing userKey');
|
|
305
|
+
}
|
|
306
|
+
if (!params.backupKey) {
|
|
307
|
+
throw new Error('missing backupKey');
|
|
308
|
+
}
|
|
309
|
+
if (!params.walletPassphrase) {
|
|
310
|
+
throw new Error('missing wallet passphrase');
|
|
311
|
+
}
|
|
312
|
+
// Clean up whitespace from entered values
|
|
313
|
+
const userKey = params.userKey.replace(/\s/g, '');
|
|
314
|
+
const backupKey = params.backupKey.replace(/\s/g, '');
|
|
315
|
+
let userPrv;
|
|
316
|
+
try {
|
|
317
|
+
userPrv = this.bitgo.decrypt({
|
|
318
|
+
input: userKey,
|
|
319
|
+
password: params.walletPassphrase,
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
catch (e) {
|
|
323
|
+
throw new Error(`Error decrypting user keychain: ${e.message}`);
|
|
324
|
+
}
|
|
325
|
+
const userSigningMaterial = JSON.parse(userPrv);
|
|
326
|
+
let backupPrv;
|
|
327
|
+
try {
|
|
328
|
+
backupPrv = this.bitgo.decrypt({
|
|
329
|
+
input: backupKey,
|
|
330
|
+
password: params.walletPassphrase,
|
|
331
|
+
});
|
|
332
|
+
}
|
|
333
|
+
catch (e) {
|
|
334
|
+
throw new Error(`Error decrypting backup keychain: ${e.message}`);
|
|
335
|
+
}
|
|
336
|
+
const backupSigningMaterial = JSON.parse(backupPrv);
|
|
337
|
+
const signatureHex = await sdk_core_1.EDDSAMethods.getTSSSignature(userSigningMaterial, backupSigningMaterial, currPath, unsignedTransaction);
|
|
338
|
+
const publicKeyObj = { pub: senderAddr };
|
|
339
|
+
txBuilder.addSignature(publicKeyObj, signatureHex);
|
|
340
|
+
}
|
|
341
|
+
const completedTransaction = await txBuilder.build();
|
|
342
|
+
const serializedTx = completedTransaction.toBroadcastFormat();
|
|
343
|
+
const walletCoin = this.getChain();
|
|
344
|
+
const inputs = [];
|
|
345
|
+
for (const input of completedTransaction.inputs) {
|
|
346
|
+
inputs.push({
|
|
347
|
+
address: input.address,
|
|
348
|
+
valueString: input.value,
|
|
349
|
+
value: new bignumber_js_1.default(input.value).toNumber(),
|
|
350
|
+
});
|
|
351
|
+
}
|
|
352
|
+
const outputs = [];
|
|
353
|
+
for (const output of completedTransaction.outputs) {
|
|
354
|
+
outputs.push({
|
|
355
|
+
address: output.address,
|
|
356
|
+
valueString: output.value,
|
|
357
|
+
coinName: output.coin,
|
|
358
|
+
});
|
|
359
|
+
}
|
|
360
|
+
const spendAmount = completedTransaction.inputs.length === 1 ? completedTransaction.inputs[0].value : 0;
|
|
361
|
+
const parsedTx = { inputs: inputs, outputs: outputs, spendAmount: spendAmount, type: '' };
|
|
362
|
+
const feeInfo = { fee: totalFeeEstimate, feeString: totalFeeEstimate.toString() };
|
|
363
|
+
const coinSpecific = { commonKeychain: bitgoKey };
|
|
364
|
+
if (isUnsignedSweep) {
|
|
365
|
+
const transaction = {
|
|
366
|
+
serializedTx: serializedTx,
|
|
367
|
+
scanIndex: index,
|
|
368
|
+
coin: walletCoin,
|
|
369
|
+
signableHex: completedTransaction.signablePayload.toString('hex'),
|
|
370
|
+
derivationPath: currPath,
|
|
371
|
+
parsedTx: parsedTx,
|
|
372
|
+
feeInfo: feeInfo,
|
|
373
|
+
coinSpecific: coinSpecific,
|
|
374
|
+
};
|
|
375
|
+
const unsignedTx = { unsignedTx: transaction, signatureShares: [] };
|
|
376
|
+
const transactions = [unsignedTx];
|
|
377
|
+
const txRequest = {
|
|
378
|
+
transactions: transactions,
|
|
379
|
+
walletCoin: walletCoin,
|
|
380
|
+
};
|
|
381
|
+
const txRequests = { txRequests: [txRequest] };
|
|
382
|
+
return txRequests;
|
|
383
|
+
}
|
|
384
|
+
const transaction = {
|
|
385
|
+
serializedTx: serializedTx,
|
|
386
|
+
scanIndex: index,
|
|
387
|
+
};
|
|
388
|
+
return transaction;
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* Creates funds sweep recovery transaction(s) without BitGo
|
|
392
|
+
*
|
|
393
|
+
* @param {MPCSweepRecoveryOptions} params parameters needed to combine the signatures
|
|
394
|
+
* and transactions to create broadcastable transactions
|
|
395
|
+
*
|
|
396
|
+
* @returns {MPCTxs} array of the serialized transaction hex strings and indices
|
|
397
|
+
* of the addresses being swept
|
|
398
|
+
*/
|
|
399
|
+
async createBroadcastableSweepTransaction(params) {
|
|
400
|
+
const req = params.signatureShares;
|
|
401
|
+
const broadcastableTransactions = [];
|
|
402
|
+
let lastScanIndex = 0;
|
|
403
|
+
for (let i = 0; i < req.length; i++) {
|
|
404
|
+
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
|
|
405
|
+
const transaction = req[i].txRequest.transactions[0].unsignedTx;
|
|
406
|
+
if (!req[i].ovc || !req[i].ovc[0].eddsaSignature) {
|
|
407
|
+
throw new Error('Missing signature(s)');
|
|
408
|
+
}
|
|
409
|
+
const signature = req[i].ovc[0].eddsaSignature;
|
|
410
|
+
if (!transaction.signableHex) {
|
|
411
|
+
throw new Error('Missing signable hex');
|
|
412
|
+
}
|
|
413
|
+
const messageBuffer = Buffer.from(transaction.signableHex, 'hex');
|
|
414
|
+
const result = MPC.verify(messageBuffer, signature);
|
|
415
|
+
if (!result) {
|
|
416
|
+
throw new Error('Invalid signature');
|
|
417
|
+
}
|
|
418
|
+
const signatureHex = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
|
|
419
|
+
const txBuilder = this.getBuilder().from(transaction.serializedTx);
|
|
420
|
+
if (!transaction.coinSpecific?.commonKeychain) {
|
|
421
|
+
throw new Error('Missing common keychain');
|
|
422
|
+
}
|
|
423
|
+
const commonKeychain = transaction.coinSpecific.commonKeychain;
|
|
424
|
+
if (!transaction.derivationPath) {
|
|
425
|
+
throw new Error('Missing derivation path');
|
|
426
|
+
}
|
|
427
|
+
const derivationPath = transaction.derivationPath;
|
|
428
|
+
const accountId = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);
|
|
429
|
+
const tonKeyPair = new keyPair_1.KeyPair({ pub: accountId });
|
|
430
|
+
// add combined signature from ovc
|
|
431
|
+
txBuilder.addSignature({ pub: tonKeyPair.getKeys().pub }, signatureHex);
|
|
432
|
+
const signedTransaction = await txBuilder.build();
|
|
433
|
+
const serializedTx = signedTransaction.toBroadcastFormat();
|
|
434
|
+
broadcastableTransactions.push({
|
|
435
|
+
serializedTx: serializedTx,
|
|
436
|
+
scanIndex: transaction.scanIndex,
|
|
437
|
+
});
|
|
438
|
+
if (i === req.length - 1 && transaction.coinSpecific.lastScanIndex) {
|
|
439
|
+
lastScanIndex = transaction.coinSpecific.lastScanIndex;
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
return { transactions: broadcastableTransactions, lastScanIndex };
|
|
443
|
+
}
|
|
186
444
|
}
|
|
187
445
|
exports.Ton = Ton;
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ton.js","sourceRoot":"","sources":["../../src/ton.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BitGoBase,\n  EDDSAMethods,\n  InvalidAddressError,\n  KeyPair,\n  MPCAlgorithm,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  TransactionExplanation,\n  TssVerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, coins } from '@bitgo-beta/statics';\nimport { KeyPair as TonKeyPair } from './lib/keyPair';\nimport BigNumber from 'bignumber.js';\nimport * as _ from 'lodash';\nimport { Transaction, TransactionBuilderFactory, Utils } from './lib';\nimport TonWeb from 'tonweb';\n\nexport interface TonParseTransactionOptions extends ParseTransactionOptions {\n  txHex: string;\n}\n\nexport class Ton extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Ton(bitgo, staticsCoin);\n  }\n\n  /**\n   * Factor between the coin's base unit and its smallest subdivison\n   */\n  public getBaseFactor(): number {\n    return 1e9;\n  }\n\n  public getChain(): string {\n    return 'ton';\n  }\n\n  public getFamily(): string {\n    return 'ton';\n  }\n\n  public getFullName(): string {\n    return 'Ton';\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'eddsa';\n  }\n\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const coinConfig = coins.get(this.getChain());\n    const { txPrebuild: txPrebuild, txParams: txParams } = params;\n    const transaction = new Transaction(coinConfig);\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n\n    transaction.fromRawTransaction(Buffer.from(rawTx, 'hex').toString('base64'));\n    const explainedTx = transaction.explainTransaction();\n    if (txParams.recipients !== undefined) {\n      const filteredRecipients = txParams.recipients?.map((recipient) => {\n        return {\n          address: new TonWeb.Address(recipient.address).toString(true, true, true),\n          amount: recipient.amount,\n        };\n      });\n      const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount']));\n\n      if (!_.isEqual(filteredOutputs, filteredRecipients)) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n      let totalAmount = new BigNumber(0);\n      for (const recipients of txParams.recipients) {\n        totalAmount = totalAmount.plus(recipients.amount);\n      }\n      if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {\n        throw new Error('Tx total amount does not match with expected total amount field');\n      }\n    }\n    return true;\n  }\n\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    const { keychains, address: newAddress, index } = params;\n\n    if (!this.isValidAddress(newAddress)) {\n      throw new InvalidAddressError(`invalid address: ${newAddress}`);\n    }\n\n    if (!keychains) {\n      throw new Error('missing required param keychains');\n    }\n\n    for (const keychain of keychains) {\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const commonKeychain = keychain.commonKeychain as string;\n\n      const derivationPath = 'm/' + index;\n      const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n      const expectedAddress = await Utils.default.getAddressFromPublicKey(derivedPublicKey);\n\n      if (newAddress !== expectedAddress) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  async parseTransaction(params: TonParseTransactionOptions): Promise<ParsedTransaction> {\n    const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n    const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));\n    const rebuiltTransaction = await transactionBuilder.build();\n    const parsedTransaction = rebuiltTransaction.toJson();\n    return {\n      inputs: [\n        {\n          address: parsedTransaction.sender,\n          amount: parsedTransaction.amount,\n        },\n      ],\n      outputs: [\n        {\n          address: parsedTransaction.destination,\n          amount: parsedTransaction.amount,\n        },\n      ],\n    };\n  }\n\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new TonKeyPair({ seed }) : new TonKeyPair();\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  isValidPub(pub: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  isValidAddress(address: string): boolean {\n    try {\n      const addressBase64 = address.replace(/\\+/g, '-').replace(/\\//g, '_');\n      const buf = Buffer.from(addressBase64, 'base64');\n      return buf.length === 36;\n    } catch {\n      return false;\n    }\n  }\n\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n    const rebuiltTransaction = await factory.from(serializedTx).build();\n    return rebuiltTransaction.signablePayload;\n  }\n\n  /** @inheritDoc */\n  async explainTransaction(params: Record<string, any>): Promise<TransactionExplanation> {\n    try {\n      const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n      const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));\n      const rebuiltTransaction = await transactionBuilder.build();\n      return rebuiltTransaction.explainTransaction();\n    } catch {\n      throw new Error('Invalid transaction');\n    }\n  }\n}\n"]}
|
|
446
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ton.js","sourceRoot":"","sources":["../../src/ton.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BitGoBase,\n  EDDSAMethods,\n  InvalidAddressError,\n  KeyPair,\n  MPCAlgorithm,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  TransactionExplanation,\n  TssVerifyAddressOptions,\n  VerifyTransactionOptions,\n  EDDSAMethodTypes,\n  MPCRecoveryOptions,\n  MPCTx,\n  MPCUnsignedTx,\n  RecoveryTxRequest,\n  OvcInput,\n  OvcOutput,\n  Environments,\n  MPCSweepTxs,\n  PublicKey,\n  MPCTxs,\n  MPCSweepRecoveryOptions,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, coins } from '@bitgo-beta/statics';\nimport { KeyPair as TonKeyPair } from './lib/keyPair';\nimport BigNumber from 'bignumber.js';\nimport * as _ from 'lodash';\nimport { Transaction, TransactionBuilderFactory, Utils, TransferBuilder } from './lib';\nimport TonWeb from 'tonweb';\nimport { getDerivationPath } from '@bitgo-beta/sdk-lib-mpc';\nimport { getFeeEstimate } from './lib/utils';\n\nexport interface TonParseTransactionOptions extends ParseTransactionOptions {\n  txHex: string;\n  fromAddressBounceable?: boolean;\n  toAddressBounceable?: boolean;\n}\n\nexport class Ton extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Ton(bitgo, staticsCoin);\n  }\n\n  /**\n   * Factor between the coin's base unit and its smallest subdivison\n   */\n  public getBaseFactor(): number {\n    return 1e9;\n  }\n\n  public getChain(): string {\n    return 'ton';\n  }\n\n  public getFamily(): string {\n    return 'ton';\n  }\n\n  public getFullName(): string {\n    return 'Ton';\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'eddsa';\n  }\n\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  getAddressDetails(address: string): { address: string; memoId?: string } {\n    const addressComponents = address.split('?memoId=');\n\n    if (addressComponents.length > 1) {\n      return {\n        address: addressComponents[0],\n        memoId: addressComponents[1],\n      };\n    } else {\n      return {\n        address: addressComponents[0],\n      };\n    }\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const coinConfig = coins.get(this.getChain());\n    const { txPrebuild: txPrebuild, txParams: txParams } = params;\n    const transaction = new Transaction(coinConfig);\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n\n    transaction.fromRawTransaction(Buffer.from(rawTx, 'hex').toString('base64'));\n    const explainedTx = transaction.explainTransaction();\n    if (txParams.recipients !== undefined) {\n      const filteredRecipients = txParams.recipients?.map((recipient) => {\n        const destination = this.getAddressDetails(recipient.address);\n        return {\n          address: new TonWeb.Address(destination.address).toString(true, true, true),\n          amount: BigInt(recipient.amount),\n        };\n      });\n      const filteredOutputs = explainedTx.outputs.map((output) => {\n        return {\n          address: new TonWeb.Address(output.address).toString(true, true, true),\n          amount: BigInt(output.amount),\n        };\n      });\n      if (!_.isEqual(filteredOutputs, filteredRecipients)) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n      let totalAmount = new BigNumber(0);\n      for (const recipients of txParams.recipients) {\n        totalAmount = totalAmount.plus(recipients.amount);\n      }\n      if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {\n        throw new Error('Tx total amount does not match with expected total amount field');\n      }\n    }\n    return true;\n  }\n\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    const { keychains, address: newAddress, index } = params;\n\n    if (!this.isValidAddress(newAddress)) {\n      throw new InvalidAddressError(`invalid address: ${newAddress}`);\n    }\n\n    if (!keychains) {\n      throw new Error('missing required param keychains');\n    }\n\n    for (const keychain of keychains) {\n      const [address, memoId] = newAddress.split('?memoId=');\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const commonKeychain = keychain.commonKeychain as string;\n\n      const derivationPath = 'm/' + index;\n      const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n      const expectedAddress = await Utils.default.getAddressFromPublicKey(derivedPublicKey);\n\n      if (memoId) {\n        return memoId === `${index}`;\n      }\n\n      if (address !== expectedAddress) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  async parseTransaction(params: TonParseTransactionOptions): Promise<ParsedTransaction> {\n    const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n    const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));\n\n    if (typeof params.toAddressBounceable === 'boolean') {\n      transactionBuilder.toAddressBounceable(params.toAddressBounceable);\n    }\n\n    if (typeof params.fromAddressBounceable === 'boolean') {\n      transactionBuilder.fromAddressBounceable(params.fromAddressBounceable);\n    }\n\n    const rebuiltTransaction = await transactionBuilder.build();\n    const parsedTransaction = rebuiltTransaction.toJson();\n    return {\n      inputs: [\n        {\n          address: parsedTransaction.sender,\n          amount: parsedTransaction.amount,\n        },\n      ],\n      outputs: [\n        {\n          address: parsedTransaction.destination,\n          amount: parsedTransaction.amount,\n        },\n      ],\n    };\n  }\n\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new TonKeyPair({ seed }) : new TonKeyPair();\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  isValidPub(pub: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  isValidAddress(address: string): boolean {\n    try {\n      const addressBase64 = address.replace(/\\+/g, '-').replace(/\\//g, '_');\n      const buf = Buffer.from(addressBase64.split('?memoId=')[0], 'base64');\n      return buf.length === 36;\n    } catch {\n      return false;\n    }\n  }\n\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n    const rebuiltTransaction = await factory.from(serializedTx).build();\n    return rebuiltTransaction.signablePayload;\n  }\n\n  /** @inheritDoc */\n  async explainTransaction(params: Record<string, any>): Promise<TransactionExplanation> {\n    try {\n      const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n      const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));\n\n      const { toAddressBounceable, fromAddressBounceable } = params;\n\n      if (typeof toAddressBounceable === 'boolean') {\n        transactionBuilder.toAddressBounceable(toAddressBounceable);\n      }\n\n      if (typeof fromAddressBounceable === 'boolean') {\n        transactionBuilder.fromAddressBounceable(fromAddressBounceable);\n      }\n\n      const rebuiltTransaction = await transactionBuilder.build();\n      return rebuiltTransaction.explainTransaction();\n    } catch {\n      throw new Error('Invalid transaction');\n    }\n  }\n\n  protected getPublicNodeUrl(): string {\n    return Environments[this.bitgo.getEnv()].tonNodeUrl;\n  }\n\n  private getBuilder(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  async recover(params: MPCRecoveryOptions): Promise<MPCTx | MPCSweepTxs> {\n    if (!params.bitgoKey) {\n      throw new Error('missing bitgoKey');\n    }\n    if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n    if (!params.apiKey) {\n      throw new Error('missing apiKey');\n    }\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n    const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;\n\n    // Build the transaction\n    const tonweb = new TonWeb(new TonWeb.HttpProvider(this.getPublicNodeUrl(), { apiKey: params.apiKey }));\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n\n    const index = params.index || 0;\n    const currPath = params.seed ? getDerivationPath(params.seed) + `/${index}` : `m/${index}`;\n    const accountId = MPC.deriveUnhardened(bitgoKey, currPath).slice(0, 64);\n    const senderAddr = await Utils.default.getAddressFromPublicKey(accountId);\n    const balance = await tonweb.getBalance(senderAddr);\n    if (new BigNumber(balance).isEqualTo(0)) {\n      throw Error('Did not find address with funds to recover');\n    }\n\n    const WalletClass = tonweb.wallet.all['v4R2'];\n    const wallet = new WalletClass(tonweb.provider, {\n      publicKey: tonweb.utils.hexToBytes(accountId),\n      wc: 0,\n    });\n    let seqno = await wallet.methods.seqno().call();\n    if (seqno === null) {\n      seqno = 0;\n    }\n\n    const feeEstimate = await getFeeEstimate(wallet, params.recoveryDestination, balance, seqno as number);\n\n    const totalFeeEstimate = Math.round(\n      (feeEstimate.source_fees.in_fwd_fee +\n        feeEstimate.source_fees.storage_fee +\n        feeEstimate.source_fees.gas_fee +\n        feeEstimate.source_fees.fwd_fee) *\n        1.5\n    );\n\n    if (new BigNumber(totalFeeEstimate).gt(balance)) {\n      throw Error('Did not find address with funds to recover');\n    }\n\n    const factory = this.getBuilder();\n    const expireAt = Math.floor(Date.now() / 1e3) + 60 * 60 * 24 * 7; // 7 days\n\n    const txBuilder = factory\n      .getTransferBuilder()\n      .sender(senderAddr)\n      .sequenceNumber(seqno as number)\n      .publicKey(accountId)\n      .expireTime(expireAt);\n\n    (txBuilder as TransferBuilder).send({\n      address: params.recoveryDestination,\n      amount: new BigNumber(balance).minus(new BigNumber(totalFeeEstimate)).toString(),\n    });\n\n    const unsignedTransaction = await txBuilder.build();\n\n    if (!isUnsignedSweep) {\n      if (!params.userKey) {\n        throw new Error('missing userKey');\n      }\n      if (!params.backupKey) {\n        throw new Error('missing backupKey');\n      }\n      if (!params.walletPassphrase) {\n        throw new Error('missing wallet passphrase');\n      }\n\n      // Clean up whitespace from entered values\n      const userKey = params.userKey.replace(/\\s/g, '');\n      const backupKey = params.backupKey.replace(/\\s/g, '');\n\n      let userPrv;\n\n      try {\n        userPrv = this.bitgo.decrypt({\n          input: userKey,\n          password: params.walletPassphrase,\n        });\n      } catch (e) {\n        throw new Error(`Error decrypting user keychain: ${e.message}`);\n      }\n      const userSigningMaterial = JSON.parse(userPrv) as EDDSAMethodTypes.UserSigningMaterial;\n\n      let backupPrv;\n      try {\n        backupPrv = this.bitgo.decrypt({\n          input: backupKey,\n          password: params.walletPassphrase,\n        });\n      } catch (e) {\n        throw new Error(`Error decrypting backup keychain: ${e.message}`);\n      }\n      const backupSigningMaterial = JSON.parse(backupPrv) as EDDSAMethodTypes.BackupSigningMaterial;\n\n      const signatureHex = await EDDSAMethods.getTSSSignature(\n        userSigningMaterial,\n        backupSigningMaterial,\n        currPath,\n        unsignedTransaction\n      );\n\n      const publicKeyObj = { pub: senderAddr };\n      txBuilder.addSignature(publicKeyObj as PublicKey, signatureHex);\n    }\n\n    const completedTransaction = await txBuilder.build();\n    const serializedTx = completedTransaction.toBroadcastFormat();\n    const walletCoin = this.getChain();\n\n    const inputs: OvcInput[] = [];\n    for (const input of completedTransaction.inputs) {\n      inputs.push({\n        address: input.address,\n        valueString: input.value,\n        value: new BigNumber(input.value).toNumber(),\n      });\n    }\n    const outputs: OvcOutput[] = [];\n    for (const output of completedTransaction.outputs) {\n      outputs.push({\n        address: output.address,\n        valueString: output.value,\n        coinName: output.coin,\n      });\n    }\n    const spendAmount = completedTransaction.inputs.length === 1 ? completedTransaction.inputs[0].value : 0;\n    const parsedTx = { inputs: inputs, outputs: outputs, spendAmount: spendAmount, type: '' };\n    const feeInfo = { fee: totalFeeEstimate, feeString: totalFeeEstimate.toString() };\n    const coinSpecific = { commonKeychain: bitgoKey };\n    if (isUnsignedSweep) {\n      const transaction: MPCTx = {\n        serializedTx: serializedTx,\n        scanIndex: index,\n        coin: walletCoin,\n        signableHex: completedTransaction.signablePayload.toString('hex'),\n        derivationPath: currPath,\n        parsedTx: parsedTx,\n        feeInfo: feeInfo,\n        coinSpecific: coinSpecific,\n      };\n      const unsignedTx: MPCUnsignedTx = { unsignedTx: transaction, signatureShares: [] };\n      const transactions: MPCUnsignedTx[] = [unsignedTx];\n      const txRequest: RecoveryTxRequest = {\n        transactions: transactions,\n        walletCoin: walletCoin,\n      };\n      const txRequests: MPCSweepTxs = { txRequests: [txRequest] };\n      return txRequests;\n    }\n\n    const transaction: MPCTx = {\n      serializedTx: serializedTx,\n      scanIndex: index,\n    };\n    return transaction;\n  }\n\n  /**\n   * Creates funds sweep recovery transaction(s) without BitGo\n   *\n   * @param {MPCSweepRecoveryOptions} params parameters needed to combine the signatures\n   * and transactions to create broadcastable transactions\n   *\n   * @returns {MPCTxs} array of the serialized transaction hex strings and indices\n   * of the addresses being swept\n   */\n  async createBroadcastableSweepTransaction(params: MPCSweepRecoveryOptions): Promise<MPCTxs> {\n    const req = params.signatureShares;\n    const broadcastableTransactions: MPCTx[] = [];\n    let lastScanIndex = 0;\n\n    for (let i = 0; i < req.length; i++) {\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const transaction = req[i].txRequest.transactions[0].unsignedTx;\n      if (!req[i].ovc || !req[i].ovc[0].eddsaSignature) {\n        throw new Error('Missing signature(s)');\n      }\n      const signature = req[i].ovc[0].eddsaSignature;\n      if (!transaction.signableHex) {\n        throw new Error('Missing signable hex');\n      }\n      const messageBuffer = Buffer.from(transaction.signableHex!, 'hex');\n      const result = MPC.verify(messageBuffer, signature);\n      if (!result) {\n        throw new Error('Invalid signature');\n      }\n      const signatureHex = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      const txBuilder = this.getBuilder().from(transaction.serializedTx as string);\n      if (!transaction.coinSpecific?.commonKeychain) {\n        throw new Error('Missing common keychain');\n      }\n      const commonKeychain = transaction.coinSpecific!.commonKeychain! as string;\n      if (!transaction.derivationPath) {\n        throw new Error('Missing derivation path');\n      }\n      const derivationPath = transaction.derivationPath as string;\n      const accountId = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n      const tonKeyPair = new TonKeyPair({ pub: accountId });\n\n      // add combined signature from ovc\n      txBuilder.addSignature({ pub: tonKeyPair.getKeys().pub }, signatureHex);\n      const signedTransaction = await txBuilder.build();\n      const serializedTx = signedTransaction.toBroadcastFormat();\n\n      broadcastableTransactions.push({\n        serializedTx: serializedTx,\n        scanIndex: transaction.scanIndex,\n      });\n\n      if (i === req.length - 1 && transaction.coinSpecific!.lastScanIndex) {\n        lastScanIndex = transaction.coinSpecific!.lastScanIndex as number;\n      }\n    }\n\n    return { transactions: broadcastableTransactions, lastScanIndex };\n  }\n}\n"]}
|
package/dist/src/tton.js
CHANGED
|
@@ -27,4 +27,4 @@ class Tton extends ton_1.Ton {
|
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
29
|
exports.Tton = Tton;
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHRvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90dG9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQU1BLCtCQUE0QjtBQUc1QixNQUFhLElBQUssU0FBUSxTQUFHO0lBRTNCLFlBQXNCLEtBQWdCLEVBQUUsV0FBdUM7UUFDN0UsS0FBSyxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztRQUUxQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDakIsTUFBTSxJQUFJLEtBQUssQ0FBQyxvREFBb0QsQ0FBQyxDQUFDO1FBQ3hFLENBQUM7UUFFRCxJQUFJLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQztJQUNsQyxDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxLQUFnQixFQUFFLFdBQXVDO1FBQzdFLE9BQU8sSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRDs7T0FFRztJQUNJLFFBQVE7UUFDYixPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0lBRUQ7O09BRUc7SUFDSSxXQUFXO1FBQ2hCLE9BQU8sYUFBYSxDQUFDO0lBQ3ZCLENBQUM7Q0FDRjtBQTdCRCxvQkE2QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRlc3RuZXQgVG9uXG4gKlxuICogQGZvcm1hdFxuICovXG5pbXBvcnQgeyBCYXNlQ29pbiwgQml0R29CYXNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgVG9uIH0gZnJvbSAnLi90b24nO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgU3RhdGljc0Jhc2VDb2luIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5cbmV4cG9ydCBjbGFzcyBUdG9uIGV4dGVuZHMgVG9uIHtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IF9zdGF0aWNzQ29pbjogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPjtcbiAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKGJpdGdvOiBCaXRHb0Jhc2UsIHN0YXRpY3NDb2luPzogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPikge1xuICAgIHN1cGVyKGJpdGdvLCBzdGF0aWNzQ29pbik7XG5cbiAgICBpZiAoIXN0YXRpY3NDb2luKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ21pc3NpbmcgcmVxdWlyZWQgY29uc3RydWN0b3IgcGFyYW1ldGVyIHN0YXRpY3NDb2luJyk7XG4gICAgfVxuXG4gICAgdGhpcy5fc3RhdGljc0NvaW4gPSBzdGF0aWNzQ29pbjtcbiAgfVxuXG4gIHN0YXRpYyBjcmVhdGVJbnN0YW5jZShiaXRnbzogQml0R29CYXNlLCBzdGF0aWNzQ29pbj86IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj4pOiBCYXNlQ29pbiB7XG4gICAgcmV0dXJuIG5ldyBUdG9uKGJpdGdvLCBzdGF0aWNzQ29pbik7XG4gIH1cblxuICAvKipcbiAgICogSWRlbnRpZmllciBmb3IgdGhlIGJsb2NrY2hhaW4gd2hpY2ggc3VwcG9ydHMgdGhpcyBjb2luXG4gICAqL1xuICBwdWJsaWMgZ2V0Q2hhaW4oKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJ3R0b24nO1xuICB9XG5cbiAgLyoqXG4gICAqIENvbXBsZXRlIGh1bWFuLXJlYWRhYmxlIG5hbWUgb2YgdGhpcyBjb2luXG4gICAqL1xuICBwdWJsaWMgZ2V0RnVsbE5hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJ1Rlc3RuZXQgVG9uJztcbiAgfVxufVxuIl19
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-coin-ton",
|
|
3
|
-
"version": "1.0.1-beta.
|
|
3
|
+
"version": "1.0.1-beta.761",
|
|
4
4
|
"description": "BitGo SDK coin library for Ton",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
"author": "BitGo SDK Team <sdkteam@bitgo.com>",
|
|
19
19
|
"license": "MIT",
|
|
20
20
|
"engines": {
|
|
21
|
-
"node": ">=
|
|
21
|
+
"node": ">=18 <21"
|
|
22
22
|
},
|
|
23
23
|
"repository": {
|
|
24
24
|
"type": "git",
|
|
@@ -40,9 +40,9 @@
|
|
|
40
40
|
]
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@bitgo-beta/sdk-core": "8.2.1-beta.
|
|
44
|
-
"@bitgo-beta/sdk-lib-mpc": "8.2.0-beta.
|
|
45
|
-
"@bitgo-beta/statics": "15.1.1-beta.
|
|
43
|
+
"@bitgo-beta/sdk-core": "8.2.1-beta.899",
|
|
44
|
+
"@bitgo-beta/sdk-lib-mpc": "8.2.0-beta.891",
|
|
45
|
+
"@bitgo-beta/statics": "15.1.1-beta.902",
|
|
46
46
|
"bignumber.js": "^9.0.0",
|
|
47
47
|
"bn.js": "^5.2.1",
|
|
48
48
|
"lodash": "^4.17.21",
|
|
@@ -50,8 +50,8 @@
|
|
|
50
50
|
"tweetnacl": "^1.0.3"
|
|
51
51
|
},
|
|
52
52
|
"devDependencies": {
|
|
53
|
-
"@bitgo-beta/sdk-api": "1.10.1-beta.
|
|
54
|
-
"@bitgo-beta/sdk-test": "^
|
|
53
|
+
"@bitgo-beta/sdk-api": "1.10.1-beta.898",
|
|
54
|
+
"@bitgo-beta/sdk-test": "^8.0.86"
|
|
55
55
|
},
|
|
56
|
-
"gitHead": "
|
|
56
|
+
"gitHead": "7849ae6d9644af95823d5f1c0f9f3f280f653167"
|
|
57
57
|
}
|