@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.
Files changed (50) hide show
  1. package/dist/src/hbar.d.ts +20 -3
  2. package/dist/src/hbar.d.ts.map +1 -1
  3. package/dist/src/hbar.js +183 -6
  4. package/dist/src/lib/index.d.ts +1 -0
  5. package/dist/src/lib/index.d.ts.map +1 -1
  6. package/dist/src/lib/index.js +1 -1
  7. package/dist/test/fixtures/hbar.d.ts +6 -0
  8. package/dist/test/fixtures/hbar.d.ts.map +1 -0
  9. package/dist/test/fixtures/hbar.js +9 -0
  10. package/dist/test/resources/hbar.d.ts +67 -0
  11. package/dist/test/resources/hbar.d.ts.map +1 -0
  12. package/dist/test/resources/hbar.js +73 -0
  13. package/dist/test/unit/fixtures/hbarBackupKey.d.ts +4 -0
  14. package/dist/test/unit/fixtures/hbarBackupKey.d.ts.map +1 -0
  15. package/dist/test/unit/fixtures/hbarBackupKey.js +10 -0
  16. package/dist/test/unit/getBuilderFactory.d.ts +3 -0
  17. package/dist/test/unit/getBuilderFactory.d.ts.map +1 -0
  18. package/dist/test/unit/getBuilderFactory.js +10 -0
  19. package/dist/test/unit/hbar.d.ts +2 -0
  20. package/dist/test/unit/hbar.d.ts.map +1 -0
  21. package/dist/test/unit/hbar.js +1437 -0
  22. package/dist/test/unit/hbarToken.d.ts +2 -0
  23. package/dist/test/unit/hbarToken.d.ts.map +1 -0
  24. package/dist/test/unit/hbarToken.js +34 -0
  25. package/dist/test/unit/keyPair.d.ts +2 -0
  26. package/dist/test/unit/keyPair.d.ts.map +1 -0
  27. package/dist/test/unit/keyPair.js +179 -0
  28. package/dist/test/unit/transaction.d.ts +2 -0
  29. package/dist/test/unit/transaction.d.ts.map +1 -0
  30. package/dist/test/unit/transaction.js +94 -0
  31. package/dist/test/unit/transactionBuilder/tokenAssociateBuilder.d.ts +2 -0
  32. package/dist/test/unit/transactionBuilder/tokenAssociateBuilder.d.ts.map +1 -0
  33. package/dist/test/unit/transactionBuilder/tokenAssociateBuilder.js +215 -0
  34. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts +2 -0
  35. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
  36. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +329 -0
  37. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
  38. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  39. package/dist/test/unit/transactionBuilder/transferBuilder.js +353 -0
  40. package/dist/test/unit/transactionBuilder/walletInitialization.d.ts +2 -0
  41. package/dist/test/unit/transactionBuilder/walletInitialization.d.ts.map +1 -0
  42. package/dist/test/unit/transactionBuilder/walletInitialization.js +214 -0
  43. package/dist/test/unit/utils.d.ts +2 -0
  44. package/dist/test/unit/utils.d.ts.map +1 -0
  45. package/dist/test/unit/utils.js +275 -0
  46. package/dist/tsconfig.tsbuildinfo +1 -0
  47. package/package.json +13 -10
  48. package/.eslintignore +0 -5
  49. package/.mocharc.yml +0 -8
  50. package/CHANGELOG.md +0 -743
