@bitgo-beta/sdk-coin-hbar 2.0.73-alpha.13 → 2.0.73-alpha.131
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/src/hbar.d.ts +20 -3
- package/dist/src/hbar.d.ts.map +1 -1
- package/dist/src/hbar.js +183 -6
- package/dist/src/lib/index.d.ts +1 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +1 -1
- package/dist/test/fixtures/hbar.d.ts +6 -0
- package/dist/test/fixtures/hbar.d.ts.map +1 -0
- package/dist/test/fixtures/hbar.js +9 -0
- package/dist/test/resources/hbar.d.ts +67 -0
- package/dist/test/resources/hbar.d.ts.map +1 -0
- package/dist/test/resources/hbar.js +73 -0
- package/dist/test/unit/fixtures/hbarBackupKey.d.ts +4 -0
- package/dist/test/unit/fixtures/hbarBackupKey.d.ts.map +1 -0
- package/dist/test/unit/fixtures/hbarBackupKey.js +10 -0
- package/dist/test/unit/getBuilderFactory.d.ts +3 -0
- package/dist/test/unit/getBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/getBuilderFactory.js +10 -0
- package/dist/test/unit/hbar.d.ts +2 -0
- package/dist/test/unit/hbar.d.ts.map +1 -0
- package/dist/test/unit/hbar.js +1437 -0
- package/dist/test/unit/hbarToken.d.ts +2 -0
- package/dist/test/unit/hbarToken.d.ts.map +1 -0
- package/dist/test/unit/hbarToken.js +34 -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 +179 -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 +94 -0
- package/dist/test/unit/transactionBuilder/tokenAssociateBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/tokenAssociateBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/tokenAssociateBuilder.js +215 -0
- package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +329 -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 +353 -0
- package/dist/test/unit/transactionBuilder/walletInitialization.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/walletInitialization.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/walletInitialization.js +214 -0
- package/dist/test/unit/utils.d.ts +2 -0
- package/dist/test/unit/utils.d.ts.map +1 -0
- package/dist/test/unit/utils.js +275 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +13 -10
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -743
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hbarToken.d.ts","sourceRoot":"","sources":["../../../test/unit/hbarToken.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
require("should");
|
|
4
|
+
const sdk_test_1 = require("@bitgo-beta/sdk-test");
|
|
5
|
+
const sdk_api_1 = require("@bitgo-beta/sdk-api");
|
|
6
|
+
const src_1 = require("../../src");
|
|
7
|
+
describe('Hedera Hashgraph Token', function () {
|
|
8
|
+
let bitgo;
|
|
9
|
+
let token;
|
|
10
|
+
const tokenName = 'thbar:usdc';
|
|
11
|
+
before(function () {
|
|
12
|
+
bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'mock' });
|
|
13
|
+
src_1.HbarToken.createTokenConstructors().forEach(({ name, coinConstructor }) => {
|
|
14
|
+
bitgo.safeRegister(name, coinConstructor);
|
|
15
|
+
});
|
|
16
|
+
bitgo.initializeTestVars();
|
|
17
|
+
token = bitgo.coin(tokenName);
|
|
18
|
+
});
|
|
19
|
+
it('Return correct configurations', function () {
|
|
20
|
+
token.getChain().should.equal('thbar:usdc');
|
|
21
|
+
token.getFullName().should.equal('Testnet Hedera USD Coin');
|
|
22
|
+
token.getBaseFactor().should.equal(1e6);
|
|
23
|
+
token.type.should.equal('thbar:usdc');
|
|
24
|
+
token.name.should.equal('Testnet Hedera USD Coin');
|
|
25
|
+
token.coin.should.equal('thbar');
|
|
26
|
+
token.network.should.equal('Testnet');
|
|
27
|
+
token.decimalPlaces.should.equal(6);
|
|
28
|
+
token.nodeAccountId.should.equal('0.0.3');
|
|
29
|
+
token.tokenId.should.equal('0.0.429274');
|
|
30
|
+
token.contractAddress.should.equal('0.0.429274');
|
|
31
|
+
token.tokenId.should.equal(token.contractAddress);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGJhclRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vdGVzdC91bml0L2hiYXJUb2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGtCQUFnQjtBQUNoQixtREFBK0Q7QUFDL0QsaURBQStDO0FBQy9DLG1DQUFzQztBQUV0QyxRQUFRLENBQUMsd0JBQXdCLEVBQUU7SUFDakMsSUFBSSxLQUFtQixDQUFDO0lBQ3hCLElBQUksS0FBZ0IsQ0FBQztJQUNyQixNQUFNLFNBQVMsR0FBRyxZQUFZLENBQUM7SUFFL0IsTUFBTSxDQUFDO1FBQ0wsS0FBSyxHQUFHLG9CQUFTLENBQUMsUUFBUSxDQUFDLGtCQUFRLEVBQUUsRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUN0RCxlQUFTLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxFQUFFO1lBQ3hFLEtBQUssQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1FBQzVDLENBQUMsQ0FBQyxDQUFDO1FBQ0gsS0FBSyxDQUFDLGtCQUFrQixFQUFFLENBQUM7UUFDM0IsS0FBSyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFjLENBQUM7SUFDN0MsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsK0JBQStCLEVBQUU7UUFDbEMsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDNUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUM1RCxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN4QyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDdEMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDbkQsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2pDLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUN0QyxLQUFLLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDcEMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzFDLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN6QyxLQUFLLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDakQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICdzaG91bGQnO1xuaW1wb3J0IHsgVGVzdEJpdEdvLCBUZXN0Qml0R29BUEkgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstdGVzdCc7XG5pbXBvcnQgeyBCaXRHb0FQSSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1hcGknO1xuaW1wb3J0IHsgSGJhclRva2VuIH0gZnJvbSAnLi4vLi4vc3JjJztcblxuZGVzY3JpYmUoJ0hlZGVyYSBIYXNoZ3JhcGggVG9rZW4nLCBmdW5jdGlvbiAoKSB7XG4gIGxldCBiaXRnbzogVGVzdEJpdEdvQVBJO1xuICBsZXQgdG9rZW46IEhiYXJUb2tlbjtcbiAgY29uc3QgdG9rZW5OYW1lID0gJ3RoYmFyOnVzZGMnO1xuXG4gIGJlZm9yZShmdW5jdGlvbiAoKSB7XG4gICAgYml0Z28gPSBUZXN0Qml0R28uZGVjb3JhdGUoQml0R29BUEksIHsgZW52OiAnbW9jaycgfSk7XG4gICAgSGJhclRva2VuLmNyZWF0ZVRva2VuQ29uc3RydWN0b3JzKCkuZm9yRWFjaCgoeyBuYW1lLCBjb2luQ29uc3RydWN0b3IgfSkgPT4ge1xuICAgICAgYml0Z28uc2FmZVJlZ2lzdGVyKG5hbWUsIGNvaW5Db25zdHJ1Y3Rvcik7XG4gICAgfSk7XG4gICAgYml0Z28uaW5pdGlhbGl6ZVRlc3RWYXJzKCk7XG4gICAgdG9rZW4gPSBiaXRnby5jb2luKHRva2VuTmFtZSkgYXMgSGJhclRva2VuO1xuICB9KTtcblxuICBpdCgnUmV0dXJuIGNvcnJlY3QgY29uZmlndXJhdGlvbnMnLCBmdW5jdGlvbiAoKSB7XG4gICAgdG9rZW4uZ2V0Q2hhaW4oKS5zaG91bGQuZXF1YWwoJ3RoYmFyOnVzZGMnKTtcbiAgICB0b2tlbi5nZXRGdWxsTmFtZSgpLnNob3VsZC5lcXVhbCgnVGVzdG5ldCBIZWRlcmEgVVNEIENvaW4nKTtcbiAgICB0b2tlbi5nZXRCYXNlRmFjdG9yKCkuc2hvdWxkLmVxdWFsKDFlNik7XG4gICAgdG9rZW4udHlwZS5zaG91bGQuZXF1YWwoJ3RoYmFyOnVzZGMnKTtcbiAgICB0b2tlbi5uYW1lLnNob3VsZC5lcXVhbCgnVGVzdG5ldCBIZWRlcmEgVVNEIENvaW4nKTtcbiAgICB0b2tlbi5jb2luLnNob3VsZC5lcXVhbCgndGhiYXInKTtcbiAgICB0b2tlbi5uZXR3b3JrLnNob3VsZC5lcXVhbCgnVGVzdG5ldCcpO1xuICAgIHRva2VuLmRlY2ltYWxQbGFjZXMuc2hvdWxkLmVxdWFsKDYpO1xuICAgIHRva2VuLm5vZGVBY2NvdW50SWQuc2hvdWxkLmVxdWFsKCcwLjAuMycpO1xuICAgIHRva2VuLnRva2VuSWQuc2hvdWxkLmVxdWFsKCcwLjAuNDI5Mjc0Jyk7XG4gICAgdG9rZW4uY29udHJhY3RBZGRyZXNzLnNob3VsZC5lcXVhbCgnMC4wLjQyOTI3NCcpO1xuICAgIHRva2VuLnRva2VuSWQuc2hvdWxkLmVxdWFsKHRva2VuLmNvbnRyYWN0QWRkcmVzcyk7XG4gIH0pO1xufSk7XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keyPair.d.ts","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,179 @@
|
|
|
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 assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const should = __importStar(require("should"));
|
|
41
|
+
const nacl = __importStar(require("tweetnacl"));
|
|
42
|
+
const src_1 = require("../../src");
|
|
43
|
+
const testData = __importStar(require("../resources/hbar"));
|
|
44
|
+
const utils_1 = require("../../src/lib/utils");
|
|
45
|
+
const pub = testData.ACCOUNT_1.pubKeyWithPrefix;
|
|
46
|
+
const prv = testData.ACCOUNT_1.prvKeyWithPrefix;
|
|
47
|
+
describe('Hedera Key Pair', () => {
|
|
48
|
+
describe('should create a valid KeyPair', () => {
|
|
49
|
+
it('from an empty value', () => {
|
|
50
|
+
const keyPair = new src_1.KeyPair();
|
|
51
|
+
should.exists(keyPair.getKeys().prv);
|
|
52
|
+
should.exists(keyPair.getKeys().pub);
|
|
53
|
+
should.equal(keyPair.getKeys(true).prv.length, 64);
|
|
54
|
+
should.equal(keyPair.getKeys(true).pub.length, 64);
|
|
55
|
+
should.equal(keyPair.getKeys().prv.slice(0, 32), testData.ed25519PrivKeyPrefix);
|
|
56
|
+
should.equal(keyPair.getKeys().pub.slice(0, 24), testData.ed25519PubKeyPrefix);
|
|
57
|
+
});
|
|
58
|
+
it('from a seed', () => {
|
|
59
|
+
const keyPair = new src_1.KeyPair({ seed: Buffer.from((0, utils_1.toUint8Array)(testData.ACCOUNT_1.prvKeyWithPrefix.slice(32))) });
|
|
60
|
+
should.equal(keyPair.getKeys().prv, testData.ACCOUNT_1.prvKeyWithPrefix);
|
|
61
|
+
should.equal(keyPair.getKeys().pub, testData.ACCOUNT_1.pubKeyWithPrefix);
|
|
62
|
+
});
|
|
63
|
+
it('from a public key', () => {
|
|
64
|
+
const keyPair = new src_1.KeyPair({ pub: pub });
|
|
65
|
+
should.equal(keyPair.getKeys().pub, pub);
|
|
66
|
+
});
|
|
67
|
+
it('from a public key with prefix', () => {
|
|
68
|
+
const stellarPubs = [
|
|
69
|
+
'GBVEZT27ZUCMJABF76XIPPO7M3KUABVR4GZNPBAD3YTPXUSDA57ANRLD',
|
|
70
|
+
'GDMQYYBRX3ZD34VHU4IJNSLASAQY6VZ7B6UJD5OFKSOW7XFJI5MZMETW',
|
|
71
|
+
'GAD2SVW5EZLCH6HDC3VK7UE4DZK7KCIUHVCY2PO7ZEUERSWU6QQ6QIHB',
|
|
72
|
+
];
|
|
73
|
+
stellarPubs.forEach((stellarPub) => {
|
|
74
|
+
const edPub = (0, utils_1.convertFromStellarPub)(stellarPub);
|
|
75
|
+
const keyPair = new src_1.KeyPair({ pub: edPub });
|
|
76
|
+
should.exist(keyPair.getKeys().pub);
|
|
77
|
+
should.not.exist(keyPair.getKeys().prv);
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
it('from a private key', () => {
|
|
81
|
+
const keyPair = new src_1.KeyPair({ prv: prv });
|
|
82
|
+
should.equal(keyPair.getKeys().prv, prv);
|
|
83
|
+
should.equal(keyPair.getKeys().pub, pub);
|
|
84
|
+
});
|
|
85
|
+
it('from a private key with prefix', () => {
|
|
86
|
+
const keyPair = new src_1.KeyPair({ prv: testData.ACCOUNT_1.prvKeyWithPrefix });
|
|
87
|
+
should.equal(keyPair.getKeys().prv, prv);
|
|
88
|
+
should.equal(keyPair.getKeys().pub, pub);
|
|
89
|
+
});
|
|
90
|
+
it('from seed', () => {
|
|
91
|
+
const seed = nacl.randomBytes(32);
|
|
92
|
+
const keyPair = new src_1.KeyPair({ seed: Buffer.from(seed) });
|
|
93
|
+
keyPair.getKeys().should.have.property('pub');
|
|
94
|
+
keyPair.getKeys().should.have.property('prv');
|
|
95
|
+
});
|
|
96
|
+
it('without source', () => {
|
|
97
|
+
const keyPair = new src_1.KeyPair();
|
|
98
|
+
keyPair.getKeys().should.have.property('pub');
|
|
99
|
+
keyPair.getKeys().should.have.property('prv');
|
|
100
|
+
});
|
|
101
|
+
it('from a byte array private key', () => {
|
|
102
|
+
const keyPair = new src_1.KeyPair({ prv: Buffer.from(testData.ACCOUNT_1.privateKeyBytes).toString('hex') });
|
|
103
|
+
should.equal(keyPair.getKeys().prv, prv);
|
|
104
|
+
});
|
|
105
|
+
it('from a byte array public key', () => {
|
|
106
|
+
const keyPair = new src_1.KeyPair({ pub: Buffer.from(testData.ACCOUNT_1.publicKeyBytes).toString('hex') });
|
|
107
|
+
should.equal(keyPair.getKeys().pub, pub);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
describe('should fail to create a KeyPair', () => {
|
|
111
|
+
it('from an invalid public key', () => {
|
|
112
|
+
const source = { pub: '01D63D' };
|
|
113
|
+
assert_1.default.throws(() => new src_1.KeyPair(source), (e) => e.message.includes(testData.errorMessageInvalidPublicKey));
|
|
114
|
+
});
|
|
115
|
+
it('from an invalid private key', () => {
|
|
116
|
+
const shorterPrv = { prv: '82A34E' };
|
|
117
|
+
const longerPrv = { prv: prv + '12' };
|
|
118
|
+
const prvWithPrefix = { prv: testData.ed25519PrivKeyPrefix + prv + '12' };
|
|
119
|
+
const prvWithOddNumber = { prv: testData.ed25519PrivKeyPrefix + prv + '1' };
|
|
120
|
+
const prvWithNonHex = { prv: testData.ed25519PrivKeyPrefix + prv + 'GG' };
|
|
121
|
+
assert_1.default.throws(() => new src_1.KeyPair(shorterPrv), (e) => e.message === testData.errorMessageInvalidPrivateKey);
|
|
122
|
+
assert_1.default.throws(() => new src_1.KeyPair(longerPrv), (e) => e.message === testData.errorMessageInvalidPrivateKey);
|
|
123
|
+
assert_1.default.throws(() => new src_1.KeyPair(prvWithPrefix), (e) => e.message === testData.errorMessageInvalidPrivateKey);
|
|
124
|
+
assert_1.default.throws(() => new src_1.KeyPair({ prv: prv + pub }), (e) => e.message === testData.errorMessageInvalidPrivateKey);
|
|
125
|
+
assert_1.default.throws(() => new src_1.KeyPair(prvWithOddNumber), (e) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey);
|
|
126
|
+
assert_1.default.throws(() => new src_1.KeyPair(prvWithNonHex), (e) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey);
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
describe('should fail to get address ', () => {
|
|
130
|
+
it('from a private key', () => {
|
|
131
|
+
const keyPair = new src_1.KeyPair({ prv: prv });
|
|
132
|
+
assert_1.default.throws(() => keyPair.getAddress(), (e) => e.message === testData.errorMessageNotPossibleToDeriveAddress);
|
|
133
|
+
});
|
|
134
|
+
it('from a public key', () => {
|
|
135
|
+
const keyPair = new src_1.KeyPair({ pub: pub });
|
|
136
|
+
assert_1.default.throws(() => keyPair.getAddress(), (e) => e.message === testData.errorMessageNotPossibleToDeriveAddress);
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
describe('should succeed to sign and verify ', () => {
|
|
140
|
+
it('a random message', () => {
|
|
141
|
+
const message = 'Hello World!';
|
|
142
|
+
const keyPair = new src_1.KeyPair({ prv: prv });
|
|
143
|
+
const signature = keyPair.signMessage(message);
|
|
144
|
+
const isValid = keyPair.verifySignature(message, signature);
|
|
145
|
+
isValid.should.be.true();
|
|
146
|
+
});
|
|
147
|
+
it('a public key in hex format', () => {
|
|
148
|
+
const keyPair = new src_1.KeyPair({ prv: prv });
|
|
149
|
+
const message = keyPair.getKeys().pub;
|
|
150
|
+
const signature = keyPair.signMessage(message);
|
|
151
|
+
const isValid = keyPair.verifySignature(message, signature);
|
|
152
|
+
isValid.should.be.true();
|
|
153
|
+
});
|
|
154
|
+
it('a message in hex format', () => {
|
|
155
|
+
const userPub = '302a300506032b657003210012558e304e09d468d3ab07edf6f7e634adc4788cee76d6a9eb2aff9385698077';
|
|
156
|
+
const message = '302a300506032b6570032100aa3de24a1df3ce6fb61c8397358985f1df517853ef01523daee5b19dc82f40d5';
|
|
157
|
+
const signature = Buffer.from('76ca6556fbfcc5a8b43c12ba6425c5a6c90f5033180628410b5c29f651719f58ef4c1e' +
|
|
158
|
+
'78dddd5fd794c555ec38c9b9c02ea76d3eef4d8422ae7ea8363cab920c', 'hex');
|
|
159
|
+
const keyPair = new src_1.KeyPair({ pub: userPub });
|
|
160
|
+
const isValid = keyPair.verifySignature(message, new Uint8Array(signature));
|
|
161
|
+
isValid.should.be.true();
|
|
162
|
+
});
|
|
163
|
+
it('an empty message', () => {
|
|
164
|
+
const message = '';
|
|
165
|
+
const keyPair = new src_1.KeyPair({ prv: prv });
|
|
166
|
+
const signature = keyPair.signMessage(message);
|
|
167
|
+
const isValid = keyPair.verifySignature(message, signature);
|
|
168
|
+
isValid.should.be.true();
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
describe('should fail sign ', () => {
|
|
172
|
+
it('a message without a private key', () => {
|
|
173
|
+
const message = 'Hello World!';
|
|
174
|
+
const keyPair = new src_1.KeyPair({ pub: pub });
|
|
175
|
+
assert_1.default.throws(() => keyPair.signMessage(message), (e) => e.message === testData.errorMessageMissingPrivateKey);
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
});
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport * as should from 'should';\nimport * as nacl from 'tweetnacl';\nimport { KeyPair } from '../../src';\nimport * as testData from '../resources/hbar';\nimport { convertFromStellarPub, toUint8Array } from '../../src/lib/utils';\n\nconst pub = testData.ACCOUNT_1.pubKeyWithPrefix;\nconst prv = testData.ACCOUNT_1.prvKeyWithPrefix;\n\ndescribe('Hedera Key Pair', () => {\n  describe('should create a valid KeyPair', () => {\n    it('from an empty value', () => {\n      const keyPair = new KeyPair();\n      should.exists(keyPair.getKeys().prv);\n      should.exists(keyPair.getKeys().pub);\n      should.equal(keyPair.getKeys(true).prv!.length, 64);\n      should.equal(keyPair.getKeys(true).pub.length, 64);\n      should.equal(keyPair.getKeys().prv!.slice(0, 32), testData.ed25519PrivKeyPrefix);\n      should.equal(keyPair.getKeys().pub.slice(0, 24), testData.ed25519PubKeyPrefix);\n    });\n\n    it('from a seed', () => {\n      const keyPair = new KeyPair({ seed: Buffer.from(toUint8Array(testData.ACCOUNT_1.prvKeyWithPrefix.slice(32))) });\n      should.equal(keyPair.getKeys().prv!, testData.ACCOUNT_1.prvKeyWithPrefix);\n      should.equal(keyPair.getKeys().pub, testData.ACCOUNT_1.pubKeyWithPrefix);\n    });\n\n    it('from a public key', () => {\n      const keyPair = new KeyPair({ pub: pub });\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n\n    it('from a public key with prefix', () => {\n      const stellarPubs = [\n        'GBVEZT27ZUCMJABF76XIPPO7M3KUABVR4GZNPBAD3YTPXUSDA57ANRLD',\n        'GDMQYYBRX3ZD34VHU4IJNSLASAQY6VZ7B6UJD5OFKSOW7XFJI5MZMETW',\n        'GAD2SVW5EZLCH6HDC3VK7UE4DZK7KCIUHVCY2PO7ZEUERSWU6QQ6QIHB',\n      ];\n\n      stellarPubs.forEach((stellarPub) => {\n        const edPub = convertFromStellarPub(stellarPub);\n        const keyPair = new KeyPair({ pub: edPub });\n\n        should.exist(keyPair.getKeys().pub);\n        should.not.exist(keyPair.getKeys().prv);\n      });\n    });\n\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: prv });\n      should.equal(keyPair.getKeys().prv!, prv);\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n\n    it('from a private key with prefix', () => {\n      const keyPair = new KeyPair({ prv: testData.ACCOUNT_1.prvKeyWithPrefix });\n      should.equal(keyPair.getKeys().prv!, prv);\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n\n    it('from seed', () => {\n      const seed = nacl.randomBytes(32);\n      const keyPair = new KeyPair({ seed: Buffer.from(seed) });\n      keyPair.getKeys().should.have.property('pub');\n      keyPair.getKeys().should.have.property('prv');\n    });\n\n    it('without source', () => {\n      const keyPair = new KeyPair();\n      keyPair.getKeys().should.have.property('pub');\n      keyPair.getKeys().should.have.property('prv');\n    });\n\n    it('from a byte array private key', () => {\n      const keyPair = new KeyPair({ prv: Buffer.from(testData.ACCOUNT_1.privateKeyBytes).toString('hex') });\n      should.equal(keyPair.getKeys().prv!, prv);\n    });\n\n    it('from a byte array public key', () => {\n      const keyPair = new KeyPair({ pub: Buffer.from(testData.ACCOUNT_1.publicKeyBytes).toString('hex') });\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n  });\n\n  describe('should fail to create a KeyPair', () => {\n    it('from an invalid public key', () => {\n      const source = { pub: '01D63D' };\n      assert.throws(\n        () => new KeyPair(source),\n        (e: any) => e.message.includes(testData.errorMessageInvalidPublicKey)\n      );\n    });\n\n    it('from an invalid private key', () => {\n      const shorterPrv = { prv: '82A34E' };\n      const longerPrv = { prv: prv + '12' };\n      const prvWithPrefix = { prv: testData.ed25519PrivKeyPrefix + prv + '12' };\n      const prvWithOddNumber = { prv: testData.ed25519PrivKeyPrefix + prv + '1' };\n      const prvWithNonHex = { prv: testData.ed25519PrivKeyPrefix + prv + 'GG' };\n      assert.throws(\n        () => new KeyPair(shorterPrv),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(longerPrv),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(prvWithPrefix),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair({ prv: prv + pub }),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(prvWithOddNumber),\n        (e: any) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(prvWithNonHex),\n        (e: any) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey\n      );\n    });\n  });\n\n  describe('should fail to get address ', () => {\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: prv });\n      assert.throws(\n        () => keyPair.getAddress(),\n        (e: any) => e.message === testData.errorMessageNotPossibleToDeriveAddress\n      );\n    });\n\n    it('from a public key', () => {\n      const keyPair = new KeyPair({ pub: pub });\n      assert.throws(\n        () => keyPair.getAddress(),\n        (e: any) => e.message === testData.errorMessageNotPossibleToDeriveAddress\n      );\n    });\n  });\n\n  describe('should succeed to sign and verify ', () => {\n    it('a random message', () => {\n      const message = 'Hello World!';\n      const keyPair = new KeyPair({ prv: prv });\n      const signature = keyPair.signMessage(message);\n      const isValid = keyPair.verifySignature(message, signature);\n      isValid.should.be.true();\n    });\n\n    it('a public key in hex format', () => {\n      const keyPair = new KeyPair({ prv: prv });\n      const message = keyPair.getKeys().pub;\n      const signature = keyPair.signMessage(message);\n      const isValid = keyPair.verifySignature(message, signature);\n      isValid.should.be.true();\n    });\n\n    it('a message in hex format', () => {\n      const userPub = '302a300506032b657003210012558e304e09d468d3ab07edf6f7e634adc4788cee76d6a9eb2aff9385698077';\n      const message = '302a300506032b6570032100aa3de24a1df3ce6fb61c8397358985f1df517853ef01523daee5b19dc82f40d5';\n      const signature = Buffer.from(\n        '76ca6556fbfcc5a8b43c12ba6425c5a6c90f5033180628410b5c29f651719f58ef4c1e' +\n          '78dddd5fd794c555ec38c9b9c02ea76d3eef4d8422ae7ea8363cab920c',\n        'hex'\n      );\n\n      const keyPair = new KeyPair({ pub: userPub });\n      const isValid = keyPair.verifySignature(message, new Uint8Array(signature));\n      isValid.should.be.true();\n    });\n\n    it('an empty message', () => {\n      const message = '';\n      const keyPair = new KeyPair({ prv: prv });\n      const signature = keyPair.signMessage(message);\n      const isValid = keyPair.verifySignature(message, signature);\n      isValid.should.be.true();\n    });\n  });\n\n  describe('should fail sign ', () => {\n    it('a message without a private key', () => {\n      const message = 'Hello World!';\n      const keyPair = new KeyPair({ pub: pub });\n      assert.throws(\n        () => keyPair.signMessage(message),\n        (e: any) => e.message === testData.errorMessageMissingPrivateKey\n      );\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../test/unit/transaction.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,94 @@
|
|
|
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 assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const should_1 = __importDefault(require("should"));
|
|
41
|
+
const statics_1 = require("@bitgo-beta/statics");
|
|
42
|
+
const src_1 = require("../../src");
|
|
43
|
+
const testData = __importStar(require("../resources/hbar"));
|
|
44
|
+
describe('Hbar Transaction', () => {
|
|
45
|
+
const coin = statics_1.coins.get('thbar');
|
|
46
|
+
/**
|
|
47
|
+
*
|
|
48
|
+
*/
|
|
49
|
+
function getTransaction() {
|
|
50
|
+
return new src_1.Transaction(coin);
|
|
51
|
+
}
|
|
52
|
+
it('should throw empty transaction', () => {
|
|
53
|
+
const tx = getTransaction();
|
|
54
|
+
assert_1.default.throws(() => {
|
|
55
|
+
tx.toJson();
|
|
56
|
+
});
|
|
57
|
+
assert_1.default.throws(() => {
|
|
58
|
+
tx.toBroadcastFormat();
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
describe('should sign if transaction is', () => {
|
|
62
|
+
it('invalid', function () {
|
|
63
|
+
const tx = getTransaction();
|
|
64
|
+
return tx.sign(testData.INVALID_KEYPAIR_PRV).should.be.rejected();
|
|
65
|
+
});
|
|
66
|
+
it('valid', async () => {
|
|
67
|
+
const tx = getTransaction();
|
|
68
|
+
tx.bodyBytes(testData.WALLET_TXDATA);
|
|
69
|
+
const keypair = new src_1.KeyPair({ prv: testData.ACCOUNT_1.prvKeyWithPrefix });
|
|
70
|
+
await tx.sign(keypair).should.be.fulfilled();
|
|
71
|
+
should_1.default.equal(Buffer.from(tx.hederaTx.sigMap.sigPair[0].pubKeyPrefix).toString('hex'), testData.ACCOUNT_1.pubKeyWithPrefix.slice(24));
|
|
72
|
+
});
|
|
73
|
+
it('multiple valid', async () => {
|
|
74
|
+
const tx = getTransaction();
|
|
75
|
+
tx.bodyBytes(testData.WALLET_TXDATA);
|
|
76
|
+
const keypair = new src_1.KeyPair({ prv: testData.ACCOUNT_1.prvKeyWithPrefix });
|
|
77
|
+
const keypair2 = new src_1.KeyPair({ prv: testData.OPERATOR.privateKey });
|
|
78
|
+
await tx.sign(keypair).should.be.fulfilled();
|
|
79
|
+
should_1.default.equal(Buffer.from(tx.hederaTx.sigMap.sigPair[0].pubKeyPrefix).toString('hex'), testData.ACCOUNT_1.pubKeyWithPrefix.slice(24));
|
|
80
|
+
await tx.sign(keypair2).should.be.fulfilled();
|
|
81
|
+
should_1.default.equal(Buffer.from(tx.hederaTx.sigMap.sigPair[0].pubKeyPrefix).toString('hex'), testData.ACCOUNT_1.pubKeyWithPrefix.slice(24));
|
|
82
|
+
should_1.default.equal(Buffer.from(tx.hederaTx.sigMap.sigPair[1].pubKeyPrefix).toString('hex'), testData.OPERATOR.publicKey.slice(24));
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
describe('should return encoded tx', function () {
|
|
86
|
+
it('valid sign', async function () {
|
|
87
|
+
const tx = getTransaction();
|
|
88
|
+
tx.bodyBytes(testData.WALLET_TXDATA);
|
|
89
|
+
await tx.sign(testData.KEYPAIR_PRV);
|
|
90
|
+
should_1.default.equal(tx.toBroadcastFormat(), testData.WALLET_SIGNED_TRANSACTION);
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90ZXN0L3VuaXQvdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxvREFBNEI7QUFDNUIsb0RBQTRCO0FBQzVCLGlEQUE0QztBQUM1QyxtQ0FBaUQ7QUFDakQsNERBQThDO0FBRTlDLFFBQVEsQ0FBQyxrQkFBa0IsRUFBRSxHQUFHLEVBQUU7SUFDaEMsTUFBTSxJQUFJLEdBQUcsZUFBSyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUVoQzs7T0FFRztJQUNILFNBQVMsY0FBYztRQUNyQixPQUFPLElBQUksaUJBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBRUQsRUFBRSxDQUFDLGdDQUFnQyxFQUFFLEdBQUcsRUFBRTtRQUN4QyxNQUFNLEVBQUUsR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUM1QixnQkFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDakIsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQUM7UUFDSCxnQkFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDakIsRUFBRSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQywrQkFBK0IsRUFBRSxHQUFHLEVBQUU7UUFDN0MsRUFBRSxDQUFDLFNBQVMsRUFBRTtZQUNaLE1BQU0sRUFBRSxHQUFHLGNBQWMsRUFBRSxDQUFDO1lBQzVCLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3BFLENBQUMsQ0FBQyxDQUFDO1FBRUgsRUFBRSxDQUFDLE9BQU8sRUFBRSxLQUFLLElBQUksRUFBRTtZQUNyQixNQUFNLEVBQUUsR0FBRyxjQUFjLEVBQUUsQ0FBQztZQUM1QixFQUFFLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUNyQyxNQUFNLE9BQU8sR0FBRyxJQUFJLGFBQU8sQ0FBQyxFQUFFLEdBQUcsRUFBRSxRQUFRLENBQUMsU0FBUyxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQztZQUMxRSxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUM3QyxnQkFBTSxDQUFDLEtBQUssQ0FDVixNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsTUFBTyxDQUFDLE9BQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxZQUFhLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQzFFLFFBQVEsQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUM5QyxDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7UUFFSCxFQUFFLENBQUMsZ0JBQWdCLEVBQUUsS0FBSyxJQUFJLEVBQUU7WUFDOUIsTUFBTSxFQUFFLEdBQUcsY0FBYyxFQUFFLENBQUM7WUFDNUIsRUFBRSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDckMsTUFBTSxPQUFPLEdBQUcsSUFBSSxhQUFPLENBQUMsRUFBRSxHQUFHLEVBQUUsUUFBUSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7WUFDMUUsTUFBTSxRQUFRLEdBQUcsSUFBSSxhQUFPLENBQUMsRUFBRSxHQUFHLEVBQUUsUUFBUSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1lBQ3BFLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQzdDLGdCQUFNLENBQUMsS0FBSyxDQUNWLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxNQUFPLENBQUMsT0FBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLFlBQWEsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFDMUUsUUFBUSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQzlDLENBQUM7WUFDRixNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUM5QyxnQkFBTSxDQUFDLEtBQUssQ0FDVixNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsTUFBTyxDQUFDLE9BQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxZQUFhLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQzFFLFFBQVEsQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUM5QyxDQUFDO1lBQ0YsZ0JBQU0sQ0FBQyxLQUFLLENBQ1YsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLE1BQU8sQ0FBQyxPQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBYSxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUMxRSxRQUFRLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQ3RDLENBQUM7UUFDSixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0lBRUgsUUFBUSxDQUFDLDBCQUEwQixFQUFFO1FBQ25DLEVBQUUsQ0FBQyxZQUFZLEVBQUUsS0FBSztZQUNwQixNQUFNLEVBQUUsR0FBRyxjQUFjLEVBQUUsQ0FBQztZQUM1QixFQUFFLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUNyQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ3BDLGdCQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLFFBQVEsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBQzNFLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcbmltcG9ydCBzaG91bGQgZnJvbSAnc2hvdWxkJztcbmltcG9ydCB7IGNvaW5zIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgeyBLZXlQYWlyLCBUcmFuc2FjdGlvbiB9IGZyb20gJy4uLy4uL3NyYyc7XG5pbXBvcnQgKiBhcyB0ZXN0RGF0YSBmcm9tICcuLi9yZXNvdXJjZXMvaGJhcic7XG5cbmRlc2NyaWJlKCdIYmFyIFRyYW5zYWN0aW9uJywgKCkgPT4ge1xuICBjb25zdCBjb2luID0gY29pbnMuZ2V0KCd0aGJhcicpO1xuXG4gIC8qKlxuICAgKlxuICAgKi9cbiAgZnVuY3Rpb24gZ2V0VHJhbnNhY3Rpb24oKTogVHJhbnNhY3Rpb24ge1xuICAgIHJldHVybiBuZXcgVHJhbnNhY3Rpb24oY29pbik7XG4gIH1cblxuICBpdCgnc2hvdWxkIHRocm93IGVtcHR5IHRyYW5zYWN0aW9uJywgKCkgPT4ge1xuICAgIGNvbnN0IHR4ID0gZ2V0VHJhbnNhY3Rpb24oKTtcbiAgICBhc3NlcnQudGhyb3dzKCgpID0+IHtcbiAgICAgIHR4LnRvSnNvbigpO1xuICAgIH0pO1xuICAgIGFzc2VydC50aHJvd3MoKCkgPT4ge1xuICAgICAgdHgudG9Ccm9hZGNhc3RGb3JtYXQoKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3Nob3VsZCBzaWduIGlmIHRyYW5zYWN0aW9uIGlzJywgKCkgPT4ge1xuICAgIGl0KCdpbnZhbGlkJywgZnVuY3Rpb24gKCkge1xuICAgICAgY29uc3QgdHggPSBnZXRUcmFuc2FjdGlvbigpO1xuICAgICAgcmV0dXJuIHR4LnNpZ24odGVzdERhdGEuSU5WQUxJRF9LRVlQQUlSX1BSVikuc2hvdWxkLmJlLnJlamVjdGVkKCk7XG4gICAgfSk7XG5cbiAgICBpdCgndmFsaWQnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCB0eCA9IGdldFRyYW5zYWN0aW9uKCk7XG4gICAgICB0eC5ib2R5Qnl0ZXModGVzdERhdGEuV0FMTEVUX1RYREFUQSk7XG4gICAgICBjb25zdCBrZXlwYWlyID0gbmV3IEtleVBhaXIoeyBwcnY6IHRlc3REYXRhLkFDQ09VTlRfMS5wcnZLZXlXaXRoUHJlZml4IH0pO1xuICAgICAgYXdhaXQgdHguc2lnbihrZXlwYWlyKS5zaG91bGQuYmUuZnVsZmlsbGVkKCk7XG4gICAgICBzaG91bGQuZXF1YWwoXG4gICAgICAgIEJ1ZmZlci5mcm9tKHR4LmhlZGVyYVR4LnNpZ01hcCEuc2lnUGFpciFbMF0ucHViS2V5UHJlZml4ISkudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgICB0ZXN0RGF0YS5BQ0NPVU5UXzEucHViS2V5V2l0aFByZWZpeC5zbGljZSgyNClcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICBpdCgnbXVsdGlwbGUgdmFsaWQnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCB0eCA9IGdldFRyYW5zYWN0aW9uKCk7XG4gICAgICB0eC5ib2R5Qnl0ZXModGVzdERhdGEuV0FMTEVUX1RYREFUQSk7XG4gICAgICBjb25zdCBrZXlwYWlyID0gbmV3IEtleVBhaXIoeyBwcnY6IHRlc3REYXRhLkFDQ09VTlRfMS5wcnZLZXlXaXRoUHJlZml4IH0pO1xuICAgICAgY29uc3Qga2V5cGFpcjIgPSBuZXcgS2V5UGFpcih7IHBydjogdGVzdERhdGEuT1BFUkFUT1IucHJpdmF0ZUtleSB9KTtcbiAgICAgIGF3YWl0IHR4LnNpZ24oa2V5cGFpcikuc2hvdWxkLmJlLmZ1bGZpbGxlZCgpO1xuICAgICAgc2hvdWxkLmVxdWFsKFxuICAgICAgICBCdWZmZXIuZnJvbSh0eC5oZWRlcmFUeC5zaWdNYXAhLnNpZ1BhaXIhWzBdLnB1YktleVByZWZpeCEpLnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgdGVzdERhdGEuQUNDT1VOVF8xLnB1YktleVdpdGhQcmVmaXguc2xpY2UoMjQpXG4gICAgICApO1xuICAgICAgYXdhaXQgdHguc2lnbihrZXlwYWlyMikuc2hvdWxkLmJlLmZ1bGZpbGxlZCgpO1xuICAgICAgc2hvdWxkLmVxdWFsKFxuICAgICAgICBCdWZmZXIuZnJvbSh0eC5oZWRlcmFUeC5zaWdNYXAhLnNpZ1BhaXIhWzBdLnB1YktleVByZWZpeCEpLnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgdGVzdERhdGEuQUNDT1VOVF8xLnB1YktleVdpdGhQcmVmaXguc2xpY2UoMjQpXG4gICAgICApO1xuICAgICAgc2hvdWxkLmVxdWFsKFxuICAgICAgICBCdWZmZXIuZnJvbSh0eC5oZWRlcmFUeC5zaWdNYXAhLnNpZ1BhaXIhWzFdLnB1YktleVByZWZpeCEpLnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgdGVzdERhdGEuT1BFUkFUT1IucHVibGljS2V5LnNsaWNlKDI0KVxuICAgICAgKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3Nob3VsZCByZXR1cm4gZW5jb2RlZCB0eCcsIGZ1bmN0aW9uICgpIHtcbiAgICBpdCgndmFsaWQgc2lnbicsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICAgIGNvbnN0IHR4ID0gZ2V0VHJhbnNhY3Rpb24oKTtcbiAgICAgIHR4LmJvZHlCeXRlcyh0ZXN0RGF0YS5XQUxMRVRfVFhEQVRBKTtcbiAgICAgIGF3YWl0IHR4LnNpZ24odGVzdERhdGEuS0VZUEFJUl9QUlYpO1xuICAgICAgc2hvdWxkLmVxdWFsKHR4LnRvQnJvYWRjYXN0Rm9ybWF0KCksIHRlc3REYXRhLldBTExFVF9TSUdORURfVFJBTlNBQ1RJT04pO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokenAssociateBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/transactionBuilder/tokenAssociateBuilder.ts"],"names":[],"mappings":""}
|