@bitgo/sdk-coin-xtz 2.4.13 → 2.6.0

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 (42) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/package.json +8 -7
  3. package/LICENSE +0 -191
  4. package/dist/src/index.d.ts +0 -5
  5. package/dist/src/index.d.ts.map +0 -1
  6. package/dist/src/index.js +0 -44
  7. package/dist/src/lib/address.d.ts +0 -8
  8. package/dist/src/lib/address.d.ts.map +0 -1
  9. package/dist/src/lib/address.js +0 -10
  10. package/dist/src/lib/iface.d.ts +0 -114
  11. package/dist/src/lib/iface.d.ts.map +0 -1
  12. package/dist/src/lib/iface.js +0 -3
  13. package/dist/src/lib/index.d.ts +0 -10
  14. package/dist/src/lib/index.d.ts.map +0 -1
  15. package/dist/src/lib/index.js +0 -51
  16. package/dist/src/lib/keyPair.d.ts +0 -40
  17. package/dist/src/lib/keyPair.d.ts.map +0 -1
  18. package/dist/src/lib/keyPair.js +0 -149
  19. package/dist/src/lib/multisigUtils.d.ts +0 -134
  20. package/dist/src/lib/multisigUtils.d.ts.map +0 -1
  21. package/dist/src/lib/multisigUtils.js +0 -1193
  22. package/dist/src/lib/transaction.d.ts +0 -119
  23. package/dist/src/lib/transaction.d.ts.map +0 -1
  24. package/dist/src/lib/transaction.js +0 -329
  25. package/dist/src/lib/transactionBuilder.d.ts +0 -171
  26. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  27. package/dist/src/lib/transactionBuilder.js +0 -453
  28. package/dist/src/lib/transferBuilder.d.ts +0 -24
  29. package/dist/src/lib/transferBuilder.d.ts.map +0 -1
  30. package/dist/src/lib/transferBuilder.js +0 -64
  31. package/dist/src/lib/utils.d.ts +0 -264
  32. package/dist/src/lib/utils.d.ts.map +0 -1
  33. package/dist/src/lib/utils.js +0 -473
  34. package/dist/src/register.d.ts +0 -3
  35. package/dist/src/register.d.ts.map +0 -1
  36. package/dist/src/register.js +0 -11
  37. package/dist/src/txtz.d.ts +0 -13
  38. package/dist/src/txtz.d.ts.map +0 -1
  39. package/dist/src/txtz.js +0 -14
  40. package/dist/src/xtz.d.ts +0 -82
  41. package/dist/src/xtz.d.ts.map +0 -1
  42. package/dist/src/xtz.js +0 -200
