@bitgo-beta/sdk-coin-flrp 1.0.1-beta.4 → 1.0.1-beta.400

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 (115) hide show
  1. package/dist/src/flrp.d.ts +75 -61
  2. package/dist/src/flrp.d.ts.map +1 -1
  3. package/dist/src/flrp.js +276 -134
  4. package/dist/src/index.d.ts +0 -1
  5. package/dist/src/index.d.ts.map +1 -1
  6. package/dist/src/index.js +1 -2
  7. package/dist/src/lib/ExportInCTxBuilder.d.ts +43 -0
  8. package/dist/src/lib/ExportInCTxBuilder.d.ts.map +1 -0
  9. package/dist/src/lib/ExportInCTxBuilder.js +150 -0
  10. package/dist/src/lib/ExportInPTxBuilder.d.ts +28 -0
  11. package/dist/src/lib/ExportInPTxBuilder.d.ts.map +1 -0
  12. package/dist/src/lib/ExportInPTxBuilder.js +174 -0
  13. package/dist/src/lib/ImportInCTxBuilder.d.ts +34 -0
  14. package/dist/src/lib/ImportInCTxBuilder.d.ts.map +1 -0
  15. package/dist/src/lib/ImportInCTxBuilder.js +175 -0
  16. package/dist/src/lib/ImportInPTxBuilder.d.ts +38 -0
  17. package/dist/src/lib/ImportInPTxBuilder.d.ts.map +1 -0
  18. package/dist/src/lib/ImportInPTxBuilder.js +208 -0
  19. package/dist/src/lib/atomicInCTransactionBuilder.d.ts +12 -16
  20. package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +1 -1
  21. package/dist/src/lib/atomicInCTransactionBuilder.js +30 -41
  22. package/dist/src/lib/atomicTransactionBuilder.d.ts +112 -35
  23. package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
  24. package/dist/src/lib/atomicTransactionBuilder.js +244 -34
  25. package/dist/src/lib/iface.d.ts +81 -22
  26. package/dist/src/lib/iface.d.ts.map +1 -1
  27. package/dist/src/lib/iface.js +20 -14
  28. package/dist/src/lib/index.d.ts +7 -0
  29. package/dist/src/lib/index.d.ts.map +1 -1
  30. package/dist/src/lib/index.js +16 -2
  31. package/dist/src/lib/keyPair.d.ts +5 -5
  32. package/dist/src/lib/keyPair.d.ts.map +1 -1
  33. package/dist/src/lib/keyPair.js +15 -9
  34. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +41 -0
  35. package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -0
  36. package/dist/src/lib/permissionlessValidatorTxBuilder.js +126 -0
  37. package/dist/src/lib/transaction.d.ts +75 -0
  38. package/dist/src/lib/transaction.d.ts.map +1 -0
  39. package/dist/src/lib/transaction.js +460 -0
  40. package/dist/src/lib/transactionBuilder.d.ts +115 -0
  41. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  42. package/dist/src/lib/transactionBuilder.js +228 -0
  43. package/dist/src/lib/transactionBuilderFactory.d.ts +57 -0
  44. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -0
  45. package/dist/src/lib/transactionBuilderFactory.js +148 -0
  46. package/dist/src/lib/utils.d.ts +138 -102
  47. package/dist/src/lib/utils.d.ts.map +1 -1
  48. package/dist/src/lib/utils.js +359 -245
  49. package/dist/test/resources/account.d.ts +81 -0
  50. package/dist/test/resources/account.d.ts.map +1 -0
  51. package/dist/test/resources/account.js +79 -0
  52. package/dist/test/resources/transactionData/exportInC.d.ts +50 -0
  53. package/dist/test/resources/transactionData/exportInC.d.ts.map +1 -0
  54. package/dist/test/resources/transactionData/exportInC.js +58 -0
  55. package/dist/test/resources/transactionData/exportInP.d.ts +60 -0
  56. package/dist/test/resources/transactionData/exportInP.d.ts.map +1 -0
  57. package/dist/test/resources/transactionData/exportInP.js +101 -0
  58. package/dist/test/resources/transactionData/importInC.d.ts +56 -0
  59. package/dist/test/resources/transactionData/importInC.d.ts.map +1 -0
  60. package/dist/test/resources/transactionData/importInC.js +120 -0
  61. package/dist/test/resources/transactionData/importInP.d.ts +66 -0
  62. package/dist/test/resources/transactionData/importInP.d.ts.map +1 -0
  63. package/dist/test/resources/transactionData/importInP.js +84 -0
  64. package/dist/test/unit/flrp.js +490 -20
  65. package/dist/test/unit/lib/exportInCTxBuilder.d.ts +2 -0
  66. package/dist/test/unit/lib/exportInCTxBuilder.d.ts.map +1 -0
  67. package/dist/test/unit/lib/exportInCTxBuilder.js +193 -0
  68. package/dist/test/unit/lib/exportInPTxBuilder.d.ts +2 -0
  69. package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +1 -0
  70. package/dist/test/unit/lib/exportInPTxBuilder.js +296 -0
  71. package/dist/test/unit/lib/importInCTxBuilder.d.ts +2 -0
  72. package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +1 -0
  73. package/dist/test/unit/lib/importInCTxBuilder.js +309 -0
  74. package/dist/test/unit/lib/importInPTxBuilder.d.ts +2 -0
  75. package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +1 -0
  76. package/dist/test/unit/lib/importInPTxBuilder.js +490 -0
  77. package/dist/test/unit/lib/keyPair.d.ts +2 -0
  78. package/dist/test/unit/lib/keyPair.d.ts.map +1 -0
  79. package/dist/test/unit/lib/keyPair.js +158 -0
  80. package/dist/test/unit/lib/signFlowTestSuit.d.ts +20 -0
  81. package/dist/test/unit/lib/signFlowTestSuit.d.ts.map +1 -0
  82. package/dist/test/unit/lib/signFlowTestSuit.js +83 -0
  83. package/dist/test/unit/lib/signatureIndex.d.ts +13 -0
  84. package/dist/test/unit/lib/signatureIndex.d.ts.map +1 -0
  85. package/dist/test/unit/lib/signatureIndex.js +843 -0
  86. package/dist/test/unit/lib/transactionBuilderFactory.d.ts +2 -0
  87. package/dist/test/unit/lib/transactionBuilderFactory.d.ts.map +1 -0
  88. package/dist/test/unit/lib/transactionBuilderFactory.js +60 -0
  89. package/dist/test/unit/lib/utils.d.ts +2 -0
  90. package/dist/test/unit/lib/utils.d.ts.map +1 -0
  91. package/dist/test/unit/lib/utils.js +761 -0
  92. package/dist/tsconfig.tsbuildinfo +1 -1
  93. package/package.json +18 -12
  94. package/.eslintignore +0 -5
  95. package/.eslintrc.json +0 -7
  96. package/.mocharc.yml +0 -8
  97. package/CHANGELOG.md +0 -0
  98. package/dist/src/iface.d.ts +0 -25
  99. package/dist/src/iface.d.ts.map +0 -1
  100. package/dist/src/iface.js +0 -3
  101. package/dist/src/lib/constants.d.ts +0 -11
  102. package/dist/src/lib/constants.d.ts.map +0 -1
  103. package/dist/src/lib/constants.js +0 -17
  104. package/dist/src/lib/errors.d.ts +0 -8
  105. package/dist/src/lib/errors.d.ts.map +0 -1
  106. package/dist/src/lib/errors.js +0 -19
  107. package/dist/src/lib/exportInCTxBuilder.d.ts +0 -77
  108. package/dist/src/lib/exportInCTxBuilder.d.ts.map +0 -1
  109. package/dist/src/lib/exportInCTxBuilder.js +0 -164
  110. package/dist/src/lib/exportInPTxBuilder.d.ts +0 -30
  111. package/dist/src/lib/exportInPTxBuilder.d.ts.map +0 -1
  112. package/dist/src/lib/exportInPTxBuilder.js +0 -56
  113. package/dist/test/unit/smoke.d.ts +0 -2
  114. package/dist/test/unit/smoke.d.ts.map +0 -1
  115. package/dist/test/unit/smoke.js +0 -9
