@bitgo-beta/sdk-coin-polyx 1.0.1-beta.68 → 1.0.1-beta.680

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 (150) hide show
  1. package/dist/src/index.d.ts +1 -0
  2. package/dist/src/index.d.ts.map +1 -1
  3. package/dist/src/index.js +2 -1
  4. package/dist/src/lib/baseBuilder.d.ts +24 -0
  5. package/dist/src/lib/baseBuilder.d.ts.map +1 -0
  6. package/dist/src/lib/baseBuilder.js +31 -0
  7. package/dist/src/lib/batchStakingBuilder.d.ts +79 -0
  8. package/dist/src/lib/batchStakingBuilder.d.ts.map +1 -0
  9. package/dist/src/lib/batchStakingBuilder.js +299 -0
  10. package/dist/src/lib/batchUnstakingBuilder.d.ts +39 -0
  11. package/dist/src/lib/batchUnstakingBuilder.d.ts.map +1 -0
  12. package/dist/src/lib/batchUnstakingBuilder.js +127 -0
  13. package/dist/src/lib/bondExtraBuilder.d.ts +37 -0
  14. package/dist/src/lib/bondExtraBuilder.d.ts.map +1 -0
  15. package/dist/src/lib/bondExtraBuilder.js +101 -0
  16. package/dist/src/lib/constants.d.ts +12 -0
  17. package/dist/src/lib/constants.d.ts.map +1 -0
  18. package/dist/src/lib/constants.js +15 -0
  19. package/dist/src/lib/iface.d.ts +140 -2
  20. package/dist/src/lib/iface.d.ts.map +1 -1
  21. package/dist/src/lib/iface.js +37 -1
  22. package/dist/src/lib/index.d.ts +16 -7
  23. package/dist/src/lib/index.d.ts.map +1 -1
  24. package/dist/src/lib/index.js +44 -36
  25. package/dist/src/lib/preApproveAssetBuilder.d.ts +33 -0
  26. package/dist/src/lib/preApproveAssetBuilder.d.ts.map +1 -0
  27. package/dist/src/lib/preApproveAssetBuilder.js +77 -0
  28. package/dist/src/lib/registerDidWithCDDBuilder.d.ts +34 -0
  29. package/dist/src/lib/registerDidWithCDDBuilder.d.ts.map +1 -0
  30. package/dist/src/lib/registerDidWithCDDBuilder.js +83 -0
  31. package/dist/src/lib/rejectInstructionBuilder.d.ts +29 -0
  32. package/dist/src/lib/rejectInstructionBuilder.d.ts.map +1 -0
  33. package/dist/src/lib/rejectInstructionBuilder.js +89 -0
  34. package/dist/src/lib/tokenTransferBuilder.d.ts +58 -0
  35. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -0
  36. package/dist/src/lib/tokenTransferBuilder.js +158 -0
  37. package/dist/src/lib/transaction.d.ts +26 -4
  38. package/dist/src/lib/transaction.d.ts.map +1 -1
  39. package/dist/src/lib/transaction.js +183 -7
  40. package/dist/src/lib/transactionBuilderFactory.d.ts +29 -5
  41. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  42. package/dist/src/lib/transactionBuilderFactory.js +119 -8
  43. package/dist/src/lib/transferBuilder.d.ts +51 -3
  44. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  45. package/dist/src/lib/transferBuilder.js +109 -3
  46. package/dist/src/lib/txnSchema.d.ts +50 -0
  47. package/dist/src/lib/txnSchema.d.ts.map +1 -0
  48. package/dist/src/lib/txnSchema.js +165 -0
  49. package/dist/src/lib/unbondBuilder.d.ts +37 -0
  50. package/dist/src/lib/unbondBuilder.d.ts.map +1 -0
  51. package/dist/src/lib/unbondBuilder.js +98 -0
  52. package/dist/src/lib/utils.d.ts +15 -14
  53. package/dist/src/lib/utils.d.ts.map +1 -1
  54. package/dist/src/lib/utils.js +40 -23
  55. package/dist/src/lib/withdrawUnbondedBuilder.d.ts +35 -0
  56. package/dist/src/lib/withdrawUnbondedBuilder.d.ts.map +1 -0
  57. package/dist/src/lib/withdrawUnbondedBuilder.js +89 -0
  58. package/dist/src/polyx.d.ts +50 -9
  59. package/dist/src/polyx.d.ts.map +1 -1
  60. package/dist/src/polyx.js +269 -15
  61. package/dist/src/polyxToken.d.ts +20 -0
  62. package/dist/src/polyxToken.d.ts.map +1 -0
  63. package/dist/src/polyxToken.js +55 -0
  64. package/dist/src/register.d.ts.map +1 -1
  65. package/dist/src/register.js +5 -1
  66. package/dist/src/resources/index.d.ts +3 -0
  67. package/dist/src/resources/index.d.ts.map +1 -0
  68. package/dist/src/resources/index.js +19 -0
  69. package/dist/src/resources/mainnet.d.ts +13 -0
  70. package/dist/src/resources/mainnet.d.ts.map +1 -0
  71. package/dist/src/resources/mainnet.js +16 -0
  72. package/dist/src/resources/testnet.d.ts +13 -0
  73. package/dist/src/resources/testnet.d.ts.map +1 -0
  74. package/dist/src/resources/testnet.js +16 -0
  75. package/dist/src/tpolyx.d.ts +7 -0
  76. package/dist/src/tpolyx.d.ts.map +1 -1
  77. package/dist/src/tpolyx.js +11 -1
  78. package/dist/test/integration/index.d.ts +1 -0
  79. package/dist/test/integration/index.d.ts.map +1 -0
  80. package/dist/test/integration/index.js +1 -0
  81. package/dist/test/resources/index.d.ts +106 -0
  82. package/dist/test/resources/index.d.ts.map +1 -0
  83. package/dist/test/resources/index.js +112 -0
  84. package/dist/test/resources/mainnet.d.ts +2 -0
  85. package/dist/test/resources/mainnet.d.ts.map +1 -0
  86. package/dist/test/resources/mainnet.js +5 -0
  87. package/dist/test/resources/materialData.json +8 -0
  88. package/dist/test/resources/materialDataModified.json +8 -0
  89. package/dist/test/resources/testnet.d.ts +2 -0
  90. package/dist/test/resources/testnet.d.ts.map +1 -0
  91. package/dist/test/resources/testnet.js +5 -0
  92. package/dist/test/resources/wrwUsers.d.ts +19 -0
  93. package/dist/test/resources/wrwUsers.d.ts.map +1 -0
  94. package/dist/test/resources/wrwUsers.js +60 -0
  95. package/dist/test/unit/polyx.d.ts +2 -0
  96. package/dist/test/unit/polyx.d.ts.map +1 -0
  97. package/dist/test/unit/polyx.js +209 -0
  98. package/dist/test/unit/transactionBuilder/base.d.ts +4 -0
  99. package/dist/test/unit/transactionBuilder/base.d.ts.map +1 -0
  100. package/dist/test/unit/transactionBuilder/base.js +245 -0
  101. package/dist/test/unit/transactionBuilder/batchStakingBuilder.d.ts +2 -0
  102. package/dist/test/unit/transactionBuilder/batchStakingBuilder.d.ts.map +1 -0
  103. package/dist/test/unit/transactionBuilder/batchStakingBuilder.js +263 -0
  104. package/dist/test/unit/transactionBuilder/batchUnstakingBuilder.d.ts +2 -0
  105. package/dist/test/unit/transactionBuilder/batchUnstakingBuilder.d.ts.map +1 -0
  106. package/dist/test/unit/transactionBuilder/batchUnstakingBuilder.js +159 -0
  107. package/dist/test/unit/transactionBuilder/bondExtraBuilder.d.ts +2 -0
  108. package/dist/test/unit/transactionBuilder/bondExtraBuilder.d.ts.map +1 -0
  109. package/dist/test/unit/transactionBuilder/bondExtraBuilder.js +158 -0
  110. package/dist/test/unit/transactionBuilder/preApproveAssetBuilder.d.ts +2 -0
  111. package/dist/test/unit/transactionBuilder/preApproveAssetBuilder.d.ts.map +1 -0
  112. package/dist/test/unit/transactionBuilder/preApproveAssetBuilder.js +115 -0
  113. package/dist/test/unit/transactionBuilder/registerDidWithCDDBuilder.d.ts +2 -0
  114. package/dist/test/unit/transactionBuilder/registerDidWithCDDBuilder.d.ts.map +1 -0
  115. package/dist/test/unit/transactionBuilder/registerDidWithCDDBuilder.js +302 -0
  116. package/dist/test/unit/transactionBuilder/rejectInstructionBuilder.d.ts +2 -0
  117. package/dist/test/unit/transactionBuilder/rejectInstructionBuilder.d.ts.map +1 -0
  118. package/dist/test/unit/transactionBuilder/rejectInstructionBuilder.js +128 -0
  119. package/dist/test/unit/transactionBuilder/singletonRegistry.d.ts +2 -0
  120. package/dist/test/unit/transactionBuilder/singletonRegistry.d.ts.map +1 -0
  121. package/dist/test/unit/transactionBuilder/singletonRegistry.js +59 -0
  122. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts +2 -0
  123. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
  124. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +140 -0
  125. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts +2 -0
  126. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts.map +1 -0
  127. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +74 -0
  128. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
  129. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  130. package/dist/test/unit/transactionBuilder/transferBuilder.js +326 -0
  131. package/dist/test/unit/transactionBuilder/unbondBuilder.d.ts +2 -0
  132. package/dist/test/unit/transactionBuilder/unbondBuilder.d.ts.map +1 -0
  133. package/dist/test/unit/transactionBuilder/unbondBuilder.js +144 -0
  134. package/dist/test/unit/transactionBuilder/withdrawUnbondedBuilder.d.ts +2 -0
  135. package/dist/test/unit/transactionBuilder/withdrawUnbondedBuilder.d.ts.map +1 -0
  136. package/dist/test/unit/transactionBuilder/withdrawUnbondedBuilder.js +138 -0
  137. package/dist/test/unit/utils.d.ts +2 -0
  138. package/dist/test/unit/utils.d.ts.map +1 -0
  139. package/dist/test/unit/utils.js +143 -0
  140. package/dist/tsconfig.tsbuildinfo +1 -0
  141. package/package.json +19 -10
  142. package/.eslintignore +0 -4
  143. package/.mocharc.yml +0 -8
  144. package/CHANGELOG.md +0 -16
  145. package/dist/src/lib/keyPair.d.ts +0 -12
  146. package/dist/src/lib/keyPair.d.ts.map +0 -1
  147. package/dist/src/lib/keyPair.js +0 -24
  148. package/dist/src/lib/transactionBuilder.d.ts +0 -43
  149. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  150. package/dist/src/lib/transactionBuilder.js +0 -78