package/dist/src/xtz.d.ts DELETED
@@ -1,82 +0,0 @@
1
- import { BaseCoin, BitGoBase, ParsedTransaction, ParseTransactionOptions, KeyPair as SdkCoreKeyPair, SignedTransaction, TransactionExplanation, VerifyAddressOptions, VerifyTransactionOptions, MultisigType, AuditDecryptedKeyParams } from '@bitgo/sdk-core';
2
- import { CoinFamily, BaseCoin as StaticsBaseCoin } from '@bitgo/statics';
3
- import { Interface } from './lib';
4
- export declare class Xtz extends BaseCoin {
5
- protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;
6
- constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
7
- static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin;
8
- getChain(): string;
9
- getFamily(): CoinFamily;
10
- getFullName(): string;
11
- getBaseFactor(): number;
12
- /** inherited doc */
13
- getDefaultMultisigType(): MultisigType;
14
- /**
15
- * Flag for sending value of 0
16
- * @returns {boolean} True if okay to send 0 value, false otherwise
17
- */
18
- valuelessTransferAllowed(): boolean;
19
- /**
20
- * Xtz supports transfers to consolidate balance from receive address to the wallet contract
21
- */
22
- allowsAccountConsolidations(): boolean;
23
- /**
24
- * Checks if this is a valid base58 or hex address
25
- * @param address
26
- */
27
- isValidAddress(address: string): boolean;
28
- /**
29
- * Generate Tezos key pair - BitGo xpub format
30
- *
31
- * @param seed
32
- * @returns {Object} object with generated xpub, xprv
33
- */
34
- generateKeyPair(seed?: Buffer): SdkCoreKeyPair;
35
- parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;
36
- isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;
37
- verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
38
- /**
39
- * Derive a user key using the chain path of the address
40
- * @param key
41
- * @param path
42
- * @returns {string} derived private key
43
- */
44
- deriveKeyWithPath({ key, path }: {
45
- key: string;
46
- path: string;
47
- }): string;
48
- /**
49
- * Assemble keychain and half-sign prebuilt transaction
50
- *
51
- * @param params
52
- * @param params.txPrebuild {Object} prebuild object returned by platform
53
- * @param params.prv {String} user prv
54
- * @returns Bluebird<SignedTransaction>
55
- */
56
- signTransaction(params: Interface.XtzSignTransactionOptions): Promise<SignedTransaction>;
57
- /**
58
- * Sign message with private key
59
- *
60
- * @param key
61
- * @param message
62
- */
63
- signMessage(key: SdkCoreKeyPair, message: string | Buffer): Promise<Buffer>;
64
- /**
65
- * Builds a funds recovery transaction without BitGo.
66
- * We need to do three queries during this:
67
- * 1) Node query - how much money is in the account
68
- * 2) Build transaction - build our transaction for the amount
69
- * 3) Send signed build - send our signed build to a public node
70
- * @param params
71
- */
72
- recover(params: any): Promise<any>;
73
- /**
74
- * Explain a Tezos transaction from txHex
75
- * @param params
76
- */
77
- explainTransaction(params: Interface.ExplainTransactionOptions): Promise<TransactionExplanation>;
78
- isValidPub(pub: string): boolean;
79
- /** @inheritDoc */
80
- auditDecryptedKey(params: AuditDecryptedKeyParams): void;
81
- }
82
- //# sourceMappingURL=xtz.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"xtz.d.ts","sourceRoot":"","sources":["../../src/xtz.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAER,SAAS,EAET,iBAAiB,EACjB,uBAAuB,EACvB,OAAO,IAAI,cAAc,EACzB,iBAAiB,EACjB,sBAAsB,EACtB,oBAAoB,EACpB,wBAAwB,EACxB,YAAY,EAEZ,uBAAuB,EACxB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,UAAU,EAAS,QAAQ,IAAI,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEhF,OAAO,EAAE,SAAS,EAAsC,MAAM,OAAO,CAAC;AAEtE,qBAAa,GAAI,SAAQ,QAAQ;IAC/B,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;IAIlB,SAAS,IAAI,UAAU;IAIvB,WAAW,IAAI,MAAM;IAIrB,aAAa;IAIb,oBAAoB;IACpB,sBAAsB,IAAI,YAAY;IAItC;;;OAGG;IACH,wBAAwB,IAAI,OAAO;IAInC;;OAEG;IACH,2BAA2B,IAAI,OAAO;IAItC;;;OAGG;IACH,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAOxC;;;;;OAKG;IACH,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,cAAc;IAcxC,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAI7E,eAAe,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC;IAI/D,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAU3E;;;;;OAKG;IACH,iBAAiB,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM;IAMvE;;;;;;;OAOG;IACG,eAAe,CAAC,MAAM,EAAE,SAAS,CAAC,yBAAyB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IA6B9F;;;;;OAKG;IACG,WAAW,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAQjF;;;;;;;OAOG;IACG,OAAO,CAAC,MAAM,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IAIxC;;;OAGG;IACG,kBAAkB,CAAC,MAAM,EAAE,SAAS,CAAC,yBAAyB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IA4BtG,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,kBAAkB;IAClB,iBAAiB,CAAC,MAAM,EAAE,uBAAuB;CAGlD"}
package/dist/src/xtz.js DELETED
@@ -1,200 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Xtz = void 0;
7
- const sdk_core_1 = require("@bitgo/sdk-core");
8
- const secp256k1_1 = require("@bitgo/secp256k1");
9
- const statics_1 = require("@bitgo/statics");
10
- const bignumber_js_1 = __importDefault(require("bignumber.js"));
11
- const lib_1 = require("./lib");
12
- class Xtz extends sdk_core_1.BaseCoin {
13
- constructor(bitgo, staticsCoin) {
14
- super(bitgo);
15
- if (!staticsCoin) {
16
- throw new Error('missing required constructor parameter staticsCoin');
17
- }
18
- this._staticsCoin = staticsCoin;
19
- }
20
- static createInstance(bitgo, staticsCoin) {
21
- return new Xtz(bitgo, staticsCoin);
22
- }
23
- getChain() {
24
- return this._staticsCoin.name;
25
- }
26
- getFamily() {
27
- return this._staticsCoin.family;
28
- }
29
- getFullName() {
30
- return this._staticsCoin.fullName;
31
- }
32
- getBaseFactor() {
33
- return Math.pow(10, this._staticsCoin.decimalPlaces);
34
- }
35
- /** inherited doc */
36
- getDefaultMultisigType() {
37
- return sdk_core_1.multisigTypes.onchain;
38
- }
39
- /**
40
- * Flag for sending value of 0
41
- * @returns {boolean} True if okay to send 0 value, false otherwise
42
- */
43
- valuelessTransferAllowed() {
44
- return true;
45
- }
46
- /**
47
- * Xtz supports transfers to consolidate balance from receive address to the wallet contract
48
- */
49
- allowsAccountConsolidations() {
50
- return true;
51
- }
52
- /**
53
- * Checks if this is a valid base58 or hex address
54
- * @param address
55
- */
56
- isValidAddress(address) {
57
- if (!address) {
58
- return false;
59
- }
60
- return lib_1.Utils.isValidAddress(address);
61
- }
62
- /**
63
- * Generate Tezos key pair - BitGo xpub format
64
- *
65
- * @param seed
66
- * @returns {Object} object with generated xpub, xprv
67
- */
68
- generateKeyPair(seed) {
69
- const keyPair = seed ? new lib_1.KeyPair({ seed }) : new lib_1.KeyPair();
70
- const keys = keyPair.getExtendedKeys();
71
- if (!keys.xprv) {
72
- throw new Error('Missing xprv in key generation.');
73
- }
74
- return {
75
- pub: keys.xpub,
76
- prv: keys.xprv,
77
- };
78
- }
79
- async parseTransaction(params) {
80
- return {};
81
- }
82
- async isWalletAddress(params) {
83
- throw new sdk_core_1.MethodNotImplementedError();
84
- }
85
- async verifyTransaction(params) {
86
- const { txParams } = params;
87
- if (Array.isArray(txParams.recipients) && txParams.recipients.length > 1) {
88
- throw new Error(`${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`);
89
- }
90
- return true;
91
- }
92
- /**
93
- * Derive a user key using the chain path of the address
94
- * @param key
95
- * @param path
96
- * @returns {string} derived private key
97
- */
98
- deriveKeyWithPath({ key, path }) {
99
- const keychain = secp256k1_1.bip32.fromBase58(key);
100
- const derivedKeyNode = keychain.derivePath(path);
101
- return derivedKeyNode.toBase58();
102
- }
103
- /**
104
- * Assemble keychain and half-sign prebuilt transaction
105
- *
106
- * @param params
107
- * @param params.txPrebuild {Object} prebuild object returned by platform
108
- * @param params.prv {String} user prv
109
- * @returns Bluebird<SignedTransaction>
110
- */
111
- async signTransaction(params) {
112
- const txBuilder = new lib_1.TransactionBuilder(statics_1.coins.get(this.getChain()));
113
- txBuilder.from(params.txPrebuild.txHex);
114
- txBuilder.source(params.txPrebuild.source);
115
- if (params.txPrebuild.dataToSign) {
116
- txBuilder.overrideDataToSign({ dataToSign: params.txPrebuild.dataToSign });
117
- }
118
- // The path /0/0/0/0 is used by the wallet base address
119
- // Derive the user key only if the transaction is sent from a receive address
120
- let key;
121
- const { chain, index } = params.txPrebuild.addressInfo;
122
- if (chain === 0 && index === 0) {
123
- key = params.prv;
124
- }
125
- else {
126
- const derivationPath = `0/0/${chain}/${index}`;
127
- key = this.deriveKeyWithPath({ key: params.prv, path: derivationPath });
128
- }
129
- txBuilder.sign({ key });
130
- const transaction = await txBuilder.build();
131
- if (!transaction) {
132
- throw new Error('Invalid messaged passed to signMessage');
133
- }
134
- const response = {
135
- txHex: transaction.toBroadcastFormat(),
136
- };
137
- return transaction.signature.length >= 2 ? response : { halfSigned: response };
138
- }
139
- /**
140
- * Sign message with private key
141
- *
142
- * @param key
143
- * @param message
144
- */
145
- async signMessage(key, message) {
146
- const keyPair = new lib_1.KeyPair({ prv: key.prv });
147
- const messageHex = message instanceof Buffer ? message.toString('hex') : Buffer.from(message, 'utf-8').toString('hex');
148
- const signatureData = await lib_1.Utils.sign(keyPair, messageHex);
149
- return Buffer.from(signatureData.sig);
150
- }
151
- /**
152
- * Builds a funds recovery transaction without BitGo.
153
- * We need to do three queries during this:
154
- * 1) Node query - how much money is in the account
155
- * 2) Build transaction - build our transaction for the amount
156
- * 3) Send signed build - send our signed build to a public node
157
- * @param params
158
- */
159
- async recover(params) {
160
- throw new sdk_core_1.MethodNotImplementedError();
161
- }
162
- /**
163
- * Explain a Tezos transaction from txHex
164
- * @param params
165
- */
166
- async explainTransaction(params) {
167
- const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);
168
- if (!txHex || !params.feeInfo) {
169
- throw new Error('missing explain tx parameters');
170
- }
171
- const txBuilder = new lib_1.TransactionBuilder(statics_1.coins.get(this.getChain()));
172
- // Newer coins can return BaseTransactionBuilderFactory instead of BaseTransactionBuilder
173
- if (!(txBuilder instanceof sdk_core_1.BaseTransactionBuilder)) {
174
- throw new Error('getBuilder() did not return an BaseTransactionBuilder object. Has it been updated?');
175
- }
176
- txBuilder.from(txHex);
177
- const tx = await txBuilder.build();
178
- const displayOrder = ['id', 'outputAmount', 'changeAmount', 'outputs', 'changeOutputs', 'fee'];
179
- return {
180
- displayOrder,
181
- id: tx.id,
182
- outputs: tx.outputs,
183
- outputAmount: tx.outputs
184
- .reduce((accumulator, output) => accumulator.plus(output.value), new bignumber_js_1.default('0'))
185
- .toFixed(0),
186
- changeOutputs: [], // account based does not use change outputs
187
- changeAmount: '0', // account base does not make change
188
- fee: params.feeInfo,
189
- };
190
- }
191
- isValidPub(pub) {
192
- return lib_1.Utils.isValidPublicKey(pub);
193
- }
194
- /** @inheritDoc */
195
- auditDecryptedKey(params) {
196
- throw new sdk_core_1.MethodNotImplementedError();
197
- }
198
- }
199
- exports.Xtz = Xtz;
200
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xtz.js","sourceRoot":"","sources":["../../src/xtz.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BaseTransactionBuilder,\n  BitGoBase,\n  MethodNotImplementedError,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  KeyPair as SdkCoreKeyPair,\n  SignedTransaction,\n  TransactionExplanation,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  AuditDecryptedKeyParams,\n} from '@bitgo/sdk-core';\nimport { bip32 } from '@bitgo/secp256k1';\nimport { CoinFamily, coins, BaseCoin as StaticsBaseCoin } from '@bitgo/statics';\nimport BigNumber from 'bignumber.js';\nimport { Interface, KeyPair, TransactionBuilder, Utils } from './lib';\n\nexport class Xtz 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 Xtz(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  getBaseFactor() {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  /**\n   * Flag for sending value of 0\n   * @returns {boolean} True if okay to send 0 value, false otherwise\n   */\n  valuelessTransferAllowed(): boolean {\n    return true;\n  }\n\n  /**\n   * Xtz supports transfers to consolidate balance from receive address to the wallet contract\n   */\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  /**\n   * Checks if this is a valid base58 or hex address\n   * @param address\n   */\n  isValidAddress(address: string): boolean {\n    if (!address) {\n      return false;\n    }\n    return Utils.isValidAddress(address);\n  }\n\n  /**\n   * Generate Tezos key pair - BitGo xpub format\n   *\n   * @param seed\n   * @returns {Object} object with generated xpub, xprv\n   */\n  generateKeyPair(seed?: Buffer): SdkCoreKeyPair {\n    const keyPair = seed ? new KeyPair({ seed }) : new KeyPair();\n    const keys = keyPair.getExtendedKeys();\n\n    if (!keys.xprv) {\n      throw new Error('Missing xprv in key generation.');\n    }\n\n    return {\n      pub: keys.xpub,\n      prv: keys.xprv,\n    };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    throw new MethodNotImplementedError();\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txParams } = params;\n    if (Array.isArray(txParams.recipients) && txParams.recipients.length > 1) {\n      throw new Error(\n        `${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`\n      );\n    }\n    return true;\n  }\n\n  /**\n   * Derive a user key using the chain path of the address\n   * @param key\n   * @param path\n   * @returns {string} derived private key\n   */\n  deriveKeyWithPath({ key, path }: { key: string; path: string }): string {\n    const keychain = bip32.fromBase58(key);\n    const derivedKeyNode = keychain.derivePath(path);\n    return derivedKeyNode.toBase58();\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param params\n   * @param params.txPrebuild {Object} prebuild object returned by platform\n   * @param params.prv {String} user prv\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: Interface.XtzSignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n    txBuilder.from(params.txPrebuild.txHex);\n    txBuilder.source(params.txPrebuild.source);\n    if (params.txPrebuild.dataToSign) {\n      txBuilder.overrideDataToSign({ dataToSign: params.txPrebuild.dataToSign });\n    }\n    // The path /0/0/0/0 is used by the wallet base address\n    // Derive the user key only if the transaction is sent from a receive address\n    let key;\n    const { chain, index } = params.txPrebuild.addressInfo;\n    if (chain === 0 && index === 0) {\n      key = params.prv;\n    } else {\n      const derivationPath = `0/0/${chain}/${index}`;\n      key = this.deriveKeyWithPath({ key: params.prv, path: derivationPath });\n    }\n    txBuilder.sign({ key });\n\n    const transaction = await txBuilder.build();\n    if (!transaction) {\n      throw new Error('Invalid messaged passed to signMessage');\n    }\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: SdkCoreKeyPair, message: string | Buffer): Promise<Buffer> {\n    const keyPair = new KeyPair({ prv: key.prv });\n    const messageHex =\n      message instanceof Buffer ? message.toString('hex') : Buffer.from(message as string, 'utf-8').toString('hex');\n    const signatureData = await Utils.sign(keyPair, messageHex);\n    return Buffer.from(signatureData.sig);\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo.\n   * We need to do three queries during this:\n   * 1) Node query - how much money is in the account\n   * 2) Build transaction - build our transaction for the amount\n   * 3) Send signed build - send our signed build to a public node\n   * @param params\n   */\n  async recover(params: any): Promise<any> {\n    throw new MethodNotImplementedError();\n  }\n\n  /**\n   * Explain a Tezos transaction from txHex\n   * @param params\n   */\n  async explainTransaction(params: Interface.ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n    // Newer coins can return BaseTransactionBuilderFactory instead of BaseTransactionBuilder\n    if (!(txBuilder instanceof BaseTransactionBuilder)) {\n      throw new Error('getBuilder() did not return an BaseTransactionBuilder object. Has it been updated?');\n    }\n    txBuilder.from(txHex);\n    const tx = await txBuilder.build();\n\n    const displayOrder = ['id', 'outputAmount', 'changeAmount', 'outputs', 'changeOutputs', 'fee'];\n\n    return {\n      displayOrder,\n      id: tx.id,\n      outputs: tx.outputs,\n      outputAmount: tx.outputs\n        .reduce((accumulator, output) => accumulator.plus(output.value), new BigNumber('0'))\n        .toFixed(0),\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      fee: params.feeInfo,\n    } as any;\n  }\n\n  isValidPub(pub: string): boolean {\n    return Utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey(params: AuditDecryptedKeyParams) {\n    throw new MethodNotImplementedError();\n  }\n}\n"]}