@bitgo-beta/sdk-coin-flrp 1.0.1-beta.294 → 1.0.1-beta.296

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.
@@ -1,5 +1,7 @@
1
1
  import { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';
2
- import { AuditDecryptedKeyParams, BaseCoin, BitGoBase, KeyPair, MultisigType, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions, TssVerifyAddressOptions, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
2
+ import { AuditDecryptedKeyParams, BaseCoin, BitGoBase, KeyPair, MultisigType, ParsedTransaction, ParseTransactionOptions, SignedTransaction, VerifyAddressOptions, ITransactionRecipient } from '@bitgo-beta/sdk-core';
3
+ import * as FlrpLib from './lib';
4
+ import { FlrpEntry, FlrpExplainTransactionOptions, FlrpSignTransactionOptions, FlrpTransactionParams, FlrpVerifyTransactionOptions } from './lib/iface';
3
5
  export declare class Flrp extends BaseCoin {
4
6
  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;
5
7
  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
@@ -10,13 +12,73 @@ export declare class Flrp extends BaseCoin {
10
12
  getBaseFactor(): string | number;
11
13
  /** inherited doc */
12
14
  getDefaultMultisigType(): MultisigType;
13
- verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
14
- isWalletAddress(params: VerifyAddressOptions | TssVerifyAddressOptions): Promise<boolean>;
15
- parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;
15
+ verifyTransaction(params: FlrpVerifyTransactionOptions): Promise<boolean>;
16
+ /**
17
+ * Check if export txn is valid, based on expected tx params.
18
+ *
19
+ * @param {ITransactionRecipient[]} recipients expected recipients and info
20
+ * @param {FlrpLib.TransactionExplanation} explainedTx explained export transaction
21
+ */
22
+ validateExportTx(recipients: ITransactionRecipient[], explainedTx: FlrpLib.TransactionExplanation): void;
23
+ /**
24
+ * Check if import txn into P is valid, based on expected tx params.
25
+ *
26
+ * @param {FlrpEntry[]} explainedTxInputs tx inputs (unspents to be imported)
27
+ * @param {FlrpTransactionParams} txParams expected tx info to check against
28
+ */
29
+ validateImportTx(explainedTxInputs: FlrpEntry[], txParams: FlrpTransactionParams): void;
30
+ private getBuilder;
31
+ /**
32
+ * Check if address is valid, then make sure it matches the root address.
33
+ *
34
+ * @param params.address address to validate
35
+ * @param params.keychains public keys to generate the wallet
36
+ */
37
+ isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;
38
+ /**
39
+ * Validate that two multisig address arrays have the same elements, order doesnt matter
40
+ * @param addressArray1
41
+ * @param addressArray2
42
+ * @returns true if address arrays have the same addresses
43
+ * @private
44
+ */
45
+ private adressesArraysMatch;
46
+ /**
47
+ * Generate Flrp key pair
48
+ *
49
+ * @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used
50
+ * @returns {Object} object with generated pub and prv
51
+ */
16
52
  generateKeyPair(seed?: Buffer): KeyPair;
53
+ /**
54
+ * Return boolean indicating whether input is valid public key for the coin
55
+ *
56
+ * @param {string} pub the prv to be checked
57
+ * @returns is it valid?
58
+ */
17
59
  isValidPub(pub: string): boolean;
18
- isValidAddress(address: string): boolean;
19
- signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;
60
+ /**
61
+ * Return boolean indicating whether input is valid private key for the coin
62
+ *
63
+ * @param {string} prv the prv to be checked
64
+ * @returns is it valid?
65
+ */
66
+ isValidPrv(prv: string): boolean;
67
+ isValidAddress(address: string | string[]): boolean;
68
+ /**
69
+ * Signs Avaxp transaction
70
+ */
71
+ signTransaction(params: FlrpSignTransactionOptions): Promise<SignedTransaction>;
72
+ parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;
73
+ /**
74
+ * Explain a Avaxp transaction from txHex
75
+ * @param params
76
+ * @param callback
77
+ */
78
+ explainTransaction(params: FlrpExplainTransactionOptions): Promise<FlrpLib.TransactionExplanation>;
79
+ recoverySignature(message: Buffer, signature: Buffer): Buffer;
80
+ signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer>;
81
+ /** @inheritDoc */
20
82
  auditDecryptedKey(params: AuditDecryptedKeyParams): void;
21
83
  }
22
84
  //# sourceMappingURL=flrp.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"flrp.d.ts","sourceRoot":"","sources":["../../src/flrp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC9E,OAAO,EACL,uBAAuB,EACvB,QAAQ,EACR,SAAS,EACT,OAAO,EACP,YAAY,EAEZ,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,EACtB,uBAAuB,EACvB,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,sBAAsB,CAAC;AAE9B,qBAAa,IAAK,SAAQ,QAAQ;IAChC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;gBAE/C,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAUrE,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,QAAQ,IAAI,MAAM;IAGlB,SAAS,IAAI,UAAU;IAGvB,WAAW,IAAI,MAAM;IAGrB,aAAa,IAAI,MAAM,GAAG,MAAM;IAIhC,oBAAoB;IACpB,sBAAsB,IAAI,YAAY;IAItC,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAGrE,eAAe,CAAC,MAAM,EAAE,oBAAoB,GAAG,uBAAuB,GAAG,OAAO,CAAC,OAAO,CAAC;IAGzF,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAG7E,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAGvC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAGhC,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAGxC,eAAe,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAG3E,iBAAiB,CAAC,MAAM,EAAE,uBAAuB,GAAG,IAAI;CAGzD"}
1
+ {"version":3,"file":"flrp.d.ts","sourceRoot":"","sources":["../../src/flrp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,UAAU,EAAuB,MAAM,qBAAqB,CAAC;AACnG,OAAO,EACL,uBAAuB,EACvB,QAAQ,EACR,SAAS,EACT,OAAO,EACP,YAAY,EAEZ,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,oBAAoB,EAEpB,qBAAqB,EAOtB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,OAAO,EACL,SAAS,EACT,6BAA6B,EAC7B,0BAA0B,EAC1B,qBAAqB,EACrB,4BAA4B,EAC7B,MAAM,aAAa,CAAC;AAKrB,qBAAa,IAAK,SAAQ,QAAQ;IAChC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;gBAE/C,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAUrE,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,QAAQ,IAAI,MAAM;IAGlB,SAAS,IAAI,UAAU;IAGvB,WAAW,IAAI,MAAM;IAGrB,aAAa,IAAI,MAAM,GAAG,MAAM;IAIhC,oBAAoB;IACpB,sBAAsB,IAAI,YAAY;IAIhC,iBAAiB,CAAC,MAAM,EAAE,4BAA4B,GAAG,OAAO,CAAC,OAAO,CAAC;IAmD/E;;;;;OAKG;IACH,gBAAgB,CAAC,UAAU,EAAE,qBAAqB,EAAE,EAAE,WAAW,EAAE,OAAO,CAAC,sBAAsB,GAAG,IAAI;IAqBxG;;;;;OAKG;IACH,gBAAgB,CAAC,iBAAiB,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAgBvF,OAAO,CAAC,UAAU;IAIlB;;;;;OAKG;IACG,eAAe,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC;IA6BrE;;;;;;OAMG;IACH,OAAO,CAAC,mBAAmB;IAI3B;;;;;OAKG;IACH,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAcvC;;;;;OAKG;IACH,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAShC;;;;;OAKG;IACH,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAShC,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,OAAO;IAanD;;OAEG;IACG,eAAe,CAAC,MAAM,EAAE,0BAA0B,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAkB/E,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAInF;;;;OAIG;IACG,kBAAkB,CAAC,MAAM,EAAE,6BAA6B,GAAG,OAAO,CAAC,OAAO,CAAC,sBAAsB,CAAC;IAcxG,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;IAIvD,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAW1E,kBAAkB;IAClB,iBAAiB,CAAC,MAAM,EAAE,uBAAuB,GAAG,IAAI;CAGzD"}
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);
@@ -29,30 +70,248 @@ class Flrp extends sdk_core_1.BaseCoin {
29
70
  getDefaultMultisigType() {
30
71
  return sdk_core_1.multisigTypes.onchain;
31
72
  }
32
- verifyTransaction(params) {
33
- throw new Error('Method 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
+ }
142
+ }
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
+ }
34
161
  }
35
- isWalletAddress(params) {
36
- throw new Error('Method not implemented.');
162
+ getBuilder() {
163
+ return new FlrpLib.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
37
164
  }
38
- parseTransaction(params) {
39
- throw new Error('Method not implemented.');
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;
40
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
+ */
41
207
  generateKeyPair(seed) {
42
- throw new Error('Method not implemented.');
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
+ };
43
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
+ */
44
224
  isValidPub(pub) {
45
- throw new Error('Method not implemented.');
225
+ try {
226
+ new FlrpLib.KeyPair({ pub });
227
+ return true;
228
+ }
229
+ catch (e) {
230
+ return false;
231
+ }
232
+ }
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
+ }
46
247
  }
47
248
  isValidAddress(address) {
48
- throw new Error('Method not implemented.');
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() } };
49
275
  }