package/dist/src/flrp.js CHANGED
@@ -1,7 +1,48 @@
1
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
+ };
2
38
  Object.defineProperty(exports, "__esModule", { value: true });
3
39
  exports.Flrp = void 0;
40
+ const statics_1 = require("@bitgo-beta/statics");
4
41
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
42
+ const FlrpLib = __importStar(require("./lib"));
43
+ const utils_1 = __importDefault(require("./lib/utils"));
44
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
45
+ const ethereumjs_util_1 = require("ethereumjs-util");
5
46
  class Flrp extends sdk_core_1.BaseCoin {
6
47
  constructor(bitgo, staticsCoin) {
7
48
  super(bitgo);
@@ -25,151 +66,252 @@ class Flrp extends sdk_core_1.BaseCoin {
25
66
  getBaseFactor() {
26
67
  return Math.pow(10, this._staticsCoin.decimalPlaces);
27
68
  }
28
- // TODO WIN-6321, 6322, 6318: All below methods will be implemented in coming ticket
29
- // Feature flags
30
- supportsTss() {
31
- return false;
69
+ /** inherited doc */
70
+ getDefaultMultisigType() {
71
+ return sdk_core_1.multisigTypes.onchain;
32
72
  }
33
- supportsMessageSigning() {
34
- return false;
35
- }
36
- supportsSigningTypedData() {
37
- return false;
38
- }
39
- supportsBlockTarget() {
40
- return false;
41
- }
42
- supportsLightning() {
43
- return false;
44
- }
45
- supportsBlsDkg() {
46
- return false;
47
- }
48
- isEVM() {
49
- return false;
50
- }
51
- // Conversions (placeholder)
52
- // Use BaseCoin default conversions (baseUnitsToBigUnits / bigUnitsToBaseUnits)
53
- // Key methods (stubs)
54
- generateKeyPair() {
55
- throw new Error('generateKeyPair not implemented');
56
- }
57
- generateRootKeyPair() {
58
- throw new Error('generateRootKeyPair not implemented');
59
- }
60
- keyIdsForSigning() {
61
- return [0, 1, 2];
62
- }
63
- isValidPub(_pub) {
64
- return false;
65
- }
66
- isValidAddress(_address) {
67
- return false;
68
- }
69
- isValidMofNSetup(_params) {
70
- return false;
71
- }
72
- canonicalAddress(address) {
73
- return address;
74
- }
75
- checkRecipient(_recipient) {
76
- /* no-op */
77
- }
78
- // Verification
79
- async verifyAddress(_params) {
80
- throw new Error('verifyAddress not implemented');
81
- }
82
- async isWalletAddress(_params) {
83
- throw new Error('isWalletAddress not implemented');
84
- }
85
- async verifyTransaction(_params) {
86
- throw new Error('verifyTransaction not implemented');
87
- }
88
- // Tx lifecycle
89
- async signTransaction(_params) {
90
- // TODO WIN-6320: implement signTransaction
91
- throw new Error('signTransaction not implemented');
92
- }
93
- async explainTransaction(_options) {
94
- // TODO WIN-6320: implement signTransaction
95
- throw new Error('explainTransaction not implemented');
96
- }
97
- async parseTransaction(_params) {
98
- // TODO WIN-6320: implement signTransaction
99
- throw new Error('parseTransaction not implemented');
100
- }
101
- async presignTransaction(_params) {
102
- // TODO WIN-6320: implement signTransaction
103
- throw new Error('presignTransaction not implemented');
73
+ async verifyTransaction(params) {
74
+ const txHex = params.txPrebuild && params.txPrebuild.txHex;
75
+ if (!txHex) {
76
+ throw new Error('missing required tx prebuild property txHex');
77
+ }
78
+ let tx;
79
+ try {
80
+ const txBuilder = this.getBuilder().from(txHex);
81
+ tx = await txBuilder.build();
82
+ }
83
+ catch (error) {
84
+ throw new Error(`Invalid transaction: ${error.message}`);
85
+ }
86
+ const explainedTx = tx.explainTransaction();
87
+ const type = params.txParams.type;
88
+ if (!type || (type !== 'ImportToC' && explainedTx.type !== sdk_core_1.TransactionType[type])) {
89
+ throw new Error('Tx type does not match with expected txParams type');
90
+ }
91
+ switch (explainedTx.type) {
92
+ case sdk_core_1.TransactionType.Export:
93
+ if (!params.txParams.recipients || params.txParams.recipients?.length !== 1) {
94
+ throw new Error('Export Tx requires a recipient');
95
+ }
96
+ else {
97
+ this.validateExportTx(params.txParams.recipients, explainedTx);
98
+ }
99
+ break;
100
+ case sdk_core_1.TransactionType.Import:
101
+ if (tx.isTransactionForCChain) {
102
+ // Import to C-chain
103
+ if (explainedTx.outputs.length !== 1) {
104
+ throw new Error('Expected 1 output in import transaction');
105
+ }
106
+ if (!params.txParams.recipients || params.txParams.recipients.length !== 1) {
107
+ throw new Error('Expected 1 recipient in import transaction');
108
+ }
109
+ }
110
+ else {
111
+ // Import to P-chain
112
+ if (explainedTx.outputs.length !== 1) {
113
+ throw new Error('Expected 1 output in import transaction');
114
+ }
115
+ this.validateImportTx(explainedTx.inputs, params.txParams);
116
+ }
117
+ break;
118
+ default:
119
+ throw new Error('Tx type is not supported yet');
120
+ }
121
+ return true;
122
+ }
123
+ /**
124
+ * Check if export txn is valid, based on expected tx params.
125
+ *
126
+ * @param {ITransactionRecipient[]} recipients expected recipients and info
127
+ * @param {FlrpLib.TransactionExplanation} explainedTx explained export transaction
128
+ */
129
+ validateExportTx(recipients, explainedTx) {
130
+ if (recipients.length !== 1 || explainedTx.outputs.length !== 1) {
131
+ throw new Error('Export Tx requires one recipient');
132
+ }
133
+ const maxImportFee = this._staticsCoin.network.maxImportFee;
134
+ const recipientAmount = new bignumber_js_1.default(recipients[0].amount);
135
+ if (recipientAmount.isGreaterThan(explainedTx.outputAmount) ||
136
+ recipientAmount.plus(maxImportFee).isLessThan(explainedTx.outputAmount)) {
137
+ throw new Error(`Tx total amount ${explainedTx.outputAmount} does not match with expected total amount field ${recipientAmount} and max import fee ${maxImportFee}`);
138
+ }
139
+ if (explainedTx.outputs && !utils_1.default.isValidAddress(explainedTx.outputs[0].address)) {
140
+ throw new Error(`Invalid P-chain address ${explainedTx.outputs[0].address}`);
141
+ }
104
142
  }
105
- async postProcessPrebuild(prebuild) {
106
- // TODO WIN-6320: implement signTransaction
107
- return prebuild;
143
+ /**
144
+ * Check if import txn into P is valid, based on expected tx params.
145
+ *
146
+ * @param {FlrpEntry[]} explainedTxInputs tx inputs (unspents to be imported)
147
+ * @param {FlrpTransactionParams} txParams expected tx info to check against
148
+ */
149
+ validateImportTx(explainedTxInputs, txParams) {
150
+ if (txParams.unspents) {
151
+ if (explainedTxInputs.length !== txParams.unspents.length) {
152
+ throw new Error(`Expected ${txParams.unspents.length} UTXOs, transaction had ${explainedTxInputs.length}`);
153
+ }
154
+ const unspents = new Set(txParams.unspents);
155
+ for (const unspent of explainedTxInputs) {
156
+ if (!unspents.has(unspent.id)) {
157
+ throw new Error(`Transaction should not contain the UTXO: ${unspent.id}`);
158
+ }
159
+ }
160
+ }
108
161
  }
109
- async getExtraPrebuildParams(_buildParams) {
110
- // TODO WIN-6320: implement signTransaction
111
- return {};
162
+ getBuilder() {
163
+ return new FlrpLib.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
164
+ }
165
+ /**
166
+ * Check if address is valid, then make sure it matches the root address.
167
+ *
168
+ * @param params.address address to validate
169
+ * @param params.keychains public keys to generate the wallet
170
+ */
171
+ async isWalletAddress(params) {
172
+ const { address, keychains } = params;
173
+ if (!this.isValidAddress(address)) {
174
+ throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
175
+ }
176
+ if (!keychains || keychains.length !== 3) {
177
+ throw new Error('Invalid keychains');
178
+ }
179
+ // multisig addresses are separated by ~
180
+ const splitAddresses = address.split('~');
181
+ // derive addresses from keychain
182
+ const unlockAddresses = keychains.map((keychain) => new FlrpLib.KeyPair({ pub: keychain.pub }).getAddress(this._staticsCoin.network.type));
183
+ if (splitAddresses.length !== unlockAddresses.length) {
184
+ throw new sdk_core_1.UnexpectedAddressError(`address validation failure: multisig address length does not match`);
185
+ }
186
+ if (!this.adressesArraysMatch(splitAddresses, unlockAddresses)) {
187
+ throw new sdk_core_1.UnexpectedAddressError(`address validation failure: ${address} is not of this wallet`);
188
+ }
189
+ return true;
190
+ }
191
+ /**
192
+ * Validate that two multisig address arrays have the same elements, order doesnt matter
193
+ * @param addressArray1
194
+ * @param addressArray2
195
+ * @returns true if address arrays have the same addresses
196
+ * @private
197
+ */
198
+ adressesArraysMatch(addressArray1, addressArray2) {
199
+ return JSON.stringify(addressArray1.sort()) === JSON.stringify(addressArray2.sort());
200
+ }
201
+ /**
202
+ * Generate Flrp key pair
203
+ *
204
+ * @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used
205
+ * @returns {Object} object with generated pub and prv
206
+ */
207
+ generateKeyPair(seed) {
208
+ const keyPair = seed ? new FlrpLib.KeyPair({ seed }) : new FlrpLib.KeyPair();
209
+ const keys = keyPair.getKeys();
210
+ if (!keys.prv) {
211
+ throw new Error('Missing prv in key generation.');
212
+ }
213
+ return {
214
+ pub: keys.pub,
215
+ prv: keys.prv,
216
+ };
217
+ }
218
+ /**
219
+ * Return boolean indicating whether input is valid public key for the coin
220
+ *
221
+ * @param {string} pub the prv to be checked
222
+ * @returns is it valid?
223
+ */
224
+ isValidPub(pub) {
225
+ try {
226
+ new FlrpLib.KeyPair({ pub });
227
+ return true;
228
+ }
229
+ catch (e) {
230
+ return false;
231
+ }
112
232
  }
113
- async feeEstimate(_params) {
114
- // TODO WIN-6320: implement signTransaction
115
- throw new Error('feeEstimate not implemented');
233
+ /**
234
+ * Return boolean indicating whether input is valid private key for the coin
235
+ *
236
+ * @param {string} prv the prv to be checked
237
+ * @returns is it valid?
238
+ */
239
+ isValidPrv(prv) {
240
+ try {
241
+ new FlrpLib.KeyPair({ prv });
242
+ return true;
243
+ }
244
+ catch (e) {
245
+ return false;
246
+ }
116
247
  }
117
- async broadcastTransaction(_params) {
118
- // TODO WIN-6320: implement signTransaction
119
- throw new Error('broadcastTransaction not implemented');
248
+ isValidAddress(address) {
249
+ if (address === undefined) {
250
+ return false;
251
+ }
252
+ // validate eth address for cross-chain txs to c-chain
253
+ if (typeof address === 'string' && (0, ethereumjs_util_1.isValidAddress)(address)) {
254
+ return true;
255
+ }
256
+ return FlrpLib.Utils.isValidAddress(address);
257
+ }
258
+ /**
259
+ * Signs Avaxp transaction
260
+ */
261
+ async signTransaction(params) {
262
+ // deserialize raw transaction (note: fromAddress has onchain order)
263
+ const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);
264
+ const key = params.prv;
265
+ // push the keypair to signer array
266
+ txBuilder.sign({ key });
267
+ // build the transaction
268
+ const transaction = await txBuilder.build();
269
+ if (!transaction) {
270
+ throw new sdk_core_1.InvalidTransactionError('Error while trying to build transaction');
271
+ }
272
+ return transaction.signature.length >= 2
273
+ ? { txHex: transaction.toBroadcastFormat() }
274
+ : { halfSigned: { txHex: transaction.toBroadcastFormat() } };
120
275
  }
121
- // Wallet helpers
122
- async supplementGenerateWallet(_walletParams, _keychains) {
276
+ async parseTransaction(params) {
123
277
  return {};
124
278
  }
125
- newWalletObject(walletParams) {
126
- return walletParams;
127
- }
128
- preCreateBitGo(_params) {
129
- /* no-op */
130
- }
131
- initiateRecovery(_params) {
132
- throw new Error('initiateRecovery not implemented');
133
- }
134
- // Signing helpers
135
- async signMessage(_key, _message) {
136
- throw new Error('signMessage not implemented');
137
- }
138
- async createKeySignatures(_prv, _backup, _bitgo) {
139
- throw new Error('createKeySignatures not implemented');
140
- }
141
- async getSignablePayload(_serializedTx) {
142
- throw new Error('getSignablePayload not implemented');
143
- }
144
- getMPCAlgorithm() {
145
- return 'ecdsa';
146
- }
147
- // Token / NFT / inscription / recovery placeholders
148
- recoverToken(_params) {
149
- throw new Error('recoverToken not implemented');
150
- }
151
- buildNftTransferData(_params) {
152
- throw new Error('buildNftTransferData not implemented');
153
- }
154
- getInscriptionBuilder(_wallet) {
155
- throw new Error('getInscriptionBuilder not implemented');
156
- }
157
- // Misc
158
- getHashFunction() {
159
- throw new Error('getHashFunction not implemented');
160
- }
161
- deriveKeyWithSeed(_params) {
162
- throw new Error('deriveKeyWithSeed not implemented');
279
+ /**
280
+ * Explain a Avaxp transaction from txHex
281
+ * @param params
282
+ * @param callback
283
+ */
284
+ async explainTransaction(params) {
285
+ const txHex = params.txHex ?? params?.halfSigned?.txHex;
286
+ if (!txHex) {
287
+ throw new Error('missing transaction hex');
288
+ }
289
+ try {
290
+ const txBuilder = this.getBuilder().from(txHex);
291
+ const tx = await txBuilder.build();
292
+ return tx.explainTransaction();
293
+ }
294
+ catch (e) {
295
+ throw new Error(`Invalid transaction: ${e.message}`);
296
+ }
163
297
  }
164
- setCoinSpecificFieldsInIntent(_intent, _params) {
165
- /* no-op */
298
+ recoverySignature(messageHash, signature) {
299
+ return FlrpLib.Utils.recoverySignature(messageHash, signature);
166
300
  }
167
- assertIsValidKey(_params) {
168
- /* no-op */
301
+ async signMessage(key, message) {
302
+ const prv = new FlrpLib.KeyPair(key).getPrivateKey();
303
+ if (!prv) {
304
+ throw new sdk_core_1.SigningError('Invalid key pair options');
305
+ }
306
+ if (typeof message === 'string') {
307
+ message = Buffer.from(message, 'hex');
308
+ }
309
+ return FlrpLib.Utils.createSignature(this._staticsCoin.network, message, prv);
169
310
  }
170
- auditDecryptedKey() {
171
- /* no-op */
311
+ /** @inheritDoc */
312
+ auditDecryptedKey(params) {
313
+ throw new sdk_core_1.MethodNotImplementedError();
172
314
  }
173
315
  }
174
316
  exports.Flrp = Flrp;
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flrp.js","sourceRoot":"","sources":["../../src/flrp.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BitGoBase,\n  VerifyAddressOptions,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  KeyPair,\n  SignTransactionOptions,\n  SignedTransaction,\n  InitiateRecoveryOptions,\n  SupplementGenerateWalletOptions,\n  KeychainsTriplet,\n  TransactionPrebuild,\n  PresignTransactionOptions,\n  FeeEstimateOptions,\n  DeriveKeyWithSeedOptions,\n  AuditKeyParams,\n  PopulatedIntent,\n  PrebuildTransactionWithIntentOptions,\n  TokenTransferRecipientParams,\n  BuildNftTransferDataOptions,\n  BaseBroadcastTransactionOptions,\n  BaseBroadcastTransactionResult,\n  MPCAlgorithm,\n  Wallet,\n  IInscriptionBuilder,\n  ExtraPrebuildParamsOptions,\n  ValidMofNOptions,\n  VerifyTransactionOptions,\n  ITransactionExplanation,\n  RecoverTokenTransaction,\n  RecoverWalletTokenOptions,\n  PrecreateBitGoOptions,\n  IWallet,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';\nimport { Hash } from 'crypto';\n\nexport class Flrp extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Flrp(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family as CoinFamily;\n  }\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n  getBaseFactor(): number | string {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  // TODO WIN-6321, 6322, 6318: All below methods will be implemented in coming ticket\n  // Feature flags\n  supportsTss(): boolean {\n    return false;\n  }\n  supportsMessageSigning(): boolean {\n    return false;\n  }\n  supportsSigningTypedData(): boolean {\n    return false;\n  }\n  supportsBlockTarget(): boolean {\n    return false;\n  }\n  supportsLightning(): boolean {\n    return false;\n  }\n  supportsBlsDkg(): boolean {\n    return false;\n  }\n  isEVM(): boolean {\n    return false;\n  }\n\n  // Conversions (placeholder)\n  // Use BaseCoin default conversions (baseUnitsToBigUnits / bigUnitsToBaseUnits)\n\n  // Key methods (stubs)\n  generateKeyPair(): KeyPair {\n    throw new Error('generateKeyPair not implemented');\n  }\n  generateRootKeyPair(): KeyPair {\n    throw new Error('generateRootKeyPair not implemented');\n  }\n  keyIdsForSigning(): number[] {\n    return [0, 1, 2];\n  }\n  isValidPub(_pub: string): boolean {\n    return false;\n  }\n  isValidAddress(_address: string): boolean {\n    return false;\n  }\n  isValidMofNSetup(_params: ValidMofNOptions): boolean {\n    return false;\n  }\n  canonicalAddress(address: string): string {\n    return address;\n  }\n  checkRecipient(_recipient: { address: string; amount: string | number }): void {\n    /* no-op */\n  }\n\n  // Verification\n  async verifyAddress(_params: VerifyAddressOptions): Promise<boolean> {\n    throw new Error('verifyAddress not implemented');\n  }\n  async isWalletAddress(_params: VerifyAddressOptions): Promise<boolean> {\n    throw new Error('isWalletAddress not implemented');\n  }\n  async verifyTransaction(_params: VerifyTransactionOptions): Promise<boolean> {\n    throw new Error('verifyTransaction not implemented');\n  }\n\n  // Tx lifecycle\n  async signTransaction(_params: SignTransactionOptions): Promise<SignedTransaction> {\n    // TODO WIN-6320: implement signTransaction\n    throw new Error('signTransaction not implemented');\n  }\n  async explainTransaction(\n    _options: Record<string, unknown>\n  ): Promise<ITransactionExplanation<unknown, string | number> | undefined> {\n    // TODO WIN-6320: implement signTransaction\n    throw new Error('explainTransaction not implemented');\n  }\n  async parseTransaction(_params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    // TODO WIN-6320: implement signTransaction\n    throw new Error('parseTransaction not implemented');\n  }\n  async presignTransaction(_params: PresignTransactionOptions): Promise<PresignTransactionOptions> {\n    // TODO WIN-6320: implement signTransaction\n    throw new Error('presignTransaction not implemented');\n  }\n  async postProcessPrebuild(prebuild: TransactionPrebuild): Promise<TransactionPrebuild> {\n    // TODO WIN-6320: implement signTransaction\n    return prebuild;\n  }\n  async getExtraPrebuildParams(_buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>> {\n    // TODO WIN-6320: implement signTransaction\n    return {};\n  }\n  async feeEstimate(_params: FeeEstimateOptions): Promise<unknown> {\n    // TODO WIN-6320: implement signTransaction\n    throw new Error('feeEstimate not implemented');\n  }\n  async broadcastTransaction(_params: BaseBroadcastTransactionOptions): Promise<BaseBroadcastTransactionResult> {\n    // TODO WIN-6320: implement signTransaction\n    throw new Error('broadcastTransaction not implemented');\n  }\n\n  // Wallet helpers\n  async supplementGenerateWallet(\n    _walletParams: SupplementGenerateWalletOptions,\n    _keychains: KeychainsTriplet\n  ): Promise<Record<string, unknown>> {\n    return {};\n  }\n  newWalletObject(walletParams: unknown): IWallet {\n    return walletParams as IWallet;\n  }\n  preCreateBitGo(_params: PrecreateBitGoOptions): void {\n    /* no-op */\n  }\n  initiateRecovery(_params: InitiateRecoveryOptions): never {\n    throw new Error('initiateRecovery not implemented');\n  }\n\n  // Signing helpers\n  async signMessage(_key: { prv: string }, _message: string): Promise<Buffer> {\n    throw new Error('signMessage not implemented');\n  }\n  async createKeySignatures(\n    _prv: string,\n    _backup: { pub: string },\n    _bitgo: { pub: string }\n  ): Promise<{ backup: string; bitgo: string }> {\n    throw new Error('createKeySignatures not implemented');\n  }\n  async getSignablePayload(_serializedTx: string): Promise<Buffer> {\n    throw new Error('getSignablePayload not implemented');\n  }\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'ecdsa';\n  }\n\n  // Token / NFT / inscription / recovery placeholders\n  recoverToken(_params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction> {\n    throw new Error('recoverToken not implemented');\n  }\n  buildNftTransferData(_params: BuildNftTransferDataOptions): string | TokenTransferRecipientParams {\n    throw new Error('buildNftTransferData not implemented');\n  }\n  getInscriptionBuilder(_wallet: Wallet): IInscriptionBuilder {\n    throw new Error('getInscriptionBuilder not implemented');\n  }\n\n  // Misc\n  getHashFunction(): Hash {\n    throw new Error('getHashFunction not implemented');\n  }\n  deriveKeyWithSeed(_params: DeriveKeyWithSeedOptions): { key: string; derivationPath: string } {\n    throw new Error('deriveKeyWithSeed not implemented');\n  }\n  setCoinSpecificFieldsInIntent(_intent: PopulatedIntent, _params: PrebuildTransactionWithIntentOptions): void {\n    /* no-op */\n  }\n  assertIsValidKey(_params: AuditKeyParams): void {\n    /* no-op */\n  }\n  auditDecryptedKey(): void {\n    /* no-op */\n  }\n}\n"]}
317
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flrp.js","sourceRoot":"","sources":["../../src/flrp.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAmG;AACnG,mDAmB8B;AAC9B,+CAAiC;AAQjC,wDAAgC;AAChC,gEAAqC;AACrC,qDAAsE;AAEtE,MAAa,IAAK,SAAQ,mBAAQ;IAGhC,YAAY,KAAgB,EAAE,WAAuC;QACnE,KAAK,CAAC,KAAK,CAAC,CAAC;QAEb,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACxE,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,KAAgB,EAAE,WAAuC;QAC7E,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACtC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;IAChC,CAAC;IACD,SAAS;QACP,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;IACD,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC;IACpC,CAAC;IACD,aAAa;QACX,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAED,oBAAoB;IACpB,sBAAsB;QACpB,OAAO,wBAAa,CAAC,OAAO,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,MAAoC;QAC1D,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC;QAC3D,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;QACD,IAAI,EAAE,CAAC;QACP,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAChD,EAAE,GAAG,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;QAC/B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,wBAAwB,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3D,CAAC;QACD,MAAM,WAAW,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC;QAE5C,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;QAElC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,IAAI,WAAW,CAAC,IAAI,KAAK,0BAAe,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YAClF,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACxE,CAAC;QAED,QAAQ,WAAW,CAAC,IAAI,EAAE,CAAC;YACzB,KAAK,0BAAe,CAAC,MAAM;gBACzB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,IAAI,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC5E,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;gBACpD,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;gBACjE,CAAC;gBACD,MAAM;YACR,KAAK,0BAAe,CAAC,MAAM;gBACzB,IAAI,EAAE,CAAC,sBAAsB,EAAE,CAAC;oBAC9B,oBAAoB;oBACpB,IAAI,WAAW,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;wBACrC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;oBAC7D,CAAC;oBACD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,IAAI,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;wBAC3E,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;oBAChE,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,oBAAoB;oBACpB,IAAI,WAAW,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;wBACrC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;oBAC7D,CAAC;oBACD,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;gBAC7D,CAAC;gBACD,MAAM;YACR;gBACE,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;QACpD,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,CAAC,UAAmC,EAAE,WAA2C;QAC/F,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,WAAW,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChE,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;QACtD,CAAC;QAED,MAAM,YAAY,GAAI,IAAI,CAAC,YAAY,CAAC,OAAwB,CAAC,YAAY,CAAC;QAC9E,MAAM,eAAe,GAAG,IAAI,sBAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC5D,IACE,eAAe,CAAC,aAAa,CAAC,WAAW,CAAC,YAAY,CAAC;YACvD,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,YAAY,CAAC,EACvE,CAAC;YACD,MAAM,IAAI,KAAK,CACb,mBAAmB,WAAW,CAAC,YAAY,oDAAoD,eAAe,uBAAuB,YAAY,EAAE,CACpJ,CAAC;QACJ,CAAC;QAED,IAAI,WAAW,CAAC,OAAO,IAAI,CAAC,eAAK,CAAC,cAAc,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;YACjF,MAAM,IAAI,KAAK,CAAC,2BAA2B,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAC/E,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,CAAC,iBAA8B,EAAE,QAA+B;QAC9E,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACtB,IAAI,iBAAiB,CAAC,MAAM,KAAK,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBAC1D,MAAM,IAAI,KAAK,CAAC,YAAY,QAAQ,CAAC,QAAQ,CAAC,MAAM,2BAA2B,iBAAiB,CAAC,MAAM,EAAE,CAAC,CAAC;YAC7G,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YAE5C,KAAK,MAAM,OAAO,IAAI,iBAAiB,EAAE,CAAC;gBACxC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;oBAC9B,MAAM,IAAI,KAAK,CAAC,4CAA4C,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC5E,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEO,UAAU;QAChB,OAAO,IAAI,OAAO,CAAC,yBAAyB,CAAC,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,eAAe,CAAC,MAA4B;QAChD,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAEtC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,8BAAmB,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,wCAAwC;QACxC,MAAM,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE1C,iCAAiC;QACjC,MAAM,eAAe,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CACjD,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CACtF,CAAC;QAEF,IAAI,cAAc,CAAC,MAAM,KAAK,eAAe,CAAC,MAAM,EAAE,CAAC;YACrD,MAAM,IAAI,iCAAsB,CAAC,oEAAoE,CAAC,CAAC;QACzG,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,eAAe,CAAC,EAAE,CAAC;YAC/D,MAAM,IAAI,iCAAsB,CAAC,+BAA+B,OAAO,wBAAwB,CAAC,CAAC;QACnG,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;OAMG;IACK,mBAAmB,CAAC,aAAuB,EAAE,aAAuB;QAC1E,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC;IACvF,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,IAAa;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QAC7E,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;QAE/B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACpD,CAAC;QAED,OAAO;YACL,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC;YACH,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC;YACH,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,cAAc,CAAC,OAA0B;QACvC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YAC1B,OAAO,KAAK,CAAC;QACf,CAAC;QAED,sDAAsD;QACtD,IAAI,OAAO,OAAO,KAAK,QAAQ,IAAI,IAAA,gCAAiB,EAAC,OAAO,CAAC,EAAE,CAAC;YAC9D,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,eAAe,CAAC,MAAkC;QACtD,oEAAoE;QACpE,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAClE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC;QAEvB,mCAAmC;QACnC,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;QAExB,wBAAwB;QACxB,MAAM,WAAW,GAAoB,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;QAC7D,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,kCAAuB,CAAC,yCAAyC,CAAC,CAAC;QAC/E,CAAC;QACD,OAAO,WAAW,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC;YACtC,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,CAAC,iBAAiB,EAAE,EAAE;YAC5C,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,WAAW,CAAC,iBAAiB,EAAE,EAAE,EAAE,CAAC;IACjE,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,MAA+B;QACpD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,kBAAkB,CAAC,MAAqC;QAC5D,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC;QACxD,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QACD,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAChD,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;YACnC,OAAO,EAAE,CAAC,kBAAkB,EAAE,CAAC;QACjC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,WAAmB,EAAE,SAAiB;QACtD,OAAO,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IACjE,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,GAAY,EAAE,OAAwB;QACtD,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,CAAC;QACrD,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,MAAM,IAAI,uBAAY,CAAC,0BAA0B,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACxC,CAAC;QACD,OAAO,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,OAAuB,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;IAChG,CAAC;IAED,kBAAkB;IAClB,iBAAiB,CAAC,MAA+B;QAC/C,MAAM,IAAI,oCAAyB,EAAE,CAAC;IACxC,CAAC;CACF;AAvTD,oBAuTC","sourcesContent":["import { BaseCoin as StaticsBaseCoin, CoinFamily, coins, FlareNetwork } from '@bitgo-beta/statics';\nimport {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  VerifyAddressOptions,\n  TransactionType,\n  ITransactionRecipient,\n  InvalidAddressError,\n  UnexpectedAddressError,\n  InvalidTransactionError,\n  BaseTransaction,\n  SigningError,\n  MethodNotImplementedError,\n} from '@bitgo-beta/sdk-core';\nimport * as FlrpLib from './lib';\nimport {\n  FlrpEntry,\n  FlrpExplainTransactionOptions,\n  FlrpSignTransactionOptions,\n  FlrpTransactionParams,\n  FlrpVerifyTransactionOptions,\n} from './lib/iface';\nimport utils from './lib/utils';\nimport BigNumber from 'bignumber.js';\nimport { isValidAddress as isValidEthAddress } from 'ethereumjs-util';\n\nexport class Flrp extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Flrp(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  async verifyTransaction(params: FlrpVerifyTransactionOptions): Promise<boolean> {\n    const txHex = params.txPrebuild && params.txPrebuild.txHex;\n    if (!txHex) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    let tx;\n    try {\n      const txBuilder = this.getBuilder().from(txHex);\n      tx = await txBuilder.build();\n    } catch (error) {\n      throw new Error(`Invalid transaction: ${error.message}`);\n    }\n    const explainedTx = tx.explainTransaction();\n\n    const type = params.txParams.type;\n\n    if (!type || (type !== 'ImportToC' && explainedTx.type !== TransactionType[type])) {\n      throw new Error('Tx type does not match with expected txParams type');\n    }\n\n    switch (explainedTx.type) {\n      case TransactionType.Export:\n        if (!params.txParams.recipients || params.txParams.recipients?.length !== 1) {\n          throw new Error('Export Tx requires a recipient');\n        } else {\n          this.validateExportTx(params.txParams.recipients, explainedTx);\n        }\n        break;\n      case TransactionType.Import:\n        if (tx.isTransactionForCChain) {\n          // Import to C-chain\n          if (explainedTx.outputs.length !== 1) {\n            throw new Error('Expected 1 output in import transaction');\n          }\n          if (!params.txParams.recipients || params.txParams.recipients.length !== 1) {\n            throw new Error('Expected 1 recipient in import transaction');\n          }\n        } else {\n          // Import to P-chain\n          if (explainedTx.outputs.length !== 1) {\n            throw new Error('Expected 1 output in import transaction');\n          }\n          this.validateImportTx(explainedTx.inputs, params.txParams);\n        }\n        break;\n      default:\n        throw new Error('Tx type is not supported yet');\n    }\n    return true;\n  }\n\n  /**\n   * Check if export txn is valid, based on expected tx params.\n   *\n   * @param {ITransactionRecipient[]} recipients expected recipients and info\n   * @param {FlrpLib.TransactionExplanation} explainedTx explained export transaction\n   */\n  validateExportTx(recipients: ITransactionRecipient[], explainedTx: FlrpLib.TransactionExplanation): void {\n    if (recipients.length !== 1 || explainedTx.outputs.length !== 1) {\n      throw new Error('Export Tx requires one recipient');\n    }\n\n    const maxImportFee = (this._staticsCoin.network as FlareNetwork).maxImportFee;\n    const recipientAmount = new BigNumber(recipients[0].amount);\n    if (\n      recipientAmount.isGreaterThan(explainedTx.outputAmount) ||\n      recipientAmount.plus(maxImportFee).isLessThan(explainedTx.outputAmount)\n    ) {\n      throw new Error(\n        `Tx total amount ${explainedTx.outputAmount} does not match with expected total amount field ${recipientAmount} and max import fee ${maxImportFee}`\n      );\n    }\n\n    if (explainedTx.outputs && !utils.isValidAddress(explainedTx.outputs[0].address)) {\n      throw new Error(`Invalid P-chain address ${explainedTx.outputs[0].address}`);\n    }\n  }\n\n  /**\n   * Check if import txn into P is valid, based on expected tx params.\n   *\n   * @param {FlrpEntry[]} explainedTxInputs tx inputs (unspents to be imported)\n   * @param {FlrpTransactionParams} txParams expected tx info to check against\n   */\n  validateImportTx(explainedTxInputs: FlrpEntry[], txParams: FlrpTransactionParams): void {\n    if (txParams.unspents) {\n      if (explainedTxInputs.length !== txParams.unspents.length) {\n        throw new Error(`Expected ${txParams.unspents.length} UTXOs, transaction had ${explainedTxInputs.length}`);\n      }\n\n      const unspents = new Set(txParams.unspents);\n\n      for (const unspent of explainedTxInputs) {\n        if (!unspents.has(unspent.id)) {\n          throw new Error(`Transaction should not contain the UTXO: ${unspent.id}`);\n        }\n      }\n    }\n  }\n\n  private getBuilder(): FlrpLib.TransactionBuilderFactory {\n    return new FlrpLib.TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  /**\n   * Check if address is valid, then make sure it matches the root address.\n   *\n   * @param params.address address to validate\n   * @param params.keychains public keys to generate the wallet\n   */\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    const { address, keychains } = params;\n\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n    if (!keychains || keychains.length !== 3) {\n      throw new Error('Invalid keychains');\n    }\n\n    // multisig addresses are separated by ~\n    const splitAddresses = address.split('~');\n\n    // derive addresses from keychain\n    const unlockAddresses = keychains.map((keychain) =>\n      new FlrpLib.KeyPair({ pub: keychain.pub }).getAddress(this._staticsCoin.network.type)\n    );\n\n    if (splitAddresses.length !== unlockAddresses.length) {\n      throw new UnexpectedAddressError(`address validation failure: multisig address length does not match`);\n    }\n\n    if (!this.adressesArraysMatch(splitAddresses, unlockAddresses)) {\n      throw new UnexpectedAddressError(`address validation failure: ${address} is not of this wallet`);\n    }\n\n    return true;\n  }\n\n  /**\n   * Validate that two multisig address arrays have the same elements, order doesnt matter\n   * @param addressArray1\n   * @param addressArray2\n   * @returns true if address arrays have the same addresses\n   * @private\n   */\n  private adressesArraysMatch(addressArray1: string[], addressArray2: string[]) {\n    return JSON.stringify(addressArray1.sort()) === JSON.stringify(addressArray2.sort());\n  }\n\n  /**\n   * Generate Flrp key pair\n   *\n   * @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used\n   * @returns {Object} object with generated pub and prv\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new FlrpLib.KeyPair({ seed }) : new FlrpLib.KeyPair();\n    const keys = keyPair.getKeys();\n\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether input is valid public key for the coin\n   *\n   * @param {string} pub the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPub(pub: string): boolean {\n    try {\n      new FlrpLib.KeyPair({ pub });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid private key for the coin\n   *\n   * @param {string} prv the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPrv(prv: string): boolean {\n    try {\n      new FlrpLib.KeyPair({ prv });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  isValidAddress(address: string | string[]): boolean {\n    if (address === undefined) {\n      return false;\n    }\n\n    // validate eth address for cross-chain txs to c-chain\n    if (typeof address === 'string' && isValidEthAddress(address)) {\n      return true;\n    }\n\n    return FlrpLib.Utils.isValidAddress(address);\n  }\n\n  /**\n   * Signs Avaxp transaction\n   */\n  async signTransaction(params: FlrpSignTransactionOptions): Promise<SignedTransaction> {\n    // deserialize raw transaction (note: fromAddress has onchain order)\n    const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);\n    const key = params.prv;\n\n    // push the keypair to signer array\n    txBuilder.sign({ key });\n\n    // build the transaction\n    const transaction: BaseTransaction = await txBuilder.build();\n    if (!transaction) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    return transaction.signature.length >= 2\n      ? { txHex: transaction.toBroadcastFormat() }\n      : { halfSigned: { txHex: transaction.toBroadcastFormat() } };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  /**\n   * Explain a Avaxp transaction from txHex\n   * @param params\n   * @param callback\n   */\n  async explainTransaction(params: FlrpExplainTransactionOptions): Promise<FlrpLib.TransactionExplanation> {\n    const txHex = params.txHex ?? params?.halfSigned?.txHex;\n    if (!txHex) {\n      throw new Error('missing transaction hex');\n    }\n    try {\n      const txBuilder = this.getBuilder().from(txHex);\n      const tx = await txBuilder.build();\n      return tx.explainTransaction();\n    } catch (e) {\n      throw new Error(`Invalid transaction: ${e.message}`);\n    }\n  }\n\n  recoverySignature(messageHash: Buffer, signature: Buffer): Buffer {\n    return FlrpLib.Utils.recoverySignature(messageHash, signature);\n  }\n\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const prv = new FlrpLib.KeyPair(key).getPrivateKey();\n    if (!prv) {\n      throw new SigningError('Invalid key pair options');\n    }\n    if (typeof message === 'string') {\n      message = Buffer.from(message, 'hex');\n    }\n    return FlrpLib.Utils.createSignature(this._staticsCoin.network as FlareNetwork, message, prv);\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey(params: AuditDecryptedKeyParams): void {\n    throw new MethodNotImplementedError();\n  }\n}\n"]}
@@ -1,6 +1,5 @@
1
1
  export * from './flrp';
2
2
  export * from './tflrp';
3
3
  export * as FlrPLib from './lib';
4
- export * from './iface';
5
4
  export * from './register';
6
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,cAAc,YAAY,CAAC"}
package/dist/src/index.js CHANGED
@@ -40,6 +40,5 @@ exports.FlrPLib = void 0;
40
40
  __exportStar(require("./flrp"), exports);
41
41
  __exportStar(require("./tflrp"), exports);
42
42
  exports.FlrPLib = __importStar(require("./lib"));
43
- __exportStar(require("./iface"), exports);
44
43
  __exportStar(require("./register"), exports);
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCO0FBQ3ZCLDBDQUF3QjtBQUN4QixpREFBaUM7QUFDakMsMENBQXdCO0FBQ3hCLDZDQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmxycCc7XG5leHBvcnQgKiBmcm9tICcuL3RmbHJwJztcbmV4cG9ydCAqIGFzIEZsclBMaWIgZnJvbSAnLi9saWInO1xuZXhwb3J0ICogZnJvbSAnLi9pZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL3JlZ2lzdGVyJztcbiJdfQ==
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCO0FBQ3ZCLDBDQUF3QjtBQUN4QixpREFBaUM7QUFDakMsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9mbHJwJztcbmV4cG9ydCAqIGZyb20gJy4vdGZscnAnO1xuZXhwb3J0ICogYXMgRmxyUExpYiBmcm9tICcuL2xpYic7XG5leHBvcnQgKiBmcm9tICcuL3JlZ2lzdGVyJztcbiJdfQ==
@@ -0,0 +1,43 @@
1
+ import { TransactionType } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import { AtomicInCTransactionBuilder } from './atomicInCTransactionBuilder';
4
+ import { Credential } from '@flarenetwork/flarejs';
5
+ import { Tx, DecodedUtxoObj } from './iface';
6
+ export declare class ExportInCTxBuilder extends AtomicInCTransactionBuilder {
7
+ private _nonce;
8
+ constructor(_coinConfig: Readonly<CoinConfig>);
9
+ /**
10
+ * UTXOs are not required for Export Tx from C-Chain (uses EVM balance instead).
11
+ * Override to prevent usage by throwing an error.
12
+ *
13
+ * @throws {BuildTransactionError} always throws as UTXOs are not applicable
14
+ */
15
+ decodedUtxos(_decodedUtxos: DecodedUtxoObj[]): this;
16
+ /**
17
+ * Set the nonce of C-Chain sender address
18
+ *
19
+ * @param {number | string} nonce - number that can be only used once
20
+ */
21
+ nonce(nonce: number | string): this;
22
+ /**
23
+ * Export tx target P wallet.
24
+ *
25
+ * @param pAddresses
26
+ */
27
+ to(pAddresses: string | string[]): this;
28
+ protected get transactionType(): TransactionType;
29
+ initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this;
30
+ static verifyTxType(txnType: string): boolean;
31
+ verifyTxType(txnType: string): boolean;
32
+ /**
33
+ * Build the export in C-chain transaction
34
+ * @protected
35
+ */
36
+ protected buildFlareTransaction(): void;
37
+ /**
38
+ * Check the nonce is non-negative.
39
+ * @param nonce
40
+ */
41
+ validateNonce(nonce: bigint): void;
42
+ }
43
+ //# sourceMappingURL=ExportInCTxBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExportInCTxBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/ExportInCTxBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuC,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5F,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAGL,UAAU,EAKX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,EAAE,EAA0C,cAAc,EAAE,MAAM,SAAS,CAAC;AAErF,qBAAa,kBAAmB,SAAQ,2BAA2B;IACjE,OAAO,CAAC,MAAM,CAAS;gBAEX,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;;;;OAKG;IACH,YAAY,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI;IAInD;;;;OAIG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAOnC;;;;OAIG;IACH,EAAE,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,IAAI;IAMvC,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,WAAW,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,CAAC,EAAE,MAAM,EAAE,iBAAiB,CAAC,EAAE,UAAU,EAAE,GAAG,IAAI;IAyD9E,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAI7C,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAItC;;;OAGG;IACH,SAAS,CAAC,qBAAqB,IAAI,IAAI;IAkDvC;;;OAGG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;CAKnC"}