@@ -0,0 +1,245 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.buildMainnetConfig = exports.buildTestConfig = void 0;
7
+ const sinon_1 = __importDefault(require("sinon"));
8
+ const assert_1 = __importDefault(require("assert"));
9
+ const should_1 = __importDefault(require("should"));
10
+ const statics_1 = require("@bitgo-beta/statics");
11
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
12
+ const lib_1 = require("../../../src/lib");
13
+ const src_1 = require("../../../src/");
14
+ const resources_1 = require("../../resources");
15
+ const resources_2 = require("../../../src/resources");
16
+ const buildTestConfig = () => {
17
+ return statics_1.coins.get('tpolyx');
18
+ };
19
+ exports.buildTestConfig = buildTestConfig;
20
+ const buildMainnetConfig = () => {
21
+ return statics_1.coins.get('polyx');
22
+ };
23
+ exports.buildMainnetConfig = buildMainnetConfig;
24
+ class StubTransactionBuilder extends lib_1.TransactionBuilder {
25
+ constructor(_coinConfig) {
26
+ super(_coinConfig);
27
+ this.material(src_1.utils.getMaterial(_coinConfig.network.type));
28
+ }
29
+ validateDecodedTransaction(decodedTxn) {
30
+ return;
31
+ }
32
+ buildTransaction() {
33
+ throw new Error('Method not implemented.');
34
+ }
35
+ getSender() {
36
+ return this._sender;
37
+ }
38
+ getReferenceBlock() {
39
+ return this._referenceBlock;
40
+ }
41
+ getNonce() {
42
+ return this._nonce;
43
+ }
44
+ getTip() {
45
+ return this._tip;
46
+ }
47
+ getEraPeriod() {
48
+ return this._eraPeriod;
49
+ }
50
+ buildImplementation() {
51
+ return super.buildImplementation();
52
+ }
53
+ fromImplementation(rawTransaction) {
54
+ return super.fromImplementation(rawTransaction);
55
+ }
56
+ signImplementation(key) {
57
+ return super.signImplementation(key);
58
+ }
59
+ get transactionType() {
60
+ throw new Error('Method not implemented.');
61
+ }
62
+ getTransaction() {
63
+ return this._transaction;
64
+ }
65
+ getMaterial() {
66
+ return this._material;
67
+ }
68
+ }
69
+ describe('Polyx Transfer Builder Base', () => {
70
+ let builder;
71
+ const sender = resources_1.accounts.account1;
72
+ const receiver = resources_1.accounts.account2;
73
+ beforeEach(() => {
74
+ builder = new StubTransactionBuilder((0, exports.buildTestConfig)());
75
+ });
76
+ describe('setter validation', () => {
77
+ it('should validate sender address', () => {
78
+ const spy = sinon_1.default.spy(builder, 'validateAddress');
79
+ assert_1.default.throws(() => builder.sender({ address: 'asd' }), (e) => e.message === `The address 'asd' is not a well-formed dot address`);
80
+ should_1.default.doesNotThrow(() => builder.sender({ address: sender.address }));
81
+ sinon_1.default.assert.calledTwice(spy);
82
+ });
83
+ it('should validate eraPeriod', () => {
84
+ const spy = sinon_1.default.spy(builder, 'validateValue');
85
+ assert_1.default.throws(() => builder.validity({ maxDuration: -1 }), (e) => e.message === 'Value cannot be less than zero');
86
+ should_1.default.doesNotThrow(() => builder.validity({ maxDuration: 64 }));
87
+ sinon_1.default.assert.calledTwice(spy);
88
+ });
89
+ it('should validate nonce', () => {
90
+ const spy = sinon_1.default.spy(builder, 'validateValue');
91
+ assert_1.default.throws(() => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: -1 }), (e) => e.message === 'Value cannot be less than zero');
92
+ should_1.default.doesNotThrow(() => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: 10 }));
93
+ sinon_1.default.assert.calledTwice(spy);
94
+ });
95
+ it('should validate tip', () => {
96
+ const spy = sinon_1.default.spy(builder, 'validateValue');
97
+ assert_1.default.throws(() => builder.fee({ amount: -1, type: 'tip' }), (e) => e.message === 'Value cannot be less than zero');
98
+ should_1.default.doesNotThrow(() => builder.fee({ amount: 10, type: 'tip' }));
99
+ sinon_1.default.assert.calledTwice(spy);
100
+ });
101
+ it('should validate blockNumber', () => {
102
+ const spy = sinon_1.default.spy(builder, 'validateValue');
103
+ assert_1.default.throws(() => builder.validity({ firstValid: -1 }), (e) => e.message === 'Value cannot be less than zero');
104
+ should_1.default.doesNotThrow(() => builder.validity({ firstValid: 10 }));
105
+ sinon_1.default.assert.calledTwice(spy);
106
+ });
107
+ });
108
+ describe('build base transaction', () => {
109
+ it('should build validate base fields', async () => {
110
+ builder
111
+ .material(src_1.utils.getMaterial((0, exports.buildTestConfig)().network.type))
112
+ .sender({ address: sender.address })
113
+ .validity({ firstValid: 3933, maxDuration: 64 })
114
+ .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
115
+ .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
116
+ .fee({ amount: 0, type: 'tip' });
117
+ should_1.default.doesNotThrow(() => builder.validateTransaction(builder.getTransaction()));
118
+ });
119
+ it('should build a base transaction on testnet', async () => {
120
+ const material = builder.getMaterial();
121
+ should_1.default.deepEqual(material.specName, resources_2.testnetMaterial.specName);
122
+ should_1.default.deepEqual(material.genesisHash, resources_2.testnetMaterial.genesisHash);
123
+ should_1.default.deepEqual(material.specVersion, resources_2.testnetMaterial.specVersion);
124
+ should_1.default.deepEqual(material.chainName, resources_2.testnetMaterial.chainName);
125
+ });
126
+ it('should build from raw signed tx', async () => {
127
+ builder.from(resources_1.rawTx.transfer.signed);
128
+ should_1.default.deepEqual(builder.getSender(), '5CLYvxwx4PUS678MNuhNJ9EfpUU9utrYCz9WVxovac4u9AYD');
129
+ should_1.default.deepEqual(builder.getNonce(), 34);
130
+ should_1.default.deepEqual(builder.getEraPeriod(), 64);
131
+ should_1.default.deepEqual(builder.getTip(), undefined);
132
+ });
133
+ it('should build from raw unsigned tx', async () => {
134
+ builder.from(resources_1.rawTx.transfer.unsigned);
135
+ should_1.default.deepEqual(builder.getReferenceBlock(), '0xe5c5396f3291d2575d138b98d34eac2fc156e5280276f57a30a8e3b8fbc49bfc');
136
+ should_1.default.deepEqual(builder.getNonce(), 36);
137
+ should_1.default.deepEqual(builder.getEraPeriod(), 64);
138
+ should_1.default.deepEqual(builder.getTip(), undefined);
139
+ });
140
+ });
141
+ describe('add TSS signature', function () {
142
+ let MPC;
143
+ before('initialize mpc module', async () => {
144
+ MPC = await sdk_core_1.Eddsa.initialize();
145
+ });
146
+ it('should add TSS signature', async () => {
147
+ const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get('tpolyx'));
148
+ const A = MPC.keyShare(1, 2, 3);
149
+ const B = MPC.keyShare(2, 2, 3);
150
+ const C = MPC.keyShare(3, 2, 3);
151
+ const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
152
+ const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
153
+ const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);
154
+ const commonPub = A_combine.pShare.y;
155
+ const dotKeyPair = new lib_1.KeyPair({ pub: commonPub });
156
+ const sender = dotKeyPair.getAddress(sdk_core_1.DotAddressFormat.substrate);
157
+ let transferBuilder = factory
158
+ .getTransferBuilder()
159
+ .amount('90034235235322')
160
+ .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
161
+ .sender({ address: sender })
162
+ .to({ address: receiver.address })
163
+ .memo('0')
164
+ .validity({ firstValid: 3933, maxDuration: 64 })
165
+ .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
166
+ .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
167
+ .fee({ amount: 0, type: 'tip' });
168
+ const unsignedTransaction = await transferBuilder.build();
169
+ const signablePayload = unsignedTransaction.signablePayload;
170
+ // signing with A and B
171
+ let A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[2]]);
172
+ let B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[1]]);
173
+ let A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);
174
+ let B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);
175
+ // sign the message_buffer (unsigned txHex)
176
+ let signature = MPC.signCombine([A_sign, B_sign]);
177
+ let rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
178
+ transferBuilder = factory
179
+ .getTransferBuilder()
180
+ .amount('90034235235322')
181
+ .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
182
+ .sender({ address: sender })
183
+ .to({ address: receiver.address })
184
+ .memo('0')
185
+ .validity({ firstValid: 3933, maxDuration: 64 })
186
+ .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
187
+ .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
188
+ .fee({ amount: 0, type: 'tip' });
189
+ transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);
190
+ let signedTransaction = await transferBuilder.build();
191
+ signedTransaction.signature.length.should.equal(1);
192
+ signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));
193
+ // signing with A and C
194
+ A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[3]]);
195
+ let C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[1]]);
196
+ A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);
197
+ let C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);
198
+ signature = MPC.signCombine([A_sign, C_sign]);
199
+ rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
200
+ transferBuilder = factory
201
+ .getTransferBuilder()
202
+ .amount('90034235235322')
203
+ .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
204
+ .sender({ address: sender })
205
+ .to({ address: receiver.address })
206
+ .memo('0')
207
+ .validity({ firstValid: 3933, maxDuration: 64 })
208
+ .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
209
+ .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
210
+ .fee({ amount: 0, type: 'tip' });
211
+ transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);
212
+ signedTransaction = await transferBuilder.build();
213
+ signedTransaction.signature.length.should.equal(1);
214
+ signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));
215
+ // signing with B and C
216
+ B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[3]]);
217
+ C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[2]]);
218
+ B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);
219
+ C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);
220
+ signature = MPC.signCombine([B_sign, C_sign]);
221
+ rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
222
+ transferBuilder = factory
223
+ .getTransferBuilder()
224
+ .amount('90034235235322')
225
+ .sender({ address: sender })
226
+ .to({ address: receiver.address })
227
+ .memo('0')
228
+ .validity({ firstValid: 3933, maxDuration: 64 })
229
+ .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
230
+ .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
231
+ .fee({ amount: 0, type: 'tip' });
232
+ transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);
233
+ signedTransaction = await transferBuilder.build();
234
+ signedTransaction.signature.length.should.equal(1);
235
+ signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));
236
+ const rebuiltTransaction = await factory
237
+ .from(signedTransaction.toBroadcastFormat())
238
+ .validity({ firstValid: 3933, maxDuration: 64 })
239
+ .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
240
+ .build();
241
+ rebuiltTransaction.signature[0].should.equal(rawSignature.toString('hex'));
242
+ });
243
+ });
244
+ });
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../test/unit/transactionBuilder/base.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAC1B,oDAA4B;AAC5B,oDAA4B;AAE5B,iDAAoE;AAEpE,mDAAyF;AAEzF,0CAAkH;AAClH,uCAAsC;AACtC,+CAAkD;AAClD,sDAAyD;AAElD,MAAM,eAAe,GAAG,GAAyB,EAAE;IACxD,OAAO,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;AAC7B,CAAC,CAAC;AAFW,QAAA,eAAe,mBAE1B;AAEK,MAAM,kBAAkB,GAAG,GAAyB,EAAE;IAC3D,OAAO,eAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAC5B,CAAC,CAAC;AAFW,QAAA,kBAAkB,sBAE7B;AAEF,MAAM,sBAAuB,SAAQ,wBAAkB;IACrD,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,WAAK,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IAC7D,CAAC;IAES,0BAA0B,CAAC,UAAmD;QACtF,OAAO;IACT,CAAC;IAES,gBAAgB;QACxB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,mBAAmB;QACjB,OAAO,KAAK,CAAC,mBAAmB,EAAE,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,cAAsB;QACvC,OAAO,KAAK,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;IAClD,CAAC;IAED,kBAAkB,CAAC,GAAY;QAC7B,OAAO,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;IACvC,CAAC;IAED,IAAc,eAAe;QAC3B,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;CACF;AAED,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;IAC3C,IAAI,OAA+B,CAAC;IAEpC,MAAM,MAAM,GAAG,oBAAQ,CAAC,QAAQ,CAAC;IACjC,MAAM,QAAQ,GAAG,oBAAQ,CAAC,QAAQ,CAAC;IAEnC,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,IAAI,sBAAsB,CAAC,IAAA,uBAAe,GAAE,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACjC,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,GAAG,GAAG,eAAK,CAAC,GAAG,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;YAClD,gBAAM,CAAC,MAAM,CACX,GAAG,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EACxC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,oDAAoD,CACjF,CAAC;YACF,gBAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YACvE,eAAK,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;YACnC,MAAM,GAAG,GAAG,eAAK,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;YAChD,gBAAM,CAAC,MAAM,CACX,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,EAC3C,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,gCAAgC,CAC7D,CAAC;YACF,gBAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YACjE,eAAK,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uBAAuB,EAAE,GAAG,EAAE;YAC/B,MAAM,GAAG,GAAG,eAAK,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;YAChD,gBAAM,CAAC,MAAM,CACX,GAAG,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EACxE,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,gCAAgC,CAC7D,CAAC;YACF,gBAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YAC9F,eAAK,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qBAAqB,EAAE,GAAG,EAAE;YAC7B,MAAM,GAAG,GAAG,eAAK,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;YAChD,gBAAM,CAAC,MAAM,CACX,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAC9C,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,gCAAgC,CAC7D,CAAC;YACF,gBAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YACpE,eAAK,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;YACrC,MAAM,GAAG,GAAG,eAAK,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;YAChD,gBAAM,CAAC,MAAM,CACX,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,EAC1C,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,gCAAgC,CAC7D,CAAC;YACF,gBAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YAChE,eAAK,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACtC,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;YACjD,OAAO;iBACJ,QAAQ,CAAC,WAAK,CAAC,WAAW,CAAC,IAAA,uBAAe,GAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;iBAC3D,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC;iBACnC,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;iBAC/C,cAAc,CAAC,oEAAoE,CAAC;iBACpF,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;iBAC3D,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YACnC,gBAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;QACnF,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;YAC1D,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;YACvC,gBAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,2BAAe,CAAC,QAAQ,CAAC,CAAC;YAC9D,gBAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,2BAAe,CAAC,WAAW,CAAC,CAAC;YACpE,gBAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,2BAAe,CAAC,WAAW,CAAC,CAAC;YACpE,gBAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,EAAE,2BAAe,CAAC,SAAS,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;YAC/C,OAAO,CAAC,IAAI,CAAC,iBAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YACpC,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,kDAAkD,CAAC,CAAC;YAC1F,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;YACzC,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,EAAE,CAAC,CAAC;YAC7C,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,SAAS,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;YACjD,OAAO,CAAC,IAAI,CAAC,iBAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACtC,gBAAM,CAAC,SAAS,CACd,OAAO,CAAC,iBAAiB,EAAE,EAC3B,oEAAoE,CACrE,CAAC;YACF,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;YACzC,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,EAAE,CAAC,CAAC;YAC7C,gBAAM,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,SAAS,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,mBAAmB,EAAE;QAC5B,IAAI,GAAU,CAAC;QACf,MAAM,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;YACzC,GAAG,GAAG,MAAM,gBAAK,CAAC,UAAU,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;YACxC,MAAM,OAAO,GAAG,IAAI,+BAAyB,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;YAEnE,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAChC,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAChC,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAEhC,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACzE,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACzE,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAEzE,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;YACrC,MAAM,UAAU,GAAG,IAAI,aAAO,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;YACnD,MAAM,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC,2BAAgB,CAAC,SAAS,CAAC,CAAC;YAEjE,IAAI,eAAe,GAAG,OAAO;iBAC1B,kBAAkB,EAAE;iBACpB,MAAM,CAAC,gBAAgB,CAAC;iBACxB,EAAE,CAAC,EAAE,OAAO,EAAE,kDAAkD,EAAE,CAAC;iBACnE,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;iBAC3B,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;iBACjC,IAAI,CAAC,GAAG,CAAC;iBACT,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;iBAC/C,cAAc,CAAC,oEAAoE,CAAC;iBACpF,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;iBAC3D,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YACnC,MAAM,mBAAmB,GAAG,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC;YAC1D,MAAM,eAAe,GAAG,mBAAmB,CAAC,eAAe,CAAC;YAE5D,uBAAuB;YACvB,IAAI,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5F,IAAI,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5F,IAAI,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvG,IAAI,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvG,2CAA2C;YAC3C,IAAI,SAAS,GAAG,GAAG,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;YAClD,IAAI,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;YACzG,eAAe,GAAG,OAAO;iBACtB,kBAAkB,EAAE;iBACpB,MAAM,CAAC,gBAAgB,CAAC;iBACxB,EAAE,CAAC,EAAE,OAAO,EAAE,kDAAkD,EAAE,CAAC;iBACnE,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;iBAC3B,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;iBACjC,IAAI,CAAC,GAAG,CAAC;iBACT,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;iBAC/C,cAAc,CAAC,oEAAoE,CAAC;iBACpF,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;iBAC3D,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YACnC,eAAe,CAAC,YAAY,CAAC,EAAE,GAAG,EAAE,UAAU,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC,CAAC;YAC9E,IAAI,iBAAiB,GAAG,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC;YACtD,iBAAiB,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACnD,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YAE1E,uBAAuB;YACvB,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACxF,IAAI,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5F,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACnG,IAAI,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvG,SAAS,GAAG,GAAG,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;YAC9C,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;YACrG,eAAe,GAAG,OAAO;iBACtB,kBAAkB,EAAE;iBACpB,MAAM,CAAC,gBAAgB,CAAC;iBACxB,EAAE,CAAC,EAAE,OAAO,EAAE,kDAAkD,EAAE,CAAC;iBACnE,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;iBAC3B,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;iBACjC,IAAI,CAAC,GAAG,CAAC;iBACT,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;iBAC/C,cAAc,CAAC,oEAAoE,CAAC;iBACpF,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;iBAC3D,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YACnC,eAAe,CAAC,YAAY,CAAC,EAAE,GAAG,EAAE,UAAU,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC,CAAC;YAC9E,iBAAiB,GAAG,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC;YAClD,iBAAiB,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACnD,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YAE1E,uBAAuB;YACvB,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACxF,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACxF,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACnG,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACnG,SAAS,GAAG,GAAG,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;YAC9C,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;YACrG,eAAe,GAAG,OAAO;iBACtB,kBAAkB,EAAE;iBACpB,MAAM,CAAC,gBAAgB,CAAC;iBACxB,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;iBAC3B,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;iBACjC,IAAI,CAAC,GAAG,CAAC;iBACT,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;iBAC/C,cAAc,CAAC,oEAAoE,CAAC;iBACpF,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;iBAC3D,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YACnC,eAAe,CAAC,YAAY,CAAC,EAAE,GAAG,EAAE,UAAU,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC,CAAC;YAC9E,iBAAiB,GAAG,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC;YAClD,iBAAiB,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACnD,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YAE1E,MAAM,kBAAkB,GAAG,MAAM,OAAO;iBACrC,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,EAAE,CAAC;iBAC3C,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;iBAC/C,cAAc,CAAC,oEAAoE,CAAC;iBACpF,KAAK,EAAE,CAAC;YAEX,kBAAkB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC7E,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import sinon from 'sinon';\nimport assert from 'assert';\nimport should from 'should';\n\nimport { BaseCoin as CoinConfig, coins } from '@bitgo-beta/statics';\nimport { DecodedSignedTx, DecodedSigningPayload, UnsignedTransaction } from '@substrate/txwrapper-core';\nimport { BaseKey, DotAddressFormat, Eddsa, TransactionType } from '@bitgo-beta/sdk-core';\n\nimport { Interface, KeyPair, Transaction, TransactionBuilder, TransactionBuilderFactory } from '../../../src/lib';\nimport { utils } from '../../../src/';\nimport { accounts, rawTx } from '../../resources';\nimport { testnetMaterial } from '../../../src/resources';\n\nexport const buildTestConfig = (): Readonly<CoinConfig> => {\n  return coins.get('tpolyx');\n};\n\nexport const buildMainnetConfig = (): Readonly<CoinConfig> => {\n  return coins.get('polyx');\n};\n\nclass StubTransactionBuilder extends TransactionBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this.material(utils.getMaterial(_coinConfig.network.type));\n  }\n\n  protected validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void {\n    return;\n  }\n\n  protected buildTransaction(): UnsignedTransaction {\n    throw new Error('Method not implemented.');\n  }\n\n  getSender(): string {\n    return this._sender;\n  }\n\n  getReferenceBlock(): string {\n    return this._referenceBlock;\n  }\n\n  getNonce(): number {\n    return this._nonce;\n  }\n\n  getTip(): number | undefined {\n    return this._tip;\n  }\n\n  getEraPeriod(): number | undefined {\n    return this._eraPeriod;\n  }\n\n  buildImplementation(): Promise<Transaction> {\n    return super.buildImplementation();\n  }\n\n  fromImplementation(rawTransaction: string): Transaction {\n    return super.fromImplementation(rawTransaction);\n  }\n\n  signImplementation(key: BaseKey): Transaction {\n    return super.signImplementation(key);\n  }\n\n  protected get transactionType(): TransactionType {\n    throw new Error('Method not implemented.');\n  }\n\n  getTransaction(): Transaction {\n    return this._transaction;\n  }\n\n  getMaterial(): Interface.Material {\n    return this._material;\n  }\n}\n\ndescribe('Polyx Transfer Builder Base', () => {\n  let builder: StubTransactionBuilder;\n\n  const sender = accounts.account1;\n  const receiver = accounts.account2;\n\n  beforeEach(() => {\n    builder = new StubTransactionBuilder(buildTestConfig());\n  });\n\n  describe('setter validation', () => {\n    it('should validate sender address', () => {\n      const spy = sinon.spy(builder, 'validateAddress');\n      assert.throws(\n        () => builder.sender({ address: 'asd' }),\n        (e: Error) => e.message === `The address 'asd' is not a well-formed dot address`\n      );\n      should.doesNotThrow(() => builder.sender({ address: sender.address }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate eraPeriod', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.validity({ maxDuration: -1 }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.validity({ maxDuration: 64 }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate nonce', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: -1 }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: 10 }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate tip', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.fee({ amount: -1, type: 'tip' }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.fee({ amount: 10, type: 'tip' }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate blockNumber', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.validity({ firstValid: -1 }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.validity({ firstValid: 10 }));\n      sinon.assert.calledTwice(spy);\n    });\n  });\n\n  describe('build base transaction', () => {\n    it('should build validate base fields', async () => {\n      builder\n        .material(utils.getMaterial(buildTestConfig().network.type))\n        .sender({ address: sender.address })\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      should.doesNotThrow(() => builder.validateTransaction(builder.getTransaction()));\n    });\n\n    it('should build a base transaction on testnet', async () => {\n      const material = builder.getMaterial();\n      should.deepEqual(material.specName, testnetMaterial.specName);\n      should.deepEqual(material.genesisHash, testnetMaterial.genesisHash);\n      should.deepEqual(material.specVersion, testnetMaterial.specVersion);\n      should.deepEqual(material.chainName, testnetMaterial.chainName);\n    });\n\n    it('should build from raw signed tx', async () => {\n      builder.from(rawTx.transfer.signed);\n      should.deepEqual(builder.getSender(), '5CLYvxwx4PUS678MNuhNJ9EfpUU9utrYCz9WVxovac4u9AYD');\n      should.deepEqual(builder.getNonce(), 34);\n      should.deepEqual(builder.getEraPeriod(), 64);\n      should.deepEqual(builder.getTip(), undefined);\n    });\n\n    it('should build from raw unsigned tx', async () => {\n      builder.from(rawTx.transfer.unsigned);\n      should.deepEqual(\n        builder.getReferenceBlock(),\n        '0xe5c5396f3291d2575d138b98d34eac2fc156e5280276f57a30a8e3b8fbc49bfc'\n      );\n      should.deepEqual(builder.getNonce(), 36);\n      should.deepEqual(builder.getEraPeriod(), 64);\n      should.deepEqual(builder.getTip(), undefined);\n    });\n  });\n\n  describe('add TSS signature', function () {\n    let MPC: Eddsa;\n    before('initialize mpc module', async () => {\n      MPC = await Eddsa.initialize();\n    });\n    it('should add TSS signature', async () => {\n      const factory = new TransactionBuilderFactory(coins.get('tpolyx'));\n\n      const A = MPC.keyShare(1, 2, 3);\n      const B = MPC.keyShare(2, 2, 3);\n      const C = MPC.keyShare(3, 2, 3);\n\n      const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n      const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n      const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);\n\n      const commonPub = A_combine.pShare.y;\n      const dotKeyPair = new KeyPair({ pub: commonPub });\n      const sender = dotKeyPair.getAddress(DotAddressFormat.substrate);\n\n      let transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .memo('0')\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      const unsignedTransaction = await transferBuilder.build();\n      const signablePayload = unsignedTransaction.signablePayload;\n\n      // signing with A and B\n      let A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[2]]);\n      let B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[1]]);\n      let A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);\n      let B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);\n      // sign the message_buffer (unsigned txHex)\n      let signature = MPC.signCombine([A_sign, B_sign]);\n      let rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .memo('0')\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);\n      let signedTransaction = await transferBuilder.build();\n      signedTransaction.signature.length.should.equal(1);\n      signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n\n      // signing with A and C\n      A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[3]]);\n      let C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[1]]);\n      A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);\n      let C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);\n      signature = MPC.signCombine([A_sign, C_sign]);\n      rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .memo('0')\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);\n      signedTransaction = await transferBuilder.build();\n      signedTransaction.signature.length.should.equal(1);\n      signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n\n      // signing with B and C\n      B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[3]]);\n      C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[2]]);\n      B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);\n      C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);\n      signature = MPC.signCombine([B_sign, C_sign]);\n      rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .memo('0')\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);\n      signedTransaction = await transferBuilder.build();\n      signedTransaction.signature.length.should.equal(1);\n      signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n\n      const rebuiltTransaction = await factory\n        .from(signedTransaction.toBroadcastFormat())\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .build();\n\n      rebuiltTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n    });\n  });\n});\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=batchStakingBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batchStakingBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/transactionBuilder/batchStakingBuilder.ts"],"names":[],"mappings":""}