50
- signTransaction(params) {
51
- throw new Error('Method not implemented.');
276
+ async parseTransaction(params) {
277
+ return {};
278
+ }
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
+ }
297
+ }
298
+ recoverySignature(message, signature) {
299
+ return FlrpLib.Utils.recoverySignature(this._staticsCoin.network, message, signature);
300
+ }
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);
52
310
  }
311
+ /** @inheritDoc */
53
312
  auditDecryptedKey(params) {
54
- throw new Error('Method not implemented.');
313
+ throw new sdk_core_1.MethodNotImplementedError();
55
314
  }
56
315
  }
57
316
  exports.Flrp = Flrp;
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxycC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mbHJwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLG1EQWM4QjtBQUU5QixNQUFhLElBQUssU0FBUSxtQkFBUTtJQUdoQyxZQUFZLEtBQWdCLEVBQUUsV0FBdUM7UUFDbkUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0RBQW9ELENBQUMsQ0FBQztRQUN4RSxDQUFDO1FBRUQsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7SUFDbEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBZ0IsRUFBRSxXQUF1QztRQUM3RSxPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQsUUFBUTtRQUNOLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUM7SUFDaEMsQ0FBQztJQUNELFNBQVM7UUFDUCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDO0lBQ2xDLENBQUM7SUFDRCxXQUFXO1FBQ1QsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQztJQUNwQyxDQUFDO0lBQ0QsYUFBYTtRQUNYLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsb0JBQW9CO0lBQ3BCLHNCQUFzQjtRQUNwQixPQUFPLHdCQUFhLENBQUMsT0FBTyxDQUFDO0lBQy9CLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxNQUFnQztRQUNoRCxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELGVBQWUsQ0FBQyxNQUFzRDtRQUNwRSxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELGdCQUFnQixDQUFDLE1BQStCO1FBQzlDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsZUFBZSxDQUFDLElBQWE7UUFDM0IsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFDRCxVQUFVLENBQUMsR0FBVztRQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELGNBQWMsQ0FBQyxPQUFlO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsZUFBZSxDQUFDLE1BQThCO1FBQzVDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsaUJBQWlCLENBQUMsTUFBK0I7UUFDL0MsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7Q0FDRjtBQTNERCxvQkEyREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlQ29pbiBhcyBTdGF0aWNzQmFzZUNvaW4sIENvaW5GYW1pbHkgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7XG4gIEF1ZGl0RGVjcnlwdGVkS2V5UGFyYW1zLFxuICBCYXNlQ29pbixcbiAgQml0R29CYXNlLFxuICBLZXlQYWlyLFxuICBNdWx0aXNpZ1R5cGUsXG4gIG11bHRpc2lnVHlwZXMsXG4gIFBhcnNlZFRyYW5zYWN0aW9uLFxuICBQYXJzZVRyYW5zYWN0aW9uT3B0aW9ucyxcbiAgU2lnbmVkVHJhbnNhY3Rpb24sXG4gIFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMsXG4gIFRzc1ZlcmlmeUFkZHJlc3NPcHRpb25zLFxuICBWZXJpZnlBZGRyZXNzT3B0aW9ucyxcbiAgVmVyaWZ5VHJhbnNhY3Rpb25PcHRpb25zLFxufSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5cbmV4cG9ydCBjbGFzcyBGbHJwIGV4dGVuZHMgQmFzZUNvaW4ge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgX3N0YXRpY3NDb2luOiBSZWFkb25seTxTdGF0aWNzQmFzZUNvaW4+O1xuXG4gIGNvbnN0cnVjdG9yKGJpdGdvOiBCaXRHb0Jhc2UsIHN0YXRpY3NDb2luPzogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPikge1xuICAgIHN1cGVyKGJpdGdvKTtcblxuICAgIGlmICghc3RhdGljc0NvaW4pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignbWlzc2luZyByZXF1aXJlZCBjb25zdHJ1Y3RvciBwYXJhbWV0ZXIgc3RhdGljc0NvaW4nKTtcbiAgICB9XG5cbiAgICB0aGlzLl9zdGF0aWNzQ29pbiA9IHN0YXRpY3NDb2luO1xuICB9XG5cbiAgc3RhdGljIGNyZWF0ZUluc3RhbmNlKGJpdGdvOiBCaXRHb0Jhc2UsIHN0YXRpY3NDb2luPzogUmVhZG9ubHk8U3RhdGljc0Jhc2VDb2luPik6IEJhc2VDb2luIHtcbiAgICByZXR1cm4gbmV3IEZscnAoYml0Z28sIHN0YXRpY3NDb2luKTtcbiAgfVxuXG4gIGdldENoYWluKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3N0YXRpY3NDb2luLm5hbWU7XG4gIH1cbiAgZ2V0RmFtaWx5KCk6IENvaW5GYW1pbHkge1xuICAgIHJldHVybiB0aGlzLl9zdGF0aWNzQ29pbi5mYW1pbHk7XG4gIH1cbiAgZ2V0RnVsbE5hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fc3RhdGljc0NvaW4uZnVsbE5hbWU7XG4gIH1cbiAgZ2V0QmFzZUZhY3RvcigpOiBzdHJpbmcgfCBudW1iZXIge1xuICAgIHJldHVybiBNYXRoLnBvdygxMCwgdGhpcy5fc3RhdGljc0NvaW4uZGVjaW1hbFBsYWNlcyk7XG4gIH1cblxuICAvKiogaW5oZXJpdGVkIGRvYyAqL1xuICBnZXREZWZhdWx0TXVsdGlzaWdUeXBlKCk6IE11bHRpc2lnVHlwZSB7XG4gICAgcmV0dXJuIG11bHRpc2lnVHlwZXMub25jaGFpbjtcbiAgfVxuXG4gIHZlcmlmeVRyYW5zYWN0aW9uKHBhcmFtczogVmVyaWZ5VHJhbnNhY3Rpb25PcHRpb25zKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIGlzV2FsbGV0QWRkcmVzcyhwYXJhbXM6IFZlcmlmeUFkZHJlc3NPcHRpb25zIHwgVHNzVmVyaWZ5QWRkcmVzc09wdGlvbnMpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cbiAgcGFyc2VUcmFuc2FjdGlvbihwYXJhbXM6IFBhcnNlVHJhbnNhY3Rpb25PcHRpb25zKTogUHJvbWlzZTxQYXJzZWRUcmFuc2FjdGlvbj4ge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuICBnZW5lcmF0ZUtleVBhaXIoc2VlZD86IEJ1ZmZlcik6IEtleVBhaXIge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuICBpc1ZhbGlkUHViKHB1Yjogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIGlzVmFsaWRBZGRyZXNzKGFkZHJlc3M6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuICBzaWduVHJhbnNhY3Rpb24ocGFyYW1zOiBTaWduVHJhbnNhY3Rpb25PcHRpb25zKTogUHJvbWlzZTxTaWduZWRUcmFuc2FjdGlvbj4ge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuICBhdWRpdERlY3J5cHRlZEtleShwYXJhbXM6IEF1ZGl0RGVjcnlwdGVkS2V5UGFyYW1zKTogdm9pZCB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG59XG4iXX0=
317
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flrp.js","sourceRoot":"","sources":["../../src/flrp.ts"],"names":[],"mappings":"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","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(message: Buffer, signature: Buffer): Buffer {\n    return FlrpLib.Utils.recoverySignature(this._staticsCoin.network as FlareNetwork, message, 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 +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,EASX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,cAAc,EAAE,EAAE,EAAwB,MAAM,SAAS,CAAC;AAEnE,qBAAa,kBAAmB,SAAQ,2BAA2B;IACjE,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,MAAM,CAAS;gBAEX,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;;;;OAKG;IACH,KAAK,CAAC,KAAK,EAAE,cAAc,EAAE,GAAG,IAAI;IAIpC;;;;;OAKG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAOrC;;;;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;IAoE9E,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;IA6EvC;;;OAGG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;CAKnC"}
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,EASX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,cAAc,EAAE,EAAE,EAAwB,MAAM,SAAS,CAAC;AAEnE,qBAAa,kBAAmB,SAAQ,2BAA2B;IACjE,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,MAAM,CAAS;gBAEX,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;;;;OAKG;IACH,KAAK,CAAC,KAAK,EAAE,cAAc,EAAE,GAAG,IAAI;IAIpC;;;;;OAKG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAOrC;;;;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;IAsE9E,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;IA6EvC;;;OAGG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;CAKnC"}
@@ -70,7 +70,9 @@ class ExportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
70
70
  throw new sdk_core_1.BuildTransactionError('Transaction can have one output');
71
71
  }
72
72
  const output = outputs[0];
73
- // TODO validate assetId
73
+ if (Buffer.from(output.assetId.toBytes()).toString('hex') !== this.transaction._assetId) {
74
+ throw new sdk_core_1.BuildTransactionError('AssetID mismatch');
75
+ }
74
76
  // The inputs is not an utxo.
75
77
  // It's expected to have only one input from C-Chain address.
76
78
  const inputs = baseTx.ins;
@@ -183,4 +185,4 @@ class ExportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
183
185
  }