@@ -0,0 +1,2 @@
1
+ import 'should';
2
+ //# sourceMappingURL=hbarToken.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=keyPair.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=transaction.d.ts.map
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90ZXN0L3VuaXQvdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxvREFBNEI7QUFDNUIsb0RBQTRCO0FBQzVCLGlEQUE0QztBQUM1QyxtQ0FBaUQ7QUFDakQsNERBQThDO0FBRTlDLFFBQVEsQ0FBQyxrQkFBa0IsRUFBRSxHQUFHLEVBQUU7SUFDaEMsTUFBTSxJQUFJLEdBQUcsZUFBSyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUVoQzs7T0FFRztJQUNILFNBQVMsY0FBYztRQUNyQixPQUFPLElBQUksaUJBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBRUQsRUFBRSxDQUFDLGdDQUFnQyxFQUFFLEdBQUcsRUFBRTtRQUN4QyxNQUFNLEVBQUUsR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUM1QixnQkFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDakIsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQUM7UUFDSCxnQkFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDakIsRUFBRSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQywrQkFBK0IsRUFBRSxHQUFHLEVBQUU7UUFDN0MsRUFBRSxDQUFDLFNBQVMsRUFBRTtZQUNaLE1BQU0sRUFBRSxHQUFHLGNBQWMsRUFBRSxDQUFDO1lBQzVCLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3BFLENBQUMsQ0FBQyxDQUFDO1FBRUgsRUFBRSxDQUFDLE9B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Q0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ3BDLGdCQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLFFBQVEsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBQzNFLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcbmltcG9ydCBzaG91bGQgZnJvbSAnc2hvdWxkJztcbmltcG9ydCB7IGNvaW5zIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgeyBLZXlQYWlyLCBUcmFuc2FjdGlvbiB9IGZyb20gJy4uLy4uL3NyYyc7XG5pbXBvcnQgKiBhcyB0ZXN0RGF0YSBmcm9tICcuLi9yZXNvdXJjZXMvaGJhcic7XG5cbmRlc2NyaWJlKCdIYmFyIFRyYW5zYWN0aW9uJywgKCkgPT4ge1xuICBjb25zdCBjb2luID0gY29pbnMuZ2V0KCd0aGJhcicpO1xuXG4gIC8qKlxuICAgKlxuICAgKi9cbiAgZnVuY3Rpb24gZ2V0VHJhbnNhY3Rpb24oKTogVHJhbnNhY3Rpb24ge1xuICAgIHJldHVybiBuZXcgVHJhbnNhY3Rpb24oY29pbik7XG4gIH1cblxuICBpdCgnc2hvdWxkIHRocm93IGVtcHR5IHRyYW5zYWN0aW9uJywgKCkgPT4ge1xuICAgIGNvbnN0IHR4ID0gZ2V0VHJhbnNhY3Rpb24oKTtcbiAgICBhc3NlcnQudGhyb3dzKCgpID0+IHtcbiAgICAgIHR4LnRvSnNvbigpO1xuICAgIH0pO1xuICAgIGFzc2VydC50aHJvd3MoKCkgPT4ge1xuICAgICAgdHgudG9Ccm9hZGNhc3RGb3JtYXQoKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3Nob3VsZCBzaWduIGlmIHRyYW5zYWN0aW9uIGlzJywgKCkgPT4ge1xuICAgIGl0KCdpbnZhbGlkJywgZnVuY3Rpb24gKCkge1xuICAgICAgY29uc3QgdHggPSBnZXRUcmFuc2FjdGlvbigpO1xuICAgICAgcmV0dXJuIHR4LnNpZ24odGVzdERhdGEuSU5WQUxJRF9LRVlQQUlSX1BSVikuc2hvdWxkLmJlLnJlamVjdGVkKCk7XG4gICAgfSk7XG5cbiAgICBpdCgndmFsaWQnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCB0eCA9IGdldFRyYW5zYWN0aW9uKCk7XG4gICAgICB0eC5ib2R5Qnl0ZXModGVzdERhdGEuV0FMTEVUX1RYREFUQSk7XG4gICAgICBjb25zdCBrZXlwYWlyID0gbmV3IEtleVBhaXIoeyBwcnY6IHRlc3REYXRhLkFDQ09VTlRfMS5wcnZLZXlXaXRoUHJlZml4IH0pO1xuICAgICAgYXdhaXQgdHguc2lnbihrZXlwYWlyKS5zaG91bGQuYmUuZnVsZmlsbGVkKCk7XG4gICAgICBzaG91bGQuZXF1YWwoXG4gICAgICAgIEJ1ZmZlci5mcm9tKHR4LmhlZGVyYVR4LnNpZ01hcCEuc2lnUGFpciFbMF0ucHViS2V5UHJlZml4ISkudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgICB0ZXN0RGF0YS5BQ0NPVU5UXzEucHViS2V5V2l0aFByZWZpeC5zbGljZSgyNClcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICBpdCgnbXVsdGlwbGUgdmFsaWQnLCBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCB0eCA9IGdldFRyYW5zYWN0aW9uKCk7XG4gICAgICB0eC5ib2R5Qnl0ZXModGVzdERhdGEuV0FMTEVUX1RYREFUQSk7XG4gICAgICBjb25zdCBrZXlwYWlyID0gbmV3IEtleVBhaXIoeyBwcnY6IHRlc3REYXRhLkFDQ09VTlRfMS5wcnZLZXlXaXRoUHJlZml4IH0pO1xuICAgICAgY29uc3Qga2V5cGFpcjIgPSBuZXcgS2V5UGFpcih7IHBydjogdGVzdERhdGEuT1BFUkFUT1IucHJpdmF0ZUtleSB9KTtcbiAgICAgIGF3YWl0IHR4LnNpZ24oa2V5cGFpcikuc2hvdWxkLmJlLmZ1bGZpbGxlZCgpO1xuICAgICAgc2hvdWxkLmVxdWFsKFxuICAgICAgICBCdWZmZXIuZnJvbSh0eC5oZWRlcmFUeC5zaWdNYXAhLnNpZ1BhaXIhWzBdLnB1YktleVByZWZpeCEpLnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgdGVzdERhdGEuQUNDT1VOVF8xLnB1YktleVdpdGhQcmVmaXguc2xpY2UoMjQpXG4gICAgICApO1xuICAgICAgYXdhaXQgdHguc2lnbihrZXlwYWlyMikuc2hvdWxkLmJlLmZ1bGZpbGxlZCgpO1xuICAgICAgc2hvdWxkLmVxdWFsKFxuICAgICAgICBCdWZmZXIuZnJvbSh0eC5oZWRlcmFUeC5zaWdNYXAhLnNpZ1BhaXIhWzBdLnB1YktleVByZWZpeCEpLnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgdGVzdERhdGEuQUNDT1VOVF8xLnB1YktleVdpdGhQcmVmaXguc2xpY2UoMjQpXG4gICAgICApO1xuICAgICAgc2hvdWxkLmVxdWFsKFxuICAgICAgICBCdWZmZXIuZnJvbSh0eC5oZWRlcmFUeC5zaWdNYXAhLnNpZ1BhaXIhWzFdLnB1YktleVByZWZpeCEpLnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgdGVzdERhdGEuT1BFUkFUT1IucHVibGljS2V5LnNsaWNlKDI0KVxuICAgICAgKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3Nob3VsZCByZXR1cm4gZW5jb2RlZCB0eCcsIGZ1bmN0aW9uICgpIHtcbiAgICBpdCgndmFsaWQgc2lnbicsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICAgIGNvbnN0IHR4ID0gZ2V0VHJhbnNhY3Rpb24oKTtcbiAgICAgIHR4LmJvZHlCeXRlcyh0ZXN0RGF0YS5XQUxMRVRfVFhEQVRBKTtcbiAgICAgIGF3YWl0IHR4LnNpZ24odGVzdERhdGEuS0VZUEFJUl9QUlYpO1xuICAgICAgc2hvdWxkLmVxdWFsKHR4LnRvQnJvYWRjYXN0Rm9ybWF0KCksIHRlc3REYXRhLldBTExFVF9TSUdORURfVFJBTlNBQ1RJT04pO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tokenAssociateBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tokenAssociateBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/transactionBuilder/tokenAssociateBuilder.ts"],"names":[],"mappings":""}