@bitgo-beta/sdk-coin-stx 1.4.3-alpha.405 → 1.4.3-alpha.407
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/dist/test/fixtures.d.ts +119 -0
- package/dist/test/fixtures.d.ts.map +1 -0
- package/dist/test/fixtures.js +147 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +144 -0
- package/dist/test/unit/resources.d.ts +97 -0
- package/dist/test/unit/resources.d.ts.map +1 -0
- package/dist/test/unit/resources.js +144 -0
- package/dist/test/unit/sip10Token.d.ts +2 -0
- package/dist/test/unit/sip10Token.d.ts.map +1 -0
- package/dist/test/unit/sip10Token.js +374 -0
- package/dist/test/unit/stx.d.ts +2 -0
- package/dist/test/unit/stx.d.ts.map +1 -0
- package/dist/test/unit/stx.js +470 -0
- package/dist/test/unit/transaction.d.ts +2 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +83 -0
- package/dist/test/unit/transactionBuilder/contractBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/contractBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/contractBuilder.js +421 -0
- package/dist/test/unit/transactionBuilder/fungibleTokenTransferBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/fungibleTokenTransferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/fungibleTokenTransferBuilder.js +187 -0
- package/dist/test/unit/transactionBuilder/sendmanyBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/sendmanyBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/sendmanyBuilder.js +140 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.js +347 -0
- package/dist/test/unit/util.d.ts +2 -0
- package/dist/test/unit/util.d.ts.map +1 -0
- package/dist/test/unit/util.js +326 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +11 -8
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -831
|
@@ -0,0 +1,374 @@
|
|
|
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
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
40
|
+
const nock_1 = __importDefault(require("nock"));
|
|
41
|
+
const sdk_api_1 = require("@bitgo-beta/sdk-api");
|
|
42
|
+
const sdk_test_1 = require("@bitgo-beta/sdk-test");
|
|
43
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
44
|
+
const src_1 = require("../../src");
|
|
45
|
+
const testData = __importStar(require("../fixtures"));
|
|
46
|
+
const assert_1 = __importDefault(require("assert"));
|
|
47
|
+
describe('Sip10Token:', function () {
|
|
48
|
+
const sip10TokenName = 'tstx:tsip6dp';
|
|
49
|
+
let bitgo;
|
|
50
|
+
let basecoin;
|
|
51
|
+
let newTxPrebuild;
|
|
52
|
+
let newTxParams;
|
|
53
|
+
let wallet;
|
|
54
|
+
const txPreBuild = {
|
|
55
|
+
txHex: testData.txForExplainFungibleTokenTransfer,
|
|
56
|
+
txInfo: {},
|
|
57
|
+
};
|
|
58
|
+
const txParams = {
|
|
59
|
+
recipients: testData.recipients,
|
|
60
|
+
};
|
|
61
|
+
const memo = {
|
|
62
|
+
type: '',
|
|
63
|
+
value: '1',
|
|
64
|
+
};
|
|
65
|
+
before(function () {
|
|
66
|
+
bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, {
|
|
67
|
+
env: 'mock',
|
|
68
|
+
});
|
|
69
|
+
bitgo.initializeTestVars();
|
|
70
|
+
src_1.Sip10Token.createTokenConstructors().forEach(({ name, coinConstructor }) => {
|
|
71
|
+
bitgo.safeRegister(name, coinConstructor);
|
|
72
|
+
});
|
|
73
|
+
newTxPrebuild = () => {
|
|
74
|
+
return lodash_1.default.cloneDeep(txPreBuild);
|
|
75
|
+
};
|
|
76
|
+
newTxParams = () => {
|
|
77
|
+
return lodash_1.default.cloneDeep(txParams);
|
|
78
|
+
};
|
|
79
|
+
basecoin = bitgo.coin(sip10TokenName);
|
|
80
|
+
wallet = new sdk_core_1.Wallet(bitgo, basecoin, {});
|
|
81
|
+
});
|
|
82
|
+
describe('Verify Transaction', function () {
|
|
83
|
+
it('should succeed to verify transaction', async function () {
|
|
84
|
+
const txPrebuild = newTxPrebuild();
|
|
85
|
+
const txParams = newTxParams();
|
|
86
|
+
txParams.memo = memo;
|
|
87
|
+
const verification = {};
|
|
88
|
+
const isTransactionVerified = await basecoin.verifyTransaction({
|
|
89
|
+
txParams,
|
|
90
|
+
txPrebuild,
|
|
91
|
+
verification,
|
|
92
|
+
wallet,
|
|
93
|
+
});
|
|
94
|
+
isTransactionVerified.should.equal(true);
|
|
95
|
+
});
|
|
96
|
+
it('should succeed to verify transaction when recipients amount are numbers', async function () {
|
|
97
|
+
const txPrebuild = newTxPrebuild();
|
|
98
|
+
const txParamsWithNumberAmounts = newTxParams();
|
|
99
|
+
txParamsWithNumberAmounts.recipients = txParamsWithNumberAmounts.recipients.map(({ address, amount, memo, tokenName }) => {
|
|
100
|
+
return { address, amount: Number(amount), memo, tokenName };
|
|
101
|
+
});
|
|
102
|
+
txParamsWithNumberAmounts.memo = memo;
|
|
103
|
+
const verification = {};
|
|
104
|
+
const isTransactionVerified = await basecoin.verifyTransaction({
|
|
105
|
+
txParams: txParamsWithNumberAmounts,
|
|
106
|
+
txPrebuild,
|
|
107
|
+
verification,
|
|
108
|
+
wallet,
|
|
109
|
+
});
|
|
110
|
+
isTransactionVerified.should.equal(true);
|
|
111
|
+
});
|
|
112
|
+
it('should succeed to verify when memo is passed', async function () {
|
|
113
|
+
const txPrebuild = newTxPrebuild();
|
|
114
|
+
txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithMemoId10;
|
|
115
|
+
const txParams = newTxParams();
|
|
116
|
+
const verification = {};
|
|
117
|
+
txParams.memo = {
|
|
118
|
+
type: '',
|
|
119
|
+
value: '10',
|
|
120
|
+
};
|
|
121
|
+
const isTransactionVerified = await basecoin.verifyTransaction({
|
|
122
|
+
txParams: txParams,
|
|
123
|
+
txPrebuild,
|
|
124
|
+
verification,
|
|
125
|
+
wallet,
|
|
126
|
+
});
|
|
127
|
+
isTransactionVerified.should.equal(true);
|
|
128
|
+
});
|
|
129
|
+
it('should succeed to verify when memo is zero', async function () {
|
|
130
|
+
const txPrebuild = newTxPrebuild();
|
|
131
|
+
const txParams = newTxParams();
|
|
132
|
+
txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithMemoZero;
|
|
133
|
+
txParams.memo = {
|
|
134
|
+
type: '',
|
|
135
|
+
value: '0',
|
|
136
|
+
};
|
|
137
|
+
const verification = {};
|
|
138
|
+
const isTransactionVerified = await basecoin.verifyTransaction({
|
|
139
|
+
txParams: txParams,
|
|
140
|
+
txPrebuild,
|
|
141
|
+
verification,
|
|
142
|
+
wallet,
|
|
143
|
+
});
|
|
144
|
+
isTransactionVerified.should.equal(true);
|
|
145
|
+
});
|
|
146
|
+
it('should succeed to verify when memo is passed inside recipient address', async function () {
|
|
147
|
+
const txPrebuild = newTxPrebuild();
|
|
148
|
+
const txParams = newTxParams();
|
|
149
|
+
txParams.recipients[0].address = 'SN2NN1JP9AEP5BVE19RNJ6T2MP7NDGRZYST1VDF3M?memoId=10';
|
|
150
|
+
txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithMemoId10;
|
|
151
|
+
const verification = {};
|
|
152
|
+
const isTransactionVerified = await basecoin.verifyTransaction({
|
|
153
|
+
txParams: txParams,
|
|
154
|
+
txPrebuild,
|
|
155
|
+
verification,
|
|
156
|
+
wallet,
|
|
157
|
+
});
|
|
158
|
+
isTransactionVerified.should.equal(true);
|
|
159
|
+
});
|
|
160
|
+
it('should succeed to verify when memo is not passed', async function () {
|
|
161
|
+
const txPrebuild = newTxPrebuild();
|
|
162
|
+
const txParams = newTxParams();
|
|
163
|
+
txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithoutMemo;
|
|
164
|
+
const verification = {};
|
|
165
|
+
const isTransactionVerified = await basecoin.verifyTransaction({
|
|
166
|
+
txParams: txParams,
|
|
167
|
+
txPrebuild,
|
|
168
|
+
verification,
|
|
169
|
+
wallet,
|
|
170
|
+
});
|
|
171
|
+
isTransactionVerified.should.equal(true);
|
|
172
|
+
});
|
|
173
|
+
it('should fail to verify transaction with no recipients', async function () {
|
|
174
|
+
const txPrebuild = {};
|
|
175
|
+
const txParams = newTxParams();
|
|
176
|
+
txParams.recipients = [];
|
|
177
|
+
await basecoin
|
|
178
|
+
.verifyTransaction({
|
|
179
|
+
txParams,
|
|
180
|
+
txPrebuild,
|
|
181
|
+
wallet,
|
|
182
|
+
})
|
|
183
|
+
.should.rejectedWith('missing required tx prebuild property txHex');
|
|
184
|
+
});
|
|
185
|
+
it('should fail when more than 1 recipients are passed', async function () {
|
|
186
|
+
const txPrebuild = newTxPrebuild();
|
|
187
|
+
const txParams = newTxParams();
|
|
188
|
+
txParams.recipients.push({
|
|
189
|
+
address: 'SN2NN1JP9AEP5BVE19RNJ6T2MP7NDGRZYST1VDF3N',
|
|
190
|
+
amount: '10000',
|
|
191
|
+
memo: '1',
|
|
192
|
+
tokenName: 'tsip6dp-token',
|
|
193
|
+
});
|
|
194
|
+
await basecoin
|
|
195
|
+
.verifyTransaction({
|
|
196
|
+
txParams,
|
|
197
|
+
txPrebuild,
|
|
198
|
+
wallet,
|
|
199
|
+
})
|
|
200
|
+
.should.rejectedWith("tstx:tsip6dp doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.");
|
|
201
|
+
});
|
|
202
|
+
it('should fail to verify transaction with wrong address', async function () {
|
|
203
|
+
const txPrebuild = newTxPrebuild();
|
|
204
|
+
const txParams = newTxParams();
|
|
205
|
+
txParams.recipients[0].address = 'SN2NN1JP9AEP5BVE19RNJ6T2MP7NDGRZYST1VDF3N';
|
|
206
|
+
const verification = {};
|
|
207
|
+
await basecoin
|
|
208
|
+
.verifyTransaction({
|
|
209
|
+
txParams,
|
|
210
|
+
txPrebuild,
|
|
211
|
+
verification,
|
|
212
|
+
wallet,
|
|
213
|
+
})
|
|
214
|
+
.should.rejectedWith('Tx outputs does not match with expected txParams recipients');
|
|
215
|
+
});
|
|
216
|
+
it('should fail to verify transaction with wrong amount', async function () {
|
|
217
|
+
const txPrebuild = newTxPrebuild();
|
|
218
|
+
const txParams = newTxParams();
|
|
219
|
+
txParams.recipients[0].amount = '100';
|
|
220
|
+
const verification = {};
|
|
221
|
+
await basecoin
|
|
222
|
+
.verifyTransaction({
|
|
223
|
+
txParams,
|
|
224
|
+
txPrebuild,
|
|
225
|
+
verification,
|
|
226
|
+
wallet,
|
|
227
|
+
})
|
|
228
|
+
.should.rejectedWith('Tx outputs does not match with expected txParams recipients');
|
|
229
|
+
});
|
|
230
|
+
it('should fail to verify transaction with wrong memo', async function () {
|
|
231
|
+
const txPrebuild = newTxPrebuild();
|
|
232
|
+
const txParams = newTxParams();
|
|
233
|
+
txParams.recipients[0].memo = '2';
|
|
234
|
+
const verification = {};
|
|
235
|
+
await basecoin
|
|
236
|
+
.verifyTransaction({
|
|
237
|
+
txParams,
|
|
238
|
+
txPrebuild,
|
|
239
|
+
verification,
|
|
240
|
+
wallet,
|
|
241
|
+
})
|
|
242
|
+
.should.rejectedWith('Tx memo does not match with expected txParams recipient memo');
|
|
243
|
+
});
|
|
244
|
+
it('should fail to verify transaction with wrong token', async function () {
|
|
245
|
+
const txPrebuild = newTxPrebuild();
|
|
246
|
+
const txParams = newTxParams();
|
|
247
|
+
txParams.recipients[0].tokenName = 'tstx:tsip8dp';
|
|
248
|
+
const verification = {};
|
|
249
|
+
await basecoin
|
|
250
|
+
.verifyTransaction({
|
|
251
|
+
txParams,
|
|
252
|
+
txPrebuild,
|
|
253
|
+
verification,
|
|
254
|
+
wallet,
|
|
255
|
+
})
|
|
256
|
+
.should.rejectedWith('Tx outputs does not match with expected txParams recipients');
|
|
257
|
+
});
|
|
258
|
+
});
|
|
259
|
+
describe('Recover Transaction SIP10', () => {
|
|
260
|
+
before(function () {
|
|
261
|
+
nock_1.default.enableNetConnect();
|
|
262
|
+
});
|
|
263
|
+
beforeEach(function () {
|
|
264
|
+
nock_1.default.cleanAll();
|
|
265
|
+
});
|
|
266
|
+
after(function () {
|
|
267
|
+
nock_1.default.disableNetConnect();
|
|
268
|
+
});
|
|
269
|
+
it('should build a signed token recover transaction when private key data is passed', async () => {
|
|
270
|
+
const rootAddress = testData.HOT_WALLET_ROOT_ADDRESS;
|
|
271
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`)
|
|
272
|
+
.get(`/extended/v2/addresses/${rootAddress}/balances/stx`)
|
|
273
|
+
.reply(200, testData.ACCOUNT_BALANCE_RESPONSE);
|
|
274
|
+
(0, nock_1.default)('https://api.testnet.hiro.so')
|
|
275
|
+
.get(`/extended/v2/addresses/${rootAddress}/balances/ft/${testData.STX_TOKEN_ASSET_ID}`)
|
|
276
|
+
.reply(200, testData.TOKEN_BALANCE_RESPONSE);
|
|
277
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`)
|
|
278
|
+
.get(`/extended/v1/address/${rootAddress}/nonces`)
|
|
279
|
+
.reply(200, testData.ACCOUNT_NONCE_RESPONSE);
|
|
280
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`, { allowUnmocked: true })
|
|
281
|
+
.post(`/v2/fees/transaction`, testData.FEE_ESTIMATION_TOKEN_REQUEST)
|
|
282
|
+
.reply(200, testData.FEE_ESTIMATION_TOKEN_RESPONSE);
|
|
283
|
+
const recoveryOptions = {
|
|
284
|
+
backupKey: testData.HOT_WALLET_KEY_CARD_INFO.BACKUP_KEY,
|
|
285
|
+
userKey: testData.HOT_WALLET_KEY_CARD_INFO.USER_KEY,
|
|
286
|
+
rootAddress: rootAddress,
|
|
287
|
+
recoveryDestination: testData.DESTINATION_ADDRESS_WRW,
|
|
288
|
+
bitgoKey: testData.HOT_WALLET_KEY_CARD_INFO.BITGO_PUB_KEY,
|
|
289
|
+
walletPassphrase: testData.HOT_WALLET_KEY_CARD_INFO.WALLET_PASSPHRASE,
|
|
290
|
+
contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH.tsip6dp-token',
|
|
291
|
+
};
|
|
292
|
+
const response = await basecoin.recover(recoveryOptions);
|
|
293
|
+
response.should.have.property('txHex');
|
|
294
|
+
assert_1.default.deepEqual(response.txHex, testData.HOT_WALLET_TOKEN_RECOVERY_TX_HEX, 'tx hex not matching!');
|
|
295
|
+
});
|
|
296
|
+
it('should build an unsigned token transaction when public keys are passed', async () => {
|
|
297
|
+
const rootAddress = testData.COLD_WALLET_ROOT_ADDRESS;
|
|
298
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`)
|
|
299
|
+
.get(`/extended/v2/addresses/${rootAddress}/balances/stx`)
|
|
300
|
+
.reply(200, testData.ACCOUNT_BALANCE_RESPONSE);
|
|
301
|
+
(0, nock_1.default)('https://api.testnet.hiro.so')
|
|
302
|
+
.get(`/extended/v2/addresses/${rootAddress}/balances/ft/${testData.STX_TOKEN_ASSET_ID}`)
|
|
303
|
+
.reply(200, testData.TOKEN_BALANCE_RESPONSE);
|
|
304
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`, { allowUnmocked: true })
|
|
305
|
+
.get(`/extended/v1/address/${rootAddress}/nonces`)
|
|
306
|
+
.reply(200, testData.ACCOUNT_NONCE_RESPONSE);
|
|
307
|
+
const feeEstimateRequest = testData.FEE_ESTIMATION_TOKEN_REQUEST;
|
|
308
|
+
feeEstimateRequest.transaction_payload =
|
|
309
|
+
'021a1500a1c42f0c11bfe3893f479af18904677685be0d747369703664702d746f6b656e087472616e73666572000000040100000000000000000000000005f5e10005159f2f1aff6fa0062e1f7fa6096133e75f47a7e8f7051a1500a1c42f0c11bfe3893f479af18904677685be09';
|
|
310
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`)
|
|
311
|
+
.post(`/v2/fees/transaction`, feeEstimateRequest)
|
|
312
|
+
.reply(200, testData.FEE_ESTIMATION_TOKEN_RESPONSE);
|
|
313
|
+
const recoveryOptions = {
|
|
314
|
+
backupKey: testData.COLD_WALLET_PUBLIC_KEY_INFO.BACKUP_KEY,
|
|
315
|
+
userKey: testData.COLD_WALLET_PUBLIC_KEY_INFO.USER_KEY,
|
|
316
|
+
rootAddress: rootAddress,
|
|
317
|
+
recoveryDestination: testData.DESTINATION_ADDRESS_WRW,
|
|
318
|
+
bitgoKey: testData.COLD_WALLET_PUBLIC_KEY_INFO.BITGO_PUB_KEY,
|
|
319
|
+
contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH.tsip6dp-token',
|
|
320
|
+
};
|
|
321
|
+
const response = (await basecoin.recover(recoveryOptions));
|
|
322
|
+
response.should.have.property('txHex');
|
|
323
|
+
response.should.have.property('coin');
|
|
324
|
+
response.should.have.property('feeInfo');
|
|
325
|
+
assert_1.default.deepEqual(response.txHex, testData.COLD_WALLET_TOKEN_UNSIGNED_SWEEP_TX_HEX, 'tx hex not matching!');
|
|
326
|
+
assert_1.default.deepEqual(response.coin, 'tstx:tsip6dp', 'coin not matching!');
|
|
327
|
+
});
|
|
328
|
+
it('should fail with insufficient balance when native stx balance is lower than fee for sip10', async () => {
|
|
329
|
+
const rootAddress = testData.HOT_WALLET_ROOT_ADDRESS;
|
|
330
|
+
const accountBalance = JSON.parse(JSON.stringify(testData.ACCOUNT_BALANCE_RESPONSE));
|
|
331
|
+
accountBalance.balance = '100'; // set balance lower than fee
|
|
332
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`)
|
|
333
|
+
.get(`/extended/v2/addresses/${rootAddress}/balances/stx`)
|
|
334
|
+
.reply(200, accountBalance);
|
|
335
|
+
(0, nock_1.default)('https://api.testnet.hiro.so')
|
|
336
|
+
.get(`/extended/v2/addresses/${rootAddress}/balances/ft/${testData.STX_TOKEN_ASSET_ID}`)
|
|
337
|
+
.reply(200, testData.TOKEN_BALANCE_RESPONSE);
|
|
338
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`)
|
|
339
|
+
.get(`/extended/v1/address/${rootAddress}/nonces`)
|
|
340
|
+
.reply(200, testData.ACCOUNT_NONCE_RESPONSE);
|
|
341
|
+
const feeRequestBody = testData.FEE_ESTIMATION_TOKEN_REQUEST;
|
|
342
|
+
feeRequestBody.transaction_payload =
|
|
343
|
+
'021a1500a1c42f0c11bfe3893f479af18904677685be0d747369703664702d746f6b656e087472616e73666572000000040100000000000000000000000005f5e100051549857eb4b6dd4fee08c3ec04e3d0ed04ef67d324051a1500a1c42f0c11bfe3893f479af18904677685be09';
|
|
344
|
+
(0, nock_1.default)(`https://api.testnet.hiro.so`, { allowUnmocked: true })
|
|
345
|
+
.post(`/v2/fees/transaction`, feeRequestBody)
|
|
346
|
+
.reply(200, testData.FEE_ESTIMATION_TOKEN_RESPONSE);
|
|
347
|
+
const recoveryOptions = {
|
|
348
|
+
backupKey: testData.HOT_WALLET_KEY_CARD_INFO.BACKUP_KEY,
|
|
349
|
+
userKey: testData.HOT_WALLET_KEY_CARD_INFO.USER_KEY,
|
|
350
|
+
rootAddress: rootAddress,
|
|
351
|
+
recoveryDestination: testData.DESTINATION_ADDRESS_WRW,
|
|
352
|
+
bitgoKey: testData.HOT_WALLET_KEY_CARD_INFO.BITGO_PUB_KEY,
|
|
353
|
+
walletPassphrase: testData.HOT_WALLET_KEY_CARD_INFO.WALLET_PASSPHRASE,
|
|
354
|
+
contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH.tsip6dp-token',
|
|
355
|
+
};
|
|
356
|
+
await basecoin.recover(recoveryOptions).should.rejectedWith('insufficient balance to build the transaction');
|
|
357
|
+
});
|
|
358
|
+
it('should fail when only contract address is passed', async () => {
|
|
359
|
+
const recoveryOptions = {
|
|
360
|
+
backupKey: testData.HOT_WALLET_KEY_CARD_INFO.BACKUP_KEY,
|
|
361
|
+
userKey: testData.HOT_WALLET_KEY_CARD_INFO.USER_KEY,
|
|
362
|
+
rootAddress: testData.HOT_WALLET_ROOT_ADDRESS,
|
|
363
|
+
recoveryDestination: testData.DESTINATION_ADDRESS_WRW,
|
|
364
|
+
bitgoKey: testData.HOT_WALLET_KEY_CARD_INFO.BITGO_PUB_KEY,
|
|
365
|
+
walletPassphrase: testData.HOT_WALLET_KEY_CARD_INFO.WALLET_PASSPHRASE,
|
|
366
|
+
contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH',
|
|
367
|
+
};
|
|
368
|
+
await basecoin
|
|
369
|
+
.recover(recoveryOptions)
|
|
370
|
+
.should.rejectedWith('invalid contract id, please provide it in the form (contractAddress.contractName)');
|
|
371
|
+
});
|
|
372
|
+
});
|
|
373
|
+
});
|
|
374
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sip10Token.js","sourceRoot":"","sources":["../../../test/unit/sip10Token.ts"],"names":[],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport nock from 'nock';\nimport { BitGoAPI } from '@bitgo-beta/sdk-api';\nimport { TestBitGo, TestBitGoAPI } from '@bitgo-beta/sdk-test';\nimport { ITransactionRecipient, Wallet, Memo } from '@bitgo-beta/sdk-core';\n\nimport { Sip10Token } from '../../src';\nimport * as testData from '../fixtures';\nimport { RecoveryInfo, RecoveryOptions, RecoveryTransaction } from '../../src/lib/iface';\nimport assert from 'assert';\n\ndescribe('Sip10Token:', function () {\n  const sip10TokenName = 'tstx:tsip6dp';\n  let bitgo: TestBitGoAPI;\n  let basecoin: Sip10Token;\n  let newTxPrebuild: () => { txHex: string; txInfo: Record<string, unknown> };\n  let newTxParams: () => { recipients: ITransactionRecipient[]; memo?: Memo };\n  let wallet: Wallet;\n\n  const txPreBuild = {\n    txHex: testData.txForExplainFungibleTokenTransfer,\n    txInfo: {},\n  };\n\n  const txParams = {\n    recipients: testData.recipients,\n  };\n\n  const memo = {\n    type: '',\n    value: '1',\n  };\n\n  before(function () {\n    bitgo = TestBitGo.decorate(BitGoAPI, {\n      env: 'mock',\n    });\n    bitgo.initializeTestVars();\n    Sip10Token.createTokenConstructors().forEach(({ name, coinConstructor }) => {\n      bitgo.safeRegister(name, coinConstructor);\n    });\n    newTxPrebuild = () => {\n      return _.cloneDeep(txPreBuild);\n    };\n    newTxParams = () => {\n      return _.cloneDeep(txParams);\n    };\n    basecoin = bitgo.coin(sip10TokenName) as Sip10Token;\n    wallet = new Wallet(bitgo, basecoin, {});\n  });\n\n  describe('Verify Transaction', function () {\n    it('should succeed to verify transaction', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.memo = memo;\n      const verification = {};\n      const isTransactionVerified = await basecoin.verifyTransaction({\n        txParams,\n        txPrebuild,\n        verification,\n        wallet,\n      });\n      isTransactionVerified.should.equal(true);\n    });\n\n    it('should succeed to verify transaction when recipients amount are numbers', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParamsWithNumberAmounts = newTxParams();\n      txParamsWithNumberAmounts.recipients = txParamsWithNumberAmounts.recipients.map(\n        ({ address, amount, memo, tokenName }) => {\n          return { address, amount: Number(amount), memo, tokenName };\n        }\n      );\n      txParamsWithNumberAmounts.memo = memo;\n\n      const verification = {};\n      const isTransactionVerified = await basecoin.verifyTransaction({\n        txParams: txParamsWithNumberAmounts,\n        txPrebuild,\n        verification,\n        wallet,\n      });\n      isTransactionVerified.should.equal(true);\n    });\n\n    it('should succeed to verify when memo is passed', async function () {\n      const txPrebuild = newTxPrebuild();\n      txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithMemoId10;\n      const txParams = newTxParams();\n      const verification = {};\n      txParams.memo = {\n        type: '',\n        value: '10',\n      };\n      const isTransactionVerified = await basecoin.verifyTransaction({\n        txParams: txParams,\n        txPrebuild,\n        verification,\n        wallet,\n      });\n      isTransactionVerified.should.equal(true);\n    });\n\n    it('should succeed to verify when memo is zero', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithMemoZero;\n      txParams.memo = {\n        type: '',\n        value: '0',\n      };\n      const verification = {};\n      const isTransactionVerified = await basecoin.verifyTransaction({\n        txParams: txParams,\n        txPrebuild,\n        verification,\n        wallet,\n      });\n      isTransactionVerified.should.equal(true);\n    });\n\n    it('should succeed to verify when memo is passed inside recipient address', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.recipients[0].address = 'SN2NN1JP9AEP5BVE19RNJ6T2MP7NDGRZYST1VDF3M?memoId=10';\n      txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithMemoId10;\n      const verification = {};\n      const isTransactionVerified = await basecoin.verifyTransaction({\n        txParams: txParams,\n        txPrebuild,\n        verification,\n        wallet,\n      });\n      isTransactionVerified.should.equal(true);\n    });\n\n    it('should succeed to verify when memo is not passed', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txPrebuild.txHex = testData.txForExplainFungibleTokenTransferWithoutMemo;\n      const verification = {};\n      const isTransactionVerified = await basecoin.verifyTransaction({\n        txParams: txParams,\n        txPrebuild,\n        verification,\n        wallet,\n      });\n      isTransactionVerified.should.equal(true);\n    });\n\n    it('should fail to verify transaction with no recipients', async function () {\n      const txPrebuild = {};\n      const txParams = newTxParams();\n      txParams.recipients = [];\n      await basecoin\n        .verifyTransaction({\n          txParams,\n          txPrebuild,\n          wallet,\n        })\n        .should.rejectedWith('missing required tx prebuild property txHex');\n    });\n\n    it('should fail when more than 1 recipients are passed', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.recipients.push({\n        address: 'SN2NN1JP9AEP5BVE19RNJ6T2MP7NDGRZYST1VDF3N',\n        amount: '10000',\n        memo: '1',\n        tokenName: 'tsip6dp-token',\n      });\n      await basecoin\n        .verifyTransaction({\n          txParams,\n          txPrebuild,\n          wallet,\n        })\n        .should.rejectedWith(\n          \"tstx:tsip6dp doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.\"\n        );\n    });\n\n    it('should fail to verify transaction with wrong address', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.recipients[0].address = 'SN2NN1JP9AEP5BVE19RNJ6T2MP7NDGRZYST1VDF3N';\n      const verification = {};\n      await basecoin\n        .verifyTransaction({\n          txParams,\n          txPrebuild,\n          verification,\n          wallet,\n        })\n        .should.rejectedWith('Tx outputs does not match with expected txParams recipients');\n    });\n\n    it('should fail to verify transaction with wrong amount', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.recipients[0].amount = '100';\n      const verification = {};\n      await basecoin\n        .verifyTransaction({\n          txParams,\n          txPrebuild,\n          verification,\n          wallet,\n        })\n        .should.rejectedWith('Tx outputs does not match with expected txParams recipients');\n    });\n\n    it('should fail to verify transaction with wrong memo', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.recipients[0].memo = '2';\n      const verification = {};\n      await basecoin\n        .verifyTransaction({\n          txParams,\n          txPrebuild,\n          verification,\n          wallet,\n        })\n        .should.rejectedWith('Tx memo does not match with expected txParams recipient memo');\n    });\n\n    it('should fail to verify transaction with wrong token', async function () {\n      const txPrebuild = newTxPrebuild();\n      const txParams = newTxParams();\n      txParams.recipients[0].tokenName = 'tstx:tsip8dp';\n      const verification = {};\n      await basecoin\n        .verifyTransaction({\n          txParams,\n          txPrebuild,\n          verification,\n          wallet,\n        })\n        .should.rejectedWith('Tx outputs does not match with expected txParams recipients');\n    });\n  });\n\n  describe('Recover Transaction SIP10', () => {\n    before(function () {\n      nock.enableNetConnect();\n    });\n    beforeEach(function () {\n      nock.cleanAll();\n    });\n    after(function () {\n      nock.disableNetConnect();\n    });\n\n    it('should build a signed token recover transaction when private key data is passed', async () => {\n      const rootAddress = testData.HOT_WALLET_ROOT_ADDRESS;\n      nock(`https://api.testnet.hiro.so`)\n        .get(`/extended/v2/addresses/${rootAddress}/balances/stx`)\n        .reply(200, testData.ACCOUNT_BALANCE_RESPONSE);\n      nock('https://api.testnet.hiro.so')\n        .get(`/extended/v2/addresses/${rootAddress}/balances/ft/${testData.STX_TOKEN_ASSET_ID}`)\n        .reply(200, testData.TOKEN_BALANCE_RESPONSE);\n      nock(`https://api.testnet.hiro.so`)\n        .get(`/extended/v1/address/${rootAddress}/nonces`)\n        .reply(200, testData.ACCOUNT_NONCE_RESPONSE);\n      nock(`https://api.testnet.hiro.so`, { allowUnmocked: true })\n        .post(`/v2/fees/transaction`, testData.FEE_ESTIMATION_TOKEN_REQUEST)\n        .reply(200, testData.FEE_ESTIMATION_TOKEN_RESPONSE);\n\n      const recoveryOptions: RecoveryOptions = {\n        backupKey: testData.HOT_WALLET_KEY_CARD_INFO.BACKUP_KEY,\n        userKey: testData.HOT_WALLET_KEY_CARD_INFO.USER_KEY,\n        rootAddress: rootAddress,\n        recoveryDestination: testData.DESTINATION_ADDRESS_WRW,\n        bitgoKey: testData.HOT_WALLET_KEY_CARD_INFO.BITGO_PUB_KEY,\n        walletPassphrase: testData.HOT_WALLET_KEY_CARD_INFO.WALLET_PASSPHRASE,\n        contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH.tsip6dp-token',\n      };\n      const response: RecoveryTransaction = await basecoin.recover(recoveryOptions);\n      response.should.have.property('txHex');\n      assert.deepEqual(response.txHex, testData.HOT_WALLET_TOKEN_RECOVERY_TX_HEX, 'tx hex not matching!');\n    });\n\n    it('should build an unsigned token transaction when public keys are passed', async () => {\n      const rootAddress = testData.COLD_WALLET_ROOT_ADDRESS;\n      nock(`https://api.testnet.hiro.so`)\n        .get(`/extended/v2/addresses/${rootAddress}/balances/stx`)\n        .reply(200, testData.ACCOUNT_BALANCE_RESPONSE);\n      nock('https://api.testnet.hiro.so')\n        .get(`/extended/v2/addresses/${rootAddress}/balances/ft/${testData.STX_TOKEN_ASSET_ID}`)\n        .reply(200, testData.TOKEN_BALANCE_RESPONSE);\n      nock(`https://api.testnet.hiro.so`, { allowUnmocked: true })\n        .get(`/extended/v1/address/${rootAddress}/nonces`)\n        .reply(200, testData.ACCOUNT_NONCE_RESPONSE);\n      const feeEstimateRequest = testData.FEE_ESTIMATION_TOKEN_REQUEST;\n      feeEstimateRequest.transaction_payload =\n        '021a1500a1c42f0c11bfe3893f479af18904677685be0d747369703664702d746f6b656e087472616e73666572000000040100000000000000000000000005f5e10005159f2f1aff6fa0062e1f7fa6096133e75f47a7e8f7051a1500a1c42f0c11bfe3893f479af18904677685be09';\n      nock(`https://api.testnet.hiro.so`)\n        .post(`/v2/fees/transaction`, feeEstimateRequest)\n        .reply(200, testData.FEE_ESTIMATION_TOKEN_RESPONSE);\n\n      const recoveryOptions: RecoveryOptions = {\n        backupKey: testData.COLD_WALLET_PUBLIC_KEY_INFO.BACKUP_KEY,\n        userKey: testData.COLD_WALLET_PUBLIC_KEY_INFO.USER_KEY,\n        rootAddress: rootAddress,\n        recoveryDestination: testData.DESTINATION_ADDRESS_WRW,\n        bitgoKey: testData.COLD_WALLET_PUBLIC_KEY_INFO.BITGO_PUB_KEY,\n        contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH.tsip6dp-token',\n      };\n      const response: RecoveryInfo = (await basecoin.recover(recoveryOptions)) as RecoveryInfo;\n      response.should.have.property('txHex');\n      response.should.have.property('coin');\n      response.should.have.property('feeInfo');\n      assert.deepEqual(response.txHex, testData.COLD_WALLET_TOKEN_UNSIGNED_SWEEP_TX_HEX, 'tx hex not matching!');\n      assert.deepEqual(response.coin, 'tstx:tsip6dp', 'coin not matching!');\n    });\n\n    it('should fail with insufficient balance when native stx balance is lower than fee for sip10', async () => {\n      const rootAddress = testData.HOT_WALLET_ROOT_ADDRESS;\n      const accountBalance = JSON.parse(JSON.stringify(testData.ACCOUNT_BALANCE_RESPONSE));\n      accountBalance.balance = '100'; // set balance lower than fee\n      nock(`https://api.testnet.hiro.so`)\n        .get(`/extended/v2/addresses/${rootAddress}/balances/stx`)\n        .reply(200, accountBalance);\n      nock('https://api.testnet.hiro.so')\n        .get(`/extended/v2/addresses/${rootAddress}/balances/ft/${testData.STX_TOKEN_ASSET_ID}`)\n        .reply(200, testData.TOKEN_BALANCE_RESPONSE);\n      nock(`https://api.testnet.hiro.so`)\n        .get(`/extended/v1/address/${rootAddress}/nonces`)\n        .reply(200, testData.ACCOUNT_NONCE_RESPONSE);\n      const feeRequestBody = testData.FEE_ESTIMATION_TOKEN_REQUEST;\n      feeRequestBody.transaction_payload =\n        '021a1500a1c42f0c11bfe3893f479af18904677685be0d747369703664702d746f6b656e087472616e73666572000000040100000000000000000000000005f5e100051549857eb4b6dd4fee08c3ec04e3d0ed04ef67d324051a1500a1c42f0c11bfe3893f479af18904677685be09';\n      nock(`https://api.testnet.hiro.so`, { allowUnmocked: true })\n        .post(`/v2/fees/transaction`, feeRequestBody)\n        .reply(200, testData.FEE_ESTIMATION_TOKEN_RESPONSE);\n      const recoveryOptions: RecoveryOptions = {\n        backupKey: testData.HOT_WALLET_KEY_CARD_INFO.BACKUP_KEY,\n        userKey: testData.HOT_WALLET_KEY_CARD_INFO.USER_KEY,\n        rootAddress: rootAddress,\n        recoveryDestination: testData.DESTINATION_ADDRESS_WRW,\n        bitgoKey: testData.HOT_WALLET_KEY_CARD_INFO.BITGO_PUB_KEY,\n        walletPassphrase: testData.HOT_WALLET_KEY_CARD_INFO.WALLET_PASSPHRASE,\n        contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH.tsip6dp-token',\n      };\n      await basecoin.recover(recoveryOptions).should.rejectedWith('insufficient balance to build the transaction');\n    });\n\n    it('should fail when only contract address is passed', async () => {\n      const recoveryOptions: RecoveryOptions = {\n        backupKey: testData.HOT_WALLET_KEY_CARD_INFO.BACKUP_KEY,\n        userKey: testData.HOT_WALLET_KEY_CARD_INFO.USER_KEY,\n        rootAddress: testData.HOT_WALLET_ROOT_ADDRESS,\n        recoveryDestination: testData.DESTINATION_ADDRESS_WRW,\n        bitgoKey: testData.HOT_WALLET_KEY_CARD_INFO.BITGO_PUB_KEY,\n        walletPassphrase: testData.HOT_WALLET_KEY_CARD_INFO.WALLET_PASSPHRASE,\n        contractId: 'STAG18E45W613FZ3H4ZMF6QHH426EXM5QTSAVWYH',\n      };\n      await basecoin\n        .recover(recoveryOptions)\n        .should.rejectedWith('invalid contract id, please provide it in the form (contractAddress.contractName)');\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stx.d.ts","sourceRoot":"","sources":["../../../test/unit/stx.ts"],"names":[],"mappings":""}
|