184
186
  }
185
187
  exports.ExportInCTxBuilder = ExportInCTxBuilder;
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ExportInCTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/ExportInCTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildTransactionError, NotSupported, TransactionType } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { AtomicInCTransactionBuilder } from './atomicInCTransactionBuilder';\nimport {\n  evmSerial,\n  UnsignedTx,\n  Credential,\n  BigIntPr,\n  Int,\n  Id,\n  TransferableOutput,\n  Address,\n  TransferOutput,\n  OutputOwners,\n  utils as FlareUtils,\n} from '@flarenetwork/flarejs';\nimport utils from './utils';\nimport { DecodedUtxoObj, Tx, FlareTransactionType } from './iface';\n\nexport class ExportInCTxBuilder extends AtomicInCTransactionBuilder {\n  private _amount: bigint;\n  private _nonce: bigint;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Utxos are not required in Export Tx in C-Chain.\n   * Override utxos to prevent used by throwing a error.\n   *\n   * @param {DecodedUtxoObj[]} value ignored\n   */\n  utxos(value: DecodedUtxoObj[]): this {\n    throw new BuildTransactionError('utxos are not required in Export Tx in C-Chain');\n  }\n\n  /**\n   * Amount is a bigint that specifies the quantity of the asset that this output owns. Must be positive.\n   * The transaction output amount add a fixed fee that will be paid upon import.\n   *\n   * @param {bigint | string} amount The withdrawal amount\n   */\n  amount(amount: bigint | string): this {\n    const amountBigInt = typeof amount === 'string' ? BigInt(amount) : amount;\n    this.validateAmount(amountBigInt);\n    this._amount = amountBigInt;\n    return this;\n  }\n\n  /**\n   * Set the nonce of C-Chain sender address\n   *\n   * @param {number | string} nonce - number that can be only used once\n   */\n  nonce(nonce: number | string): this {\n    const nonceBigInt = BigInt(nonce);\n    this.validateNonce(nonceBigInt);\n    this._nonce = nonceBigInt;\n    return this;\n  }\n\n  /**\n   * Export tx target P wallet.\n   *\n   * @param pAddresses\n   */\n  to(pAddresses: string | string[]): this {\n    const pubKeys = Array.isArray(pAddresses) ? pAddresses : pAddresses.split('~');\n    this.transaction._to = pubKeys.map((addr) => utils.parseAddress(addr));\n    return this;\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Export;\n  }\n\n  initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this {\n    const baseTx = tx as evmSerial.ExportTx;\n    if (!this.verifyTxType(baseTx._type)) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n\n    // The outputs is a multisign P-Chain address result.\n    // It's expected to have only one output to the destination P-Chain address.\n    const outputs = baseTx.exportedOutputs;\n    if (outputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one output');\n    }\n    const output = outputs[0];\n\n    // TODO validate assetId\n\n    // The inputs is not an utxo.\n    // It's expected to have only one input from C-Chain address.\n    const inputs = baseTx.ins;\n    if (inputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one input');\n    }\n    const input = inputs[0];\n\n    const transferOutput = output.output as TransferOutput;\n    const owners = transferOutput.getOwners();\n    this.transaction._to = owners;\n    const inputAmount = input.amount.value();\n    const outputAmount = transferOutput.amount();\n    const fee = inputAmount - outputAmount;\n    this._amount = outputAmount;\n    // Store the actual fee directly (don't subtract fixedFee since buildFlareTransaction doesn't add it back)\n    this.transaction._fee.feeRate = Number(fee);\n    this.transaction._fee.fee = fee.toString();\n    this.transaction._fee.size = 1;\n    this.transaction._fromAddresses = [Buffer.from(input.address.toBytes())];\n    this.transaction._locktime = transferOutput.getLocktime();\n\n    this._nonce = input.nonce.value();\n\n    // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)\n    const credentials = parsedCredentials || [];\n    const hasCredentials = credentials.length > 0;\n\n    // If it's a signed transaction, store the original raw bytes to preserve exact format\n    if (hasCredentials && rawBytes) {\n      this.transaction._rawSignedBytes = rawBytes;\n    }\n\n    // Create proper UnsignedTx wrapper with credentials\n    const fromAddress = new Address(this.transaction._fromAddresses[0]);\n    const addressMap = new FlareUtils.AddressMap([\n      [fromAddress, 0],\n      [fromAddress, 1],\n    ]);\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]);\n\n    const unsignedTx = new UnsignedTx(\n      baseTx,\n      [],\n      addressMaps,\n      credentials.length > 0 ? credentials : [new Credential([utils.createNewSig('')])]\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n    return this;\n  }\n\n  static verifyTxType(txnType: string): boolean {\n    return txnType === FlareTransactionType.EvmExportTx;\n  }\n\n  verifyTxType(txnType: string): boolean {\n    return ExportInCTxBuilder.verifyTxType(txnType);\n  }\n\n  /**\n   * Build the export in C-chain transaction\n   * @protected\n   */\n  protected buildFlareTransaction(): void {\n    if (this.transaction.hasCredentials) return;\n    if (this._amount === undefined) {\n      throw new Error('amount is required');\n    }\n    if (this.transaction._fromAddresses.length !== 1) {\n      throw new Error('sender is one and required');\n    }\n    if (this.transaction._to.length === 0) {\n      throw new Error('to is required');\n    }\n    if (!this.transaction._fee.feeRate) {\n      throw new Error('fee rate is required');\n    }\n    if (this._nonce === undefined) {\n      throw new Error('nonce is required');\n    }\n\n    // For EVM exports, feeRate represents the total fee (baseFee * gasUnits)\n    // Don't add fixedFee as it's already accounted for in the EVM gas model\n    const fee = BigInt(this.transaction._fee.feeRate);\n    this.transaction._fee.fee = fee.toString();\n    this.transaction._fee.size = 1;\n\n    const fromAddressBytes = this.transaction._fromAddresses[0];\n    const fromAddress = new Address(fromAddressBytes);\n    const assetId = utils.flareIdString(this.transaction._assetId);\n    const amount = new BigIntPr(this._amount + fee);\n    const nonce = new BigIntPr(this._nonce);\n    const input = new evmSerial.Input(fromAddress, amount, assetId, nonce);\n    // Map all destination P-chain addresses for multisig support\n    // Sort addresses alphabetically by hex representation (required by Avalanche/Flare protocol)\n    const sortedToAddresses = [...this.transaction._to].sort((a, b) => {\n      const aHex = Buffer.from(a).toString('hex');\n      const bHex = Buffer.from(b).toString('hex');\n      return aHex.localeCompare(bHex);\n    });\n    const toAddresses = sortedToAddresses.map((addr) => new Address(addr));\n\n    const exportTx = new evmSerial.ExportTx(\n      new Int(this.transaction._networkID),\n      utils.flareIdString(this.transaction._blockchainID),\n      new Id(new Uint8Array(this._externalChainId)),\n      [input],\n      [\n        new TransferableOutput(\n          assetId,\n          new TransferOutput(\n            new BigIntPr(this._amount),\n            new OutputOwners(\n              new BigIntPr(this.transaction._locktime),\n              new Int(this.transaction._threshold),\n              toAddresses\n            )\n          )\n        ),\n      ]\n    );\n\n    // Create address maps with proper EVM address format\n    const addressMap = new FlareUtils.AddressMap([\n      [fromAddress, 0],\n      [fromAddress, 1], // Map the same address to both indices since it's used in both places\n    ]);\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]); // Single map is sufficient\n\n    // Create unsigned transaction with proper address mapping\n    const unsignedTx = new UnsignedTx(\n      exportTx,\n      [], // Empty UTXOs array, will be filled during processing\n      addressMaps,\n      [new Credential([utils.createNewSig('')])] // Empty credential for signing\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n  }\n\n  /**\n   * Check the nonce is non-negative.\n   * @param nonce\n   */\n  validateNonce(nonce: bigint): void {\n    if (nonce < BigInt(0)) {\n      throw new BuildTransactionError('Nonce must be greater or equal than 0');\n    }\n  }\n}\n"]}
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ExportInCTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/ExportInCTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildTransactionError, NotSupported, TransactionType } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { AtomicInCTransactionBuilder } from './atomicInCTransactionBuilder';\nimport {\n  evmSerial,\n  UnsignedTx,\n  Credential,\n  BigIntPr,\n  Int,\n  Id,\n  TransferableOutput,\n  Address,\n  TransferOutput,\n  OutputOwners,\n  utils as FlareUtils,\n} from '@flarenetwork/flarejs';\nimport utils from './utils';\nimport { DecodedUtxoObj, Tx, FlareTransactionType } from './iface';\n\nexport class ExportInCTxBuilder extends AtomicInCTransactionBuilder {\n  private _amount: bigint;\n  private _nonce: bigint;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Utxos are not required in Export Tx in C-Chain.\n   * Override utxos to prevent used by throwing a error.\n   *\n   * @param {DecodedUtxoObj[]} value ignored\n   */\n  utxos(value: DecodedUtxoObj[]): this {\n    throw new BuildTransactionError('utxos are not required in Export Tx in C-Chain');\n  }\n\n  /**\n   * Amount is a bigint that specifies the quantity of the asset that this output owns. Must be positive.\n   * The transaction output amount add a fixed fee that will be paid upon import.\n   *\n   * @param {bigint | string} amount The withdrawal amount\n   */\n  amount(amount: bigint | string): this {\n    const amountBigInt = typeof amount === 'string' ? BigInt(amount) : amount;\n    this.validateAmount(amountBigInt);\n    this._amount = amountBigInt;\n    return this;\n  }\n\n  /**\n   * Set the nonce of C-Chain sender address\n   *\n   * @param {number | string} nonce - number that can be only used once\n   */\n  nonce(nonce: number | string): this {\n    const nonceBigInt = BigInt(nonce);\n    this.validateNonce(nonceBigInt);\n    this._nonce = nonceBigInt;\n    return this;\n  }\n\n  /**\n   * Export tx target P wallet.\n   *\n   * @param pAddresses\n   */\n  to(pAddresses: string | string[]): this {\n    const pubKeys = Array.isArray(pAddresses) ? pAddresses : pAddresses.split('~');\n    this.transaction._to = pubKeys.map((addr) => utils.parseAddress(addr));\n    return this;\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Export;\n  }\n\n  initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this {\n    const baseTx = tx as evmSerial.ExportTx;\n    if (!this.verifyTxType(baseTx._type)) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n\n    // The outputs is a multisign P-Chain address result.\n    // It's expected to have only one output to the destination P-Chain address.\n    const outputs = baseTx.exportedOutputs;\n    if (outputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one output');\n    }\n    const output = outputs[0];\n\n    if (Buffer.from(output.assetId.toBytes()).toString('hex') !== this.transaction._assetId) {\n      throw new BuildTransactionError('AssetID mismatch');\n    }\n\n    // The inputs is not an utxo.\n    // It's expected to have only one input from C-Chain address.\n    const inputs = baseTx.ins;\n    if (inputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one input');\n    }\n    const input = inputs[0];\n\n    const transferOutput = output.output as TransferOutput;\n    const owners = transferOutput.getOwners();\n    this.transaction._to = owners;\n    const inputAmount = input.amount.value();\n    const outputAmount = transferOutput.amount();\n    const fee = inputAmount - outputAmount;\n    this._amount = outputAmount;\n    // Store the actual fee directly (don't subtract fixedFee since buildFlareTransaction doesn't add it back)\n    this.transaction._fee.feeRate = Number(fee);\n    this.transaction._fee.fee = fee.toString();\n    this.transaction._fee.size = 1;\n    this.transaction._fromAddresses = [Buffer.from(input.address.toBytes())];\n    this.transaction._locktime = transferOutput.getLocktime();\n\n    this._nonce = input.nonce.value();\n\n    // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)\n    const credentials = parsedCredentials || [];\n    const hasCredentials = credentials.length > 0;\n\n    // If it's a signed transaction, store the original raw bytes to preserve exact format\n    if (hasCredentials && rawBytes) {\n      this.transaction._rawSignedBytes = rawBytes;\n    }\n\n    // Create proper UnsignedTx wrapper with credentials\n    const fromAddress = new Address(this.transaction._fromAddresses[0]);\n    const addressMap = new FlareUtils.AddressMap([\n      [fromAddress, 0],\n      [fromAddress, 1],\n    ]);\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]);\n\n    const unsignedTx = new UnsignedTx(\n      baseTx,\n      [],\n      addressMaps,\n      credentials.length > 0 ? credentials : [new Credential([utils.createNewSig('')])]\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n    return this;\n  }\n\n  static verifyTxType(txnType: string): boolean {\n    return txnType === FlareTransactionType.EvmExportTx;\n  }\n\n  verifyTxType(txnType: string): boolean {\n    return ExportInCTxBuilder.verifyTxType(txnType);\n  }\n\n  /**\n   * Build the export in C-chain transaction\n   * @protected\n   */\n  protected buildFlareTransaction(): void {\n    if (this.transaction.hasCredentials) return;\n    if (this._amount === undefined) {\n      throw new Error('amount is required');\n    }\n    if (this.transaction._fromAddresses.length !== 1) {\n      throw new Error('sender is one and required');\n    }\n    if (this.transaction._to.length === 0) {\n      throw new Error('to is required');\n    }\n    if (!this.transaction._fee.feeRate) {\n      throw new Error('fee rate is required');\n    }\n    if (this._nonce === undefined) {\n      throw new Error('nonce is required');\n    }\n\n    // For EVM exports, feeRate represents the total fee (baseFee * gasUnits)\n    // Don't add fixedFee as it's already accounted for in the EVM gas model\n    const fee = BigInt(this.transaction._fee.feeRate);\n    this.transaction._fee.fee = fee.toString();\n    this.transaction._fee.size = 1;\n\n    const fromAddressBytes = this.transaction._fromAddresses[0];\n    const fromAddress = new Address(fromAddressBytes);\n    const assetId = utils.flareIdString(this.transaction._assetId);\n    const amount = new BigIntPr(this._amount + fee);\n    const nonce = new BigIntPr(this._nonce);\n    const input = new evmSerial.Input(fromAddress, amount, assetId, nonce);\n    // Map all destination P-chain addresses for multisig support\n    // Sort addresses alphabetically by hex representation (required by Avalanche/Flare protocol)\n    const sortedToAddresses = [...this.transaction._to].sort((a, b) => {\n      const aHex = Buffer.from(a).toString('hex');\n      const bHex = Buffer.from(b).toString('hex');\n      return aHex.localeCompare(bHex);\n    });\n    const toAddresses = sortedToAddresses.map((addr) => new Address(addr));\n\n    const exportTx = new evmSerial.ExportTx(\n      new Int(this.transaction._networkID),\n      utils.flareIdString(this.transaction._blockchainID),\n      new Id(new Uint8Array(this._externalChainId)),\n      [input],\n      [\n        new TransferableOutput(\n          assetId,\n          new TransferOutput(\n            new BigIntPr(this._amount),\n            new OutputOwners(\n              new BigIntPr(this.transaction._locktime),\n              new Int(this.transaction._threshold),\n              toAddresses\n            )\n          )\n        ),\n      ]\n    );\n\n    // Create address maps with proper EVM address format\n    const addressMap = new FlareUtils.AddressMap([\n      [fromAddress, 0],\n      [fromAddress, 1], // Map the same address to both indices since it's used in both places\n    ]);\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]); // Single map is sufficient\n\n    // Create unsigned transaction with proper address mapping\n    const unsignedTx = new UnsignedTx(\n      exportTx,\n      [], // Empty UTXOs array, will be filled during processing\n      addressMaps,\n      [new Credential([utils.createNewSig('')])] // Empty credential for signing\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n  }\n\n  /**\n   * Check the nonce is non-negative.\n   * @param nonce\n   */\n  validateNonce(nonce: bigint): void {\n    if (nonce < BigInt(0)) {\n      throw new BuildTransactionError('Nonce must be greater or equal than 0');\n    }\n  }\n}\n"]}
@@ -25,7 +25,7 @@ export declare abstract class AtomicTransactionBuilder extends TransactionBuilde
25
25
  /** @inheritdoc */
26
26
  protected buildImplementation(): Promise<Transaction>;
27
27
  /**
28
- * Builds the avax transaction. transaction field is changed.
28
+ * Builds the Flare transaction. Transaction field is changed.
29
29
  */
30
30
  protected abstract buildFlareTransaction(): void;
31
31
  protected abstract get transactionType(): TransactionType;