@bitgo-beta/sdk-core 8.2.1-beta.7 → 8.2.1-beta.71
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.
- package/CHANGELOG.md +98 -0
- package/dist/src/account-lib/baseCoin/enum.d.ts +3 -1
- package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
- package/dist/src/account-lib/baseCoin/enum.js +5 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +38 -12
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +555 -178
- package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts +2 -2
- package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.js +3 -3
- package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +92 -155
- package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
- package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +0 -3
- package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
- package/dist/src/account-lib/util/crypto.d.ts +5 -25
- package/dist/src/account-lib/util/crypto.d.ts.map +1 -1
- package/dist/src/account-lib/util/crypto.js +10 -55
- package/dist/src/bitgo/baseCoin/baseCoin.d.ts +16 -0
- package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
- package/dist/src/bitgo/baseCoin/baseCoin.js +15 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +13 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
- package/dist/src/bitgo/enterprise/enterprise.d.ts +3 -3
- package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/enterprise.js +7 -6
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts +3 -3
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
- package/dist/src/bitgo/environments.d.ts +6 -0
- package/dist/src/bitgo/environments.d.ts.map +1 -1
- package/dist/src/bitgo/environments.js +15 -3
- package/dist/src/bitgo/keychain/iKeychains.d.ts +1 -0
- package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/iKeychains.js +1 -1
- package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/keychains.js +30 -24
- package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
- package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
- package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +1 -0
- package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
- package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
- package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
- package/dist/src/bitgo/pendingApproval/pendingApproval.js +12 -1
- package/dist/src/bitgo/staking/iStakingWallet.d.ts +11 -1
- package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
- package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
- package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
- package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
- package/dist/src/bitgo/staking/stakingWallet.js +9 -1
- package/dist/src/bitgo/tss/common.d.ts +16 -6
- package/dist/src/bitgo/tss/common.d.ts.map +1 -1
- package/dist/src/bitgo/tss/common.js +26 -11
- package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +11 -8
- package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/tss/ecdsa/ecdsa.js +36 -33
- package/dist/src/bitgo/tss/ecdsa/types.d.ts +2 -2
- package/dist/src/bitgo/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/bitgo/tss/ecdsa/types.js +1 -1
- package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +4 -3
- package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/tss/eddsa/eddsa.js +16 -5
- package/dist/src/bitgo/tss/types.d.ts +4 -0
- package/dist/src/bitgo/tss/types.d.ts.map +1 -1
- package/dist/src/bitgo/tss/types.js +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +38 -12
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.js +28 -9
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts +48 -8
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTypes.js +11 -2
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +10 -8
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +65 -62
- package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +4 -3
- package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/types.js +1 -1
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +76 -22
- package/dist/src/bitgo/wallet/iWallet.d.ts +2 -1
- package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/iWallet.js +1 -1
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +22 -8
- package/dist/src/openssl/index.d.ts +4 -1
- package/dist/src/openssl/index.d.ts.map +1 -1
- package/dist/src/openssl/index.js +7 -12
- package/dist/tsconfig.tsbuildinfo +1 -8264
- package/package.json +6 -7
- package/dist/src/openssl/openssl.d.ts +0 -12
- package/dist/src/openssl/openssl.d.ts.map +0 -1
- package/dist/src/openssl/openssl.js +0 -48
- package/dist/src/openssl/opensslbytes.d.ts +0 -4
- package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
- package/dist/src/openssl/opensslbytes.js +0 -20
|
@@ -22,13 +22,21 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
22
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
-
exports.
|
|
25
|
+
exports.toUint8Array = exports.isBase58 = exports.toHex = exports.isValidBLSPublicKey = exports.isValidBLSPrivateKey = exports.isValidEd25519PublicKey = exports.isValidEd25519SecretKey = exports.isValidEd25519Seed = exports.isValidPrv = exports.isValidPub = exports.isValidXprv = exports.isValidXpub = exports.rawPrvToExtendedKeys = exports.xprvToRawPrv = exports.xpubToCompressedPub = exports.xpubToUncompressedPub = exports.bigIntToHex = exports.hexToBigInt = exports.convertBigIntArrToHexArr = exports.convertHexArrToBigIntArr = void 0;
|
|
26
26
|
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
27
27
|
const nacl = __importStar(require("tweetnacl"));
|
|
28
28
|
const hex = __importStar(require("@stablelib/hex"));
|
|
29
29
|
const bls = __importStar(require("noble-bls12-381"));
|
|
30
30
|
const strip_hex_prefix_1 = __importDefault(require("strip-hex-prefix"));
|
|
31
31
|
const bs58_1 = __importDefault(require("bs58"));
|
|
32
|
+
/**
|
|
33
|
+
* @deprecated - use @bitgo-beta/sdk-lib-mpc instead
|
|
34
|
+
*/
|
|
35
|
+
var sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
36
|
+
Object.defineProperty(exports, "convertHexArrToBigIntArr", { enumerable: true, get: function () { return sdk_lib_mpc_1.convertHexArrToBigIntArr; } });
|
|
37
|
+
Object.defineProperty(exports, "convertBigIntArrToHexArr", { enumerable: true, get: function () { return sdk_lib_mpc_1.convertBigIntArrToHexArr; } });
|
|
38
|
+
Object.defineProperty(exports, "hexToBigInt", { enumerable: true, get: function () { return sdk_lib_mpc_1.hexToBigInt; } });
|
|
39
|
+
Object.defineProperty(exports, "bigIntToHex", { enumerable: true, get: function () { return sdk_lib_mpc_1.bigIntToHex; } });
|
|
32
40
|
/**
|
|
33
41
|
* @param xpub - a base-58 encoded extended public key (BIP32)
|
|
34
42
|
* @param compressed flag to determine if return key should be compressed/uncompressed
|
|
@@ -244,39 +252,6 @@ function toHex(buffer) {
|
|
|
244
252
|
return hex.encode(buffer, true);
|
|
245
253
|
}
|
|
246
254
|
exports.toHex = toHex;
|
|
247
|
-
/**
|
|
248
|
-
* Returns an hex string of the given bigint
|
|
249
|
-
*
|
|
250
|
-
* @param {bigint} bigint - the bigint to be converted to hex
|
|
251
|
-
* @returns {string} - the hex value
|
|
252
|
-
*/
|
|
253
|
-
function bigIntToHex(bigint, hexLength) {
|
|
254
|
-
let hex = bigint.toString(16);
|
|
255
|
-
hex = '0'.slice(0, hex.length % 2) + hex;
|
|
256
|
-
if (hexLength) {
|
|
257
|
-
hex = hex.padStart(hexLength, '0');
|
|
258
|
-
}
|
|
259
|
-
return hex;
|
|
260
|
-
}
|
|
261
|
-
exports.bigIntToHex = bigIntToHex;
|
|
262
|
-
/**
|
|
263
|
-
* Returns a BigInt value from hex
|
|
264
|
-
*
|
|
265
|
-
* @param {string} hex - hex value to be converted to bigint
|
|
266
|
-
* @returns {bigint} - bigint representation of the hex value
|
|
267
|
-
*/
|
|
268
|
-
function hexToBigInt(hex) {
|
|
269
|
-
// Strangely bigint.toString(16) gives a hex string without 0x
|
|
270
|
-
// but it won't accept the same string without 0x to convert
|
|
271
|
-
// to a bigint (BigInt(hex string)). So have to introduce this
|
|
272
|
-
// check to convert to add 0x in case if hex string
|
|
273
|
-
// doesn't have it.
|
|
274
|
-
if (hex.slice(0, 2) === '0x') {
|
|
275
|
-
return BigInt(hex);
|
|
276
|
-
}
|
|
277
|
-
return BigInt('0x' + hex);
|
|
278
|
-
}
|
|
279
|
-
exports.hexToBigInt = hexToBigInt;
|
|
280
255
|
/**
|
|
281
256
|
* Check if base58 decoded string is equale to length
|
|
282
257
|
*
|
|
@@ -303,24 +278,4 @@ function toUint8Array(str) {
|
|
|
303
278
|
return hex.decode(str);
|
|
304
279
|
}
|
|
305
280
|
exports.toUint8Array = toUint8Array;
|
|
306
|
-
/**
|
|
307
|
-
* Returns a bigint array from a hex string array
|
|
308
|
-
* @param values
|
|
309
|
-
*/
|
|
310
|
-
function convertHexArrToBigIntArr(values) {
|
|
311
|
-
return values.map((value) => {
|
|
312
|
-
return hexToBigInt(value);
|
|
313
|
-
});
|
|
314
|
-
}
|
|
315
|
-
exports.convertHexArrToBigIntArr = convertHexArrToBigIntArr;
|
|
316
|
-
/**
|
|
317
|
-
* Returns a hex string array from a bigint array
|
|
318
|
-
* @param values
|
|
319
|
-
*/
|
|
320
|
-
function convertBigIntArrToHexArr(values) {
|
|
321
|
-
return values.map((value) => {
|
|
322
|
-
return bigIntToHex(value);
|
|
323
|
-
});
|
|
324
|
-
}
|
|
325
|
-
exports.convertBigIntArrToHexArr = convertBigIntArrToHexArr;
|
|
326
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../../../src/account-lib/util/crypto.ts"],"names":[],"mappings":"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","sourcesContent":["import { bip32, ECPair, networks } from '@bitgo-beta/utxo-lib';\nimport * as nacl from 'tweetnacl';\nimport * as hex from '@stablelib/hex';\nimport * as bls from 'noble-bls12-381';\nimport stripHexPrefix from 'strip-hex-prefix';\nimport { ExtendedKeys } from '../baseCoin/iface';\nimport bs58 from 'bs58';\n\n/**\n * @param xpub - a base-58 encoded extended public key (BIP32)\n * @param compressed flag to determine if return key should be compressed/uncompressed\n * @return a compressed or an uncompresseed public key in hexadecimal\n */\nfunction xPubToPub(xpub: string, compressed: boolean) {\n  if (!isValidXpub(xpub)) {\n    throw new Error('invalid xpub');\n  }\n  return ECPair.fromPublicKey(bip32.fromBase58(xpub, networks.bitcoin).publicKey, {\n    compressed,\n  }).publicKey.toString('hex');\n}\n\n/**\n * @param {string} xpub - a base-58 encoded extended public key (BIP32)\n * @returns {string} the uncompressed public key in hexadecimal\n */\nexport function xpubToUncompressedPub(xpub: string): string {\n  return xPubToPub(xpub, false);\n}\n\n/**\n * @param {string} xpub - a base-58 encoded extended public key (BIP32)\n * @returns {string} the uncompressed public key in hexadecimal\n */\nexport function xpubToCompressedPub(xpub: string): string {\n  return xPubToPub(xpub, true);\n}\n\n/**\n * @param {string} xprv - base58-encoded extended private key (BIP32)\n * @returns {string} the hex-encoded raw private key\n */\nexport function xprvToRawPrv(xprv: string): string {\n  if (!isValidXprv(xprv)) {\n    throw new Error('invalid xprv');\n  }\n\n  const { privateKey } = bip32.fromBase58(xprv, networks.bitcoin);\n  if (!privateKey) {\n    throw new Error('invalid xprv');\n  }\n  return privateKey.toString('hex');\n}\n\n/**\n * @param {string} prv - Private key in hex format to get the extended keys for\n * @returns {ExtendedKeys} xprv and xpub in string format\n */\nexport function rawPrvToExtendedKeys(prv: string): ExtendedKeys {\n  const hd = bip32.fromPrivateKey(Buffer.from(prv, 'hex'), Buffer.alloc(32));\n  return {\n    xprv: hd.toBase58(),\n    xpub: hd.neutered().toBase58(),\n  };\n}\n\n/**\n * Whether the input is a valid BIP32 xpub or not\n *\n * @param xpub\n */\nexport function isValidXpub(xpub: string): boolean {\n  if (xpub.substr(0, 4) !== 'xpub') {\n    // check for xpub formats we don't support, such as tpub\n    return false;\n  }\n  try {\n    bip32.fromBase58(xpub, networks.bitcoin);\n  } catch (err) {\n    return false;\n  }\n  // if HD generation didn't throw, it is a valid xpub\n  return true;\n}\n\n/**\n * Whether the input is a valid BIP32 xprv or not\n *\n * @param xprv\n */\nexport function isValidXprv(xprv: string): boolean {\n  if (xprv.substr(0, 4) !== 'xprv') {\n    // check for xprv formats we don't support\n    return false;\n  }\n  try {\n    bip32.fromBase58(xprv, networks.bitcoin);\n  } catch (err) {\n    return false;\n  }\n  // if HD generation didn't throw, it is a valid xprv\n  return true;\n}\n\n/**\n * Whether the input is a valid secp256k1 public key\n *\n * @param pub\n */\nexport function isValidPub(pub: string): boolean {\n  try {\n    ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n  } catch (e) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Whether the input is a valid secp256k1 private key\n *\n * @param prv\n */\nexport function isValidPrv(prv: string): boolean {\n  try {\n    ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));\n  } catch (e) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Whether the input is a valid ed25519 private key\n *\n * @param {string} prv A hexadecimal private key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519Seed(prv: string): boolean {\n  try {\n    const decodedPrv = toUint8Array(prv);\n    return decodedPrv.length === nacl.sign.seedLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid ed25519 private key\n *\n * @param {string} prv A hexadecimal private key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519SecretKey(prv: string): boolean {\n  try {\n    const decodedPrv = toUint8Array(prv);\n    return decodedPrv.length === nacl.sign.secretKeyLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid ed25519 public key\n *\n * @param {string} pub A hexadecimal public key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519PublicKey(pub: string): boolean {\n  try {\n    const decodedPub = new Uint8Array(Buffer.from(pub, 'hex'));\n    return decodedPub.length === nacl.sign.publicKeyLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid BLS private key\n *\n * @param {string} prv a private key to validate\n * @returns {boolean} Whether the input is a valid private key or not\n */\nexport function isValidBLSPrivateKey(prv: string): boolean {\n  try {\n    return bls.Fr.isValid(BigInt('0x' + prv));\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether input is a valid BLS public key\n *\n * @param {string} pub the public key to validate\n * @returns {boolean} Whether input is a valid public key or not\n */\nexport function isValidBLSPublicKey(pub: string): boolean {\n  try {\n    bls.PointG1.fromCompressedHex(stripHexPrefix(pub)).assertValidity();\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns an hex string of the given buffer\n *\n * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex\n * @returns {string} - the hex value\n */\nexport function toHex(buffer: Buffer | Uint8Array): string {\n  return hex.encode(buffer, true);\n}\n\n/**\n * Returns an hex string of the given bigint\n *\n * @param {bigint} bigint - the bigint to be converted to hex\n * @returns {string} - the hex value\n */\nexport function bigIntToHex(bigint: bigint, hexLength?: number): string {\n  let hex = bigint.toString(16);\n  hex = '0'.slice(0, hex.length % 2) + hex;\n  if (hexLength) {\n    hex = hex.padStart(hexLength, '0');\n  }\n  return hex;\n}\n\n/**\n * Returns a BigInt value from hex\n *\n * @param {string} hex - hex value to be converted to bigint\n * @returns {bigint} - bigint representation of the hex value\n */\nexport function hexToBigInt(hex: string): bigint {\n  // Strangely bigint.toString(16) gives a hex string without 0x\n  // but it won't accept the same string without 0x to convert\n  // to a bigint (BigInt(hex string)). So have to introduce this\n  // check to convert to add 0x in case if hex string\n  // doesn't have it.\n  if (hex.slice(0, 2) === '0x') {\n    return BigInt(hex);\n  }\n  return BigInt('0x' + hex);\n}\n\n/**\n * Check if base58 decoded string is equale to length\n *\n * @param {string} value - string to be checked\n * @param {number} length - expected decoded length\n * @return {boolean} if the string can decoded as base58 and match the expected length\n */\n\nexport function isBase58(value: string, length: number): boolean {\n  try {\n    return !!value && bs58.decode(value).length === length;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns a Uint8Array of the given hex string\n *\n * @param {string} str - the hex string to be converted\n * @returns {string} - the Uint8Array value\n */\nexport function toUint8Array(str: string): Uint8Array {\n  return hex.decode(str);\n}\n\n/**\n * Returns a bigint array from a hex string array\n * @param values\n */\nexport function convertHexArrToBigIntArr(values: string[]): bigint[] {\n  return values.map((value) => {\n    return hexToBigInt(value);\n  });\n}\n\n/**\n * Returns a hex string array from a bigint array\n * @param values\n */\nexport function convertBigIntArrToHexArr(values: bigint[]): string[] {\n  return values.map((value) => {\n    return bigIntToHex(value);\n  });\n}\n"]}
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../../../src/account-lib/util/crypto.ts"],"names":[],"mappings":"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","sourcesContent":["import { bip32, ECPair, networks } from '@bitgo-beta/utxo-lib';\nimport * as nacl from 'tweetnacl';\nimport * as hex from '@stablelib/hex';\nimport * as bls from 'noble-bls12-381';\nimport stripHexPrefix from 'strip-hex-prefix';\nimport { ExtendedKeys } from '../baseCoin';\nimport bs58 from 'bs58';\n\n/**\n * @deprecated - use @bitgo-beta/sdk-lib-mpc instead\n */\nexport { convertHexArrToBigIntArr, convertBigIntArrToHexArr, hexToBigInt, bigIntToHex } from '@bitgo-beta/sdk-lib-mpc';\n\n/**\n * @param xpub - a base-58 encoded extended public key (BIP32)\n * @param compressed flag to determine if return key should be compressed/uncompressed\n * @return a compressed or an uncompresseed public key in hexadecimal\n */\nfunction xPubToPub(xpub: string, compressed: boolean) {\n  if (!isValidXpub(xpub)) {\n    throw new Error('invalid xpub');\n  }\n  return ECPair.fromPublicKey(bip32.fromBase58(xpub, networks.bitcoin).publicKey, {\n    compressed,\n  }).publicKey.toString('hex');\n}\n\n/**\n * @param {string} xpub - a base-58 encoded extended public key (BIP32)\n * @returns {string} the uncompressed public key in hexadecimal\n */\nexport function xpubToUncompressedPub(xpub: string): string {\n  return xPubToPub(xpub, false);\n}\n\n/**\n * @param {string} xpub - a base-58 encoded extended public key (BIP32)\n * @returns {string} the uncompressed public key in hexadecimal\n */\nexport function xpubToCompressedPub(xpub: string): string {\n  return xPubToPub(xpub, true);\n}\n\n/**\n * @param {string} xprv - base58-encoded extended private key (BIP32)\n * @returns {string} the hex-encoded raw private key\n */\nexport function xprvToRawPrv(xprv: string): string {\n  if (!isValidXprv(xprv)) {\n    throw new Error('invalid xprv');\n  }\n\n  const { privateKey } = bip32.fromBase58(xprv, networks.bitcoin);\n  if (!privateKey) {\n    throw new Error('invalid xprv');\n  }\n  return privateKey.toString('hex');\n}\n\n/**\n * @param {string} prv - Private key in hex format to get the extended keys for\n * @returns {ExtendedKeys} xprv and xpub in string format\n */\nexport function rawPrvToExtendedKeys(prv: string): ExtendedKeys {\n  const hd = bip32.fromPrivateKey(Buffer.from(prv, 'hex'), Buffer.alloc(32));\n  return {\n    xprv: hd.toBase58(),\n    xpub: hd.neutered().toBase58(),\n  };\n}\n\n/**\n * Whether the input is a valid BIP32 xpub or not\n *\n * @param xpub\n */\nexport function isValidXpub(xpub: string): boolean {\n  if (xpub.substr(0, 4) !== 'xpub') {\n    // check for xpub formats we don't support, such as tpub\n    return false;\n  }\n  try {\n    bip32.fromBase58(xpub, networks.bitcoin);\n  } catch (err) {\n    return false;\n  }\n  // if HD generation didn't throw, it is a valid xpub\n  return true;\n}\n\n/**\n * Whether the input is a valid BIP32 xprv or not\n *\n * @param xprv\n */\nexport function isValidXprv(xprv: string): boolean {\n  if (xprv.substr(0, 4) !== 'xprv') {\n    // check for xprv formats we don't support\n    return false;\n  }\n  try {\n    bip32.fromBase58(xprv, networks.bitcoin);\n  } catch (err) {\n    return false;\n  }\n  // if HD generation didn't throw, it is a valid xprv\n  return true;\n}\n\n/**\n * Whether the input is a valid secp256k1 public key\n *\n * @param pub\n */\nexport function isValidPub(pub: string): boolean {\n  try {\n    ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n  } catch (e) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Whether the input is a valid secp256k1 private key\n *\n * @param prv\n */\nexport function isValidPrv(prv: string): boolean {\n  try {\n    ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));\n  } catch (e) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Whether the input is a valid ed25519 private key\n *\n * @param {string} prv A hexadecimal private key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519Seed(prv: string): boolean {\n  try {\n    const decodedPrv = toUint8Array(prv);\n    return decodedPrv.length === nacl.sign.seedLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid ed25519 private key\n *\n * @param {string} prv A hexadecimal private key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519SecretKey(prv: string): boolean {\n  try {\n    const decodedPrv = toUint8Array(prv);\n    return decodedPrv.length === nacl.sign.secretKeyLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid ed25519 public key\n *\n * @param {string} pub A hexadecimal public key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519PublicKey(pub: string): boolean {\n  try {\n    const decodedPub = new Uint8Array(Buffer.from(pub, 'hex'));\n    return decodedPub.length === nacl.sign.publicKeyLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid BLS private key\n *\n * @param {string} prv a private key to validate\n * @returns {boolean} Whether the input is a valid private key or not\n */\nexport function isValidBLSPrivateKey(prv: string): boolean {\n  try {\n    return bls.Fr.isValid(BigInt('0x' + prv));\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether input is a valid BLS public key\n *\n * @param {string} pub the public key to validate\n * @returns {boolean} Whether input is a valid public key or not\n */\nexport function isValidBLSPublicKey(pub: string): boolean {\n  try {\n    bls.PointG1.fromCompressedHex(stripHexPrefix(pub)).assertValidity();\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns an hex string of the given buffer\n *\n * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex\n * @returns {string} - the hex value\n */\nexport function toHex(buffer: Buffer | Uint8Array): string {\n  return hex.encode(buffer, true);\n}\n\n/**\n * Check if base58 decoded string is equale to length\n *\n * @param {string} value - string to be checked\n * @param {number} length - expected decoded length\n * @return {boolean} if the string can decoded as base58 and match the expected length\n */\n\nexport function isBase58(value: string, length: number): boolean {\n  try {\n    return !!value && bs58.decode(value).length === length;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns a Uint8Array of the given hex string\n *\n * @param {string} str - the hex string to be converted\n * @returns {string} - the Uint8Array value\n */\nexport function toUint8Array(str: string): Uint8Array {\n  return hex.decode(str);\n}\n"]}
|
|
@@ -110,6 +110,22 @@ export declare abstract class BaseCoin implements IBaseCoin {
|
|
|
110
110
|
signMessage(key: {
|
|
111
111
|
prv: string;
|
|
112
112
|
}, message: string): Promise<Buffer>;
|
|
113
|
+
/**
|
|
114
|
+
* Create signatures for the backup and bitgo keys using the user key.
|
|
115
|
+
* We can verify the signatures when fetching the keys from wallet-platform later.
|
|
116
|
+
* Currently only `AbstractUtxoCoin` implements and uses the complementary `verifyKeySignature` method.
|
|
117
|
+
* @param prv - the user private key
|
|
118
|
+
* @param backupKeychain - contains the backup public key
|
|
119
|
+
* @param bitgoKeychain - contains the bitgo public key
|
|
120
|
+
*/
|
|
121
|
+
createKeySignatures(prv: string, backupKeychain: {
|
|
122
|
+
pub: string;
|
|
123
|
+
}, bitgoKeychain: {
|
|
124
|
+
pub: string;
|
|
125
|
+
}): Promise<{
|
|
126
|
+
backup: string;
|
|
127
|
+
bitgo: string;
|
|
128
|
+
}>;
|
|
113
129
|
/**
|
|
114
130
|
* Decompose a raw transaction into useful information.
|
|
115
131
|
* @param options - coin-specific
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"baseCoin.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/baseCoin.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"baseCoin.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/baseCoin.ts"],"names":[],"mappings":"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"}
|
|
@@ -168,6 +168,20 @@ class BaseCoin {
|
|
|
168
168
|
async signMessage(key, message) {
|
|
169
169
|
return bip32util_1.signMessage(message, utxo_lib_1.bip32.fromBase58(key.prv), utxolib.networks.bitcoin);
|
|
170
170
|
}
|
|
171
|
+
/**
|
|
172
|
+
* Create signatures for the backup and bitgo keys using the user key.
|
|
173
|
+
* We can verify the signatures when fetching the keys from wallet-platform later.
|
|
174
|
+
* Currently only `AbstractUtxoCoin` implements and uses the complementary `verifyKeySignature` method.
|
|
175
|
+
* @param prv - the user private key
|
|
176
|
+
* @param backupKeychain - contains the backup public key
|
|
177
|
+
* @param bitgoKeychain - contains the bitgo public key
|
|
178
|
+
*/
|
|
179
|
+
async createKeySignatures(prv, backupKeychain, bitgoKeychain) {
|
|
180
|
+
return {
|
|
181
|
+
backup: (await this.signMessage({ prv }, backupKeychain.pub)).toString('hex'),
|
|
182
|
+
bitgo: (await this.signMessage({ prv }, bitgoKeychain.pub)).toString('hex'),
|
|
183
|
+
};
|
|
184
|
+
}
|
|
171
185
|
/**
|
|
172
186
|
* Decompose a raw transaction into useful information.
|
|
173
187
|
* @param options - coin-specific
|
|
@@ -346,4 +360,4 @@ class BaseCoin {
|
|
|
346
360
|
}
|
|
347
361
|
exports.BaseCoin = BaseCoin;
|
|
348
362
|
BaseCoin._coinTokenPatternSeparator = ':';
|
|
349
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseCoin.js","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/baseCoin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as crypto from 'crypto';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { BigNumber } from 'bignumber.js';\n\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { InitiateRecoveryOptions } from '../recovery';\nimport { signMessage } from '../bip32util';\nimport { NotImplementedError } from '../../account-lib';\nimport { BitGoBase } from '../bitgoBase';\nimport { Enterprises } from '../enterprise';\nimport { Keychains, KeyIndices } from '../keychain';\nimport { Markets } from '../market';\nimport { PendingApprovals } from '../pendingApproval';\nimport { Wallets, IWallet, Wallet } from '../wallet';\nimport { Webhooks } from '../webhook';\nimport {\n  ExtraPrebuildParamsOptions,\n  FeeEstimateOptions,\n  IBaseCoin,\n  ParsedTransaction,\n  ITransactionExplanation,\n  KeychainsTriplet,\n  KeyPair,\n  MPCAlgorithm,\n  ParseTransactionOptions,\n  PrecreateBitGoOptions,\n  PresignTransactionOptions,\n  RecoverTokenTransaction,\n  RecoverWalletTokenOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  SupplementGenerateWalletOptions,\n  TokenEnablementConfig,\n  TransactionPrebuild,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from './iBaseCoin';\nimport { IInscriptionBuilder } from '../inscriptionBuilder';\nimport { Hash } from 'crypto';\n\nexport abstract class BaseCoin implements IBaseCoin {\n  protected readonly bitgo: BitGoBase;\n  protected readonly _url: string;\n  protected readonly _enterprises: Enterprises;\n  protected readonly _wallets: Wallets;\n  protected readonly _keychains: Keychains;\n  protected readonly _webhooks: Webhooks;\n  protected readonly _pendingApprovals: PendingApprovals;\n  protected readonly _markets: Markets;\n  protected static readonly _coinTokenPatternSeparator = ':';\n\n  protected constructor(bitgo: BitGoBase) {\n    this.bitgo = bitgo;\n    this._url = this.bitgo.url('/', 2);\n    this._wallets = new Wallets(this.bitgo, this);\n    this._keychains = new Keychains(this.bitgo, this);\n    this._webhooks = new Webhooks(this.bitgo, this);\n    this._pendingApprovals = new PendingApprovals(this.bitgo, this);\n    this._enterprises = new Enterprises(this.bitgo, this);\n    this._markets = new Markets(this.bitgo, this);\n  }\n\n  public url(suffix: string): string {\n    return this._url + this.getChain() + suffix;\n  }\n\n  public wallets(): Wallets {\n    return this._wallets;\n  }\n\n  public enterprises(): Enterprises {\n    return this._enterprises;\n  }\n\n  public keychains(): Keychains {\n    return this._keychains;\n  }\n\n  public webhooks(): Webhooks {\n    return this._webhooks;\n  }\n\n  public pendingApprovals(): PendingApprovals {\n    return this._pendingApprovals;\n  }\n\n  public markets(): Markets {\n    return this._markets;\n  }\n\n  public static get coinTokenPatternSeparator(): string {\n    return this._coinTokenPatternSeparator;\n  }\n\n  public get type(): string {\n    return this.getChain();\n  }\n\n  /**\n   * Name of the chain which supports this coin (eg, 'btc', 'eth')\n   */\n  abstract getChain(): string;\n\n  /**\n   * Name of the coin family (eg. for tbtc, this would be btc)\n   */\n  abstract getFamily(): string;\n\n  /**\n   * Human readable full name for the coin\n   */\n  abstract getFullName(): string;\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 false;\n  }\n\n  /**\n   * Use `sendMany()` to perform wallet sweep.\n   * FIXME(BG-39738): add coin.sweepWallet() instead\n   */\n  sweepWithSendMany(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag for sending data along with transactions\n   * @returns {boolean} True if okay to send tx data (ETH), false otherwise\n   */\n  transactionDataAllowed(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag for determining whether this coin supports account consolidations\n   * from its receive addresses to the root address.\n   * @returns {boolean} True if okay to consolidate over this coin; false, otherwise\n   */\n  allowsAccountConsolidations(): boolean {\n    return false;\n  }\n\n  /**\n   * Gets config for how token enablements work for this coin\n   * @returns\n   *    requiresTokenEnablement: True if tokens need to be enabled for this coin\n   *    supportsMultipleTokenEnablements: True if multiple tokens can be enabled in one transaction\n   */\n  getTokenEnablementConfig(): TokenEnablementConfig {\n    return {\n      requiresTokenEnablement: false,\n      supportsMultipleTokenEnablements: false,\n    };\n  }\n\n  /**\n   * Flag indicating if this coin supports TSS wallets.\n   * @returns {boolean} True if TSS Wallets can be created for this coin\n   */\n  supportsTss(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag indicating if this blockchain runs on EVM architecture.\n   * @returns {boolean} True if the blockchain runs on EVM architecture.\n   */\n  isEVM(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag indicating if this coin supports BLS-DKG wallets.\n   * @returns {boolean} True if BLS-DKG Wallets can be created for this coin\n   */\n  supportsBlsDkg(): boolean {\n    return false;\n  }\n\n  /**\n   * Returns the factor between the base unit and its smallest subdivison\n   * @return {number}\n   */\n  abstract getBaseFactor(): number | string;\n\n  /**\n   * Convert a currency amount represented in base units (satoshi, wei, atoms, drops, stroops)\n   * to big units (btc, eth, xrp, xlm)\n   */\n  baseUnitsToBigUnits(baseUnits: string | number): string {\n    BigNumber.set({ DECIMAL_PLACES: 24 });\n    const dividend = this.getBaseFactor();\n    const bigNumber = new BigNumber(baseUnits).dividedBy(dividend);\n    // set the format so commas aren't added to large coin amounts\n    return bigNumber.toFormat(null as any, null as any, { groupSeparator: '', decimalSeparator: '.' });\n  }\n\n  /**\n   * Convert a currency amount represented in big units (btc, eth, xrp, xlm)\n   * to base units (satoshi, wei, atoms, drops, stroops)\n   * @param bigUnits\n   */\n  bigUnitsToBaseUnits(bigUnits: string | number): string {\n    const multiplier = this.getBaseFactor();\n    const bigNumber = new BigNumber(bigUnits).times(multiplier);\n    if (!bigNumber.isInteger()) {\n      throw new Error(`non-integer output resulted from multiplying ${bigUnits} by ${multiplier}`);\n    }\n    return bigNumber.toFixed(0);\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: { prv: string }, message: string): Promise<Buffer> {\n    return signMessage(message, bip32.fromBase58(key.prv), utxolib.networks.bitcoin);\n  }\n\n  /**\n   * Decompose a raw transaction into useful information.\n   * @param options - coin-specific\n   */\n  explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined> {\n    throw new Error(`not implemented`);\n  }\n\n  /**\n   * Verify that a transaction prebuild complies with the original intention\n   */\n  abstract verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;\n\n  /**\n   * @deprecated use {@see isWalletAddress} instead\n   */\n  verifyAddress(params: VerifyAddressOptions): Promise<boolean> {\n    return this.isWalletAddress(params);\n  }\n\n  /**\n   * @param params\n   * @return true iff address is a wallet address. Must return false if address is outside wallet.\n   */\n  abstract isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;\n\n  /**\n   * convert address into desired address format.\n   * @param address\n   * @param format\n   */\n  canonicalAddress(address: string, format?: unknown): string {\n    return address;\n  }\n\n  /**\n   * Check whether a coin supports blockTarget for transactions to be included in\n   * @returns {boolean}\n   */\n  supportsBlockTarget() {\n    return false;\n  }\n\n  /**\n   * Check whether a coin supports lightning transactions\n   * @returns {boolean}\n   */\n  supportsLightning() {\n    return false;\n  }\n\n  /**\n   * Check whether a coin supports message signing\n   * @returns {boolean}\n   */\n  supportsMessageSigning(): boolean {\n    return false;\n  }\n\n  /**\n   * Check whether a coin supports signing of Typed data\n   * @returns {boolean}\n   */\n  supportsSigningTypedData(): boolean {\n    return false;\n  }\n\n  /**\n   * Hook to add additional parameters to the wallet generation\n   * @param walletParams\n   * @param keychains\n   * @return {*}\n   */\n  supplementGenerateWallet(walletParams: SupplementGenerateWalletOptions, keychains: KeychainsTriplet): Promise<any> {\n    return Promise.resolve(walletParams);\n  }\n\n  /**\n   * Get extra parameters for prebuilding a tx. Add things like hop transaction params\n   */\n  getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>> {\n    return Promise.resolve({});\n  }\n\n  /**\n   * Modify prebuild after receiving it from the server. Add things like nlocktime\n   */\n  postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild> {\n    return Promise.resolve(prebuildResponse);\n  }\n\n  /**\n   * Coin-specific things done before signing a transaction, i.e. verification\n   */\n  presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions> {\n    return Promise.resolve(params);\n  }\n\n  /**\n   * Create a new wallet object from a wallet data object\n   * @param walletParams\n   */\n  newWalletObject(walletParams: any): IWallet {\n    return new Wallet(this.bitgo, this, walletParams);\n  }\n\n  /**\n   * Fetch fee estimate information from the server\n   * @param {Object} params The params passed into the function\n   * @param {Integer} params.numBlocks The number of blocks to target for conformation (Only works for btc)\n   * @returns {Object} The info returned from the merchant server\n   */\n  async feeEstimate(params: FeeEstimateOptions): Promise<any> {\n    const query: any = {};\n    if (params && params.numBlocks) {\n      query.numBlocks = params.numBlocks;\n    }\n\n    return this.bitgo.get(this.url('/tx/fee')).query(query).result();\n  }\n\n  /**\n   * The cold wallet tool uses this function to derive an extended key that is based on the passed key and seed\n   * @param key\n   * @param seed\n   * @returns {{key: string, derivationPath: string}}\n   */\n  deriveKeyWithSeed({ key, seed }: { key: string; seed: string }): { key: string; derivationPath: string } {\n    function sha256(input) {\n      return crypto.createHash('sha256').update(input).digest();\n    }\n    const derivationPathInput = sha256(sha256(`${seed}`)).toString('hex');\n    const derivationPathParts = [\n      parseInt(derivationPathInput.slice(0, 7), 16),\n      parseInt(derivationPathInput.slice(7, 14), 16),\n    ];\n    const derivationPath = 'm/999999/' + derivationPathParts.join('/');\n    const keyNode = bip32.fromBase58(key);\n    const derivedKeyNode = keyNode.derivePath(derivationPath);\n    return {\n      key: derivedKeyNode.toBase58(),\n      derivationPath: derivationPath,\n    };\n  }\n\n  /**\n   * Specifies what key we will need for signing - right now we just need the\n   * user key.\n   */\n  keyIdsForSigning(): number[] {\n    return [KeyIndices.USER];\n  }\n\n  /**\n   * Perform additional checks before adding a bitgo key. Base controller\n   * is a no-op, but coin-specific controller may do something\n   * @param params\n   */\n  preCreateBitGo(params: PrecreateBitGoOptions): void {\n    return;\n  }\n\n  /**\n   * @deprecated - use getBip32Keys() in conjunction with isValidAddress instead\n   */\n  initiateRecovery(params: InitiateRecoveryOptions): never {\n    throw new Error('deprecated method');\n  }\n\n  /**\n   * Only used in PendingApproval for comparing PAYGo fees purpose\n   * @param params options for parsing\n   */\n  abstract parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;\n\n  /**\n   * Generate a key pair on the curve used by the coin\n   *\n   * @param seed\n   */\n  abstract generateKeyPair(seed?: Buffer): KeyPair;\n\n  /**\n   * Return boolean indicating whether input is valid public key for the coin.\n   *\n   * @param {String} pub the pub to be checked\n   * @returns {Boolean} is it valid?\n   */\n  abstract isValidPub(pub: string): boolean;\n\n  /**\n   * Return wether the given m of n wallet signers/ key amounts are valid for the coin\n   */\n  isValidMofNSetup({ m, n }: { m?: number; n?: number }): boolean {\n    return m === 2 && n === 3;\n  }\n\n  /**\n   * Check if `address` is a plausibly valid address for the given coin.\n   *\n   * Does not verify that the address belongs to a wallet. For that,\n   * use [[verifyAddress]]\n   * @param address\n   */\n  abstract isValidAddress(address: string): boolean;\n\n  /**\n   * Sign a transaction\n   */\n  abstract signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;\n\n  /**\n   * Returns the portion of the transaction that needs to be signed in Buffer format.\n   * Only needed for coins that support adding signatures directly (e.g. TSS).\n   *\n   * @param {String} serializedTx - the unsigned transaction in broadcast format\n   * @returns {Promise<Buffer>} - the portion of the transaction that needs to be signed\n   */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    return Buffer.from(serializedTx);\n  }\n\n  /**\n   * Returns the MPC algorithm (ecdsa or eddsa) used for coins that support TSS\n   */\n  getMPCAlgorithm(): MPCAlgorithm {\n    throw new Error('no MPC algorithm is defined for this coin');\n  }\n\n  async recoverToken(params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction> {\n    throw new NotImplementedError('recoverToken is not supported for this coin');\n  }\n\n  getInscriptionBuilder(wallet: Wallet): IInscriptionBuilder {\n    throw new NotImplementedError('Inscription Builder is not supported for this coin');\n  }\n\n  /**\n   * Function to get coin specific hash function used to generate transaction digests.\n   * @returns {@see Hash} hash function if implemented, otherwise throws exception\n   */\n  getHashFunction(): Hash {\n    throw new NotImplementedError('getHashFunction is not supported for this coin');\n  }\n}\n"]}
|
|
363
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseCoin.js","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/baseCoin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;GAEG;AACH,+CAAiC;AACjC,mDAA6C;AAC7C,+CAAyC;AAEzC,8DAAgD;AAGhD,4CAA2C;AAC3C,mDAAwD;AAExD,8CAA4C;AAC5C,0CAAoD;AACpD,sCAAoC;AACpC,wDAAsD;AACtD,sCAAqD;AACrD,wCAAsC;AA0BtC,MAAsB,QAAQ;IAW5B,YAAsB,KAAgB;QACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACnC,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,UAAU,GAAG,IAAI,oBAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAClD,IAAI,CAAC,SAAS,GAAG,IAAI,kBAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAChD,IAAI,CAAC,iBAAiB,GAAG,IAAI,kCAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAChE,IAAI,CAAC,YAAY,GAAG,IAAI,wBAAW,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;IAEM,GAAG,CAAC,MAAc;QACvB,OAAO,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,MAAM,CAAC;IAC9C,CAAC;IAEM,OAAO;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAEM,WAAW;QAChB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAEM,SAAS;QACd,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAEM,QAAQ;QACb,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAEM,gBAAgB;QACrB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAEM,OAAO;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAEM,MAAM,KAAK,yBAAyB;QACzC,OAAO,IAAI,CAAC,0BAA0B,CAAC;IACzC,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IAiBD;;;OAGG;IACH,wBAAwB;QACtB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,iBAAiB;QACf,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,sBAAsB;QACpB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;OAIG;IACH,2BAA2B;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;OAKG;IACH,wBAAwB;QACtB,OAAO;YACL,uBAAuB,EAAE,KAAK;YAC9B,gCAAgC,EAAE,KAAK;SACxC,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,KAAK;QACH,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,KAAK,CAAC;IACf,CAAC;IAQD;;;OAGG;IACH,mBAAmB,CAAC,SAA0B;QAC5C,wBAAS,CAAC,GAAG,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACtC,MAAM,SAAS,GAAG,IAAI,wBAAS,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAC/D,8DAA8D;QAC9D,OAAO,SAAS,CAAC,QAAQ,CAAC,IAAW,EAAE,IAAW,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE,gBAAgB,EAAE,GAAG,EAAE,CAAC,CAAC;IACrG,CAAC;IAED;;;;OAIG;IACH,mBAAmB,CAAC,QAAyB;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACxC,MAAM,SAAS,GAAG,IAAI,wBAAS,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAC5D,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,gDAAgD,QAAQ,OAAO,UAAU,EAAE,CAAC,CAAC;SAC9F;QACD,OAAO,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW,CAAC,GAAoB,EAAE,OAAe;QACrD,OAAO,uBAAW,CAAC,OAAO,EAAE,gBAAK,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACnF,CAAC;IAED;;;;;;;OAOG;IACI,KAAK,CAAC,mBAAmB,CAC9B,GAAW,EACX,cAA+B,EAC/B,aAA8B;QAK9B,OAAO;YACL,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC7E,KAAK,EAAE,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;SAC5E,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,kBAAkB,CAAC,OAA4B;QAC7C,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;IACrC,CAAC;IAOD;;OAEG;IACH,aAAa,CAAC,MAA4B;QACxC,OAAO,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IAQD;;;;OAIG;IACH,gBAAgB,CAAC,OAAe,EAAE,MAAgB;QAChD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;OAGG;IACH,mBAAmB;QACjB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,iBAAiB;QACf,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,sBAAsB;QACpB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;OAGG;IACH,wBAAwB;QACtB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;OAKG;IACH,wBAAwB,CAAC,YAA6C,EAAE,SAA2B;QACjG,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACH,sBAAsB,CAAC,WAAuC;QAC5D,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,mBAAmB,CAAC,gBAAqC;QACvD,OAAO,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,kBAAkB,CAAC,MAAiC;QAClD,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,YAAiB;QAC/B,OAAO,IAAI,eAAM,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;IACpD,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW,CAAC,MAA0B;QAC1C,MAAM,KAAK,GAAQ,EAAE,CAAC;QACtB,IAAI,MAAM,IAAI,MAAM,CAAC,SAAS,EAAE;YAC9B,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;SACpC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC;IACnE,CAAC;IAED;;;;;OAKG;IACH,iBAAiB,CAAC,EAAE,GAAG,EAAE,IAAI,EAAiC;QAC5D,SAAS,MAAM,CAAC,KAAK;YACnB,OAAO,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC;QAC5D,CAAC;QACD,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACtE,MAAM,mBAAmB,GAAG;YAC1B,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;YAC7C,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;SAC/C,CAAC;QACF,MAAM,cAAc,GAAG,WAAW,GAAG,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnE,MAAM,OAAO,GAAG,gBAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACtC,MAAM,cAAc,GAAG,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;QAC1D,OAAO;YACL,GAAG,EAAE,cAAc,CAAC,QAAQ,EAAE;YAC9B,cAAc,EAAE,cAAc;SAC/B,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,gBAAgB;QACd,OAAO,CAAC,qBAAU,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAC,MAA6B;QAC1C,OAAO;IACT,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,MAA+B;QAC9C,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;IACvC,CAAC;IAuBD;;OAEG;IACH,gBAAgB,CAAC,EAAE,CAAC,EAAE,CAAC,EAA8B;QACnD,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAgBD;;;;;;OAMG;IACH,KAAK,CAAC,kBAAkB,CAAC,YAAoB;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,eAAe;QACb,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAiC;QAClD,MAAM,IAAI,iCAAmB,CAAC,6CAA6C,CAAC,CAAC;IAC/E,CAAC;IAED,qBAAqB,CAAC,MAAc;QAClC,MAAM,IAAI,iCAAmB,CAAC,oDAAoD,CAAC,CAAC;IACtF,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,MAAM,IAAI,iCAAmB,CAAC,gDAAgD,CAAC,CAAC;IAClF,CAAC;;AAlcH,4BAmcC;AA1b2B,mCAA0B,GAAG,GAAG,CAAC","sourcesContent":["/**\n * @prettier\n */\nimport * as crypto from 'crypto';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { BigNumber } from 'bignumber.js';\n\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { InitiateRecoveryOptions } from '../recovery';\nimport { signMessage } from '../bip32util';\nimport { NotImplementedError } from '../../account-lib';\nimport { BitGoBase } from '../bitgoBase';\nimport { Enterprises } from '../enterprise';\nimport { Keychains, KeyIndices } from '../keychain';\nimport { Markets } from '../market';\nimport { PendingApprovals } from '../pendingApproval';\nimport { Wallets, IWallet, Wallet } from '../wallet';\nimport { Webhooks } from '../webhook';\nimport {\n  ExtraPrebuildParamsOptions,\n  FeeEstimateOptions,\n  IBaseCoin,\n  ParsedTransaction,\n  ITransactionExplanation,\n  KeychainsTriplet,\n  KeyPair,\n  MPCAlgorithm,\n  ParseTransactionOptions,\n  PrecreateBitGoOptions,\n  PresignTransactionOptions,\n  RecoverTokenTransaction,\n  RecoverWalletTokenOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  SupplementGenerateWalletOptions,\n  TokenEnablementConfig,\n  TransactionPrebuild,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from './iBaseCoin';\nimport { IInscriptionBuilder } from '../inscriptionBuilder';\nimport { Hash } from 'crypto';\n\nexport abstract class BaseCoin implements IBaseCoin {\n  protected readonly bitgo: BitGoBase;\n  protected readonly _url: string;\n  protected readonly _enterprises: Enterprises;\n  protected readonly _wallets: Wallets;\n  protected readonly _keychains: Keychains;\n  protected readonly _webhooks: Webhooks;\n  protected readonly _pendingApprovals: PendingApprovals;\n  protected readonly _markets: Markets;\n  protected static readonly _coinTokenPatternSeparator = ':';\n\n  protected constructor(bitgo: BitGoBase) {\n    this.bitgo = bitgo;\n    this._url = this.bitgo.url('/', 2);\n    this._wallets = new Wallets(this.bitgo, this);\n    this._keychains = new Keychains(this.bitgo, this);\n    this._webhooks = new Webhooks(this.bitgo, this);\n    this._pendingApprovals = new PendingApprovals(this.bitgo, this);\n    this._enterprises = new Enterprises(this.bitgo, this);\n    this._markets = new Markets(this.bitgo, this);\n  }\n\n  public url(suffix: string): string {\n    return this._url + this.getChain() + suffix;\n  }\n\n  public wallets(): Wallets {\n    return this._wallets;\n  }\n\n  public enterprises(): Enterprises {\n    return this._enterprises;\n  }\n\n  public keychains(): Keychains {\n    return this._keychains;\n  }\n\n  public webhooks(): Webhooks {\n    return this._webhooks;\n  }\n\n  public pendingApprovals(): PendingApprovals {\n    return this._pendingApprovals;\n  }\n\n  public markets(): Markets {\n    return this._markets;\n  }\n\n  public static get coinTokenPatternSeparator(): string {\n    return this._coinTokenPatternSeparator;\n  }\n\n  public get type(): string {\n    return this.getChain();\n  }\n\n  /**\n   * Name of the chain which supports this coin (eg, 'btc', 'eth')\n   */\n  abstract getChain(): string;\n\n  /**\n   * Name of the coin family (eg. for tbtc, this would be btc)\n   */\n  abstract getFamily(): string;\n\n  /**\n   * Human readable full name for the coin\n   */\n  abstract getFullName(): string;\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 false;\n  }\n\n  /**\n   * Use `sendMany()` to perform wallet sweep.\n   * FIXME(BG-39738): add coin.sweepWallet() instead\n   */\n  sweepWithSendMany(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag for sending data along with transactions\n   * @returns {boolean} True if okay to send tx data (ETH), false otherwise\n   */\n  transactionDataAllowed(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag for determining whether this coin supports account consolidations\n   * from its receive addresses to the root address.\n   * @returns {boolean} True if okay to consolidate over this coin; false, otherwise\n   */\n  allowsAccountConsolidations(): boolean {\n    return false;\n  }\n\n  /**\n   * Gets config for how token enablements work for this coin\n   * @returns\n   *    requiresTokenEnablement: True if tokens need to be enabled for this coin\n   *    supportsMultipleTokenEnablements: True if multiple tokens can be enabled in one transaction\n   */\n  getTokenEnablementConfig(): TokenEnablementConfig {\n    return {\n      requiresTokenEnablement: false,\n      supportsMultipleTokenEnablements: false,\n    };\n  }\n\n  /**\n   * Flag indicating if this coin supports TSS wallets.\n   * @returns {boolean} True if TSS Wallets can be created for this coin\n   */\n  supportsTss(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag indicating if this blockchain runs on EVM architecture.\n   * @returns {boolean} True if the blockchain runs on EVM architecture.\n   */\n  isEVM(): boolean {\n    return false;\n  }\n\n  /**\n   * Flag indicating if this coin supports BLS-DKG wallets.\n   * @returns {boolean} True if BLS-DKG Wallets can be created for this coin\n   */\n  supportsBlsDkg(): boolean {\n    return false;\n  }\n\n  /**\n   * Returns the factor between the base unit and its smallest subdivison\n   * @return {number}\n   */\n  abstract getBaseFactor(): number | string;\n\n  /**\n   * Convert a currency amount represented in base units (satoshi, wei, atoms, drops, stroops)\n   * to big units (btc, eth, xrp, xlm)\n   */\n  baseUnitsToBigUnits(baseUnits: string | number): string {\n    BigNumber.set({ DECIMAL_PLACES: 24 });\n    const dividend = this.getBaseFactor();\n    const bigNumber = new BigNumber(baseUnits).dividedBy(dividend);\n    // set the format so commas aren't added to large coin amounts\n    return bigNumber.toFormat(null as any, null as any, { groupSeparator: '', decimalSeparator: '.' });\n  }\n\n  /**\n   * Convert a currency amount represented in big units (btc, eth, xrp, xlm)\n   * to base units (satoshi, wei, atoms, drops, stroops)\n   * @param bigUnits\n   */\n  bigUnitsToBaseUnits(bigUnits: string | number): string {\n    const multiplier = this.getBaseFactor();\n    const bigNumber = new BigNumber(bigUnits).times(multiplier);\n    if (!bigNumber.isInteger()) {\n      throw new Error(`non-integer output resulted from multiplying ${bigUnits} by ${multiplier}`);\n    }\n    return bigNumber.toFixed(0);\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: { prv: string }, message: string): Promise<Buffer> {\n    return signMessage(message, bip32.fromBase58(key.prv), utxolib.networks.bitcoin);\n  }\n\n  /**\n   * Create signatures for the backup and bitgo keys using the user key.\n   * We can verify the signatures when fetching the keys from wallet-platform later.\n   * Currently only `AbstractUtxoCoin` implements and uses the complementary `verifyKeySignature` method.\n   * @param prv - the user private key\n   * @param backupKeychain - contains the backup public key\n   * @param bitgoKeychain - contains the bitgo public key\n   */\n  public async createKeySignatures(\n    prv: string,\n    backupKeychain: { pub: string },\n    bitgoKeychain: { pub: string }\n  ): Promise<{\n    backup: string;\n    bitgo: string;\n  }> {\n    return {\n      backup: (await this.signMessage({ prv }, backupKeychain.pub)).toString('hex'),\n      bitgo: (await this.signMessage({ prv }, bitgoKeychain.pub)).toString('hex'),\n    };\n  }\n\n  /**\n   * Decompose a raw transaction into useful information.\n   * @param options - coin-specific\n   */\n  explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined> {\n    throw new Error(`not implemented`);\n  }\n\n  /**\n   * Verify that a transaction prebuild complies with the original intention\n   */\n  abstract verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;\n\n  /**\n   * @deprecated use {@see isWalletAddress} instead\n   */\n  verifyAddress(params: VerifyAddressOptions): Promise<boolean> {\n    return this.isWalletAddress(params);\n  }\n\n  /**\n   * @param params\n   * @return true iff address is a wallet address. Must return false if address is outside wallet.\n   */\n  abstract isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;\n\n  /**\n   * convert address into desired address format.\n   * @param address\n   * @param format\n   */\n  canonicalAddress(address: string, format?: unknown): string {\n    return address;\n  }\n\n  /**\n   * Check whether a coin supports blockTarget for transactions to be included in\n   * @returns {boolean}\n   */\n  supportsBlockTarget() {\n    return false;\n  }\n\n  /**\n   * Check whether a coin supports lightning transactions\n   * @returns {boolean}\n   */\n  supportsLightning() {\n    return false;\n  }\n\n  /**\n   * Check whether a coin supports message signing\n   * @returns {boolean}\n   */\n  supportsMessageSigning(): boolean {\n    return false;\n  }\n\n  /**\n   * Check whether a coin supports signing of Typed data\n   * @returns {boolean}\n   */\n  supportsSigningTypedData(): boolean {\n    return false;\n  }\n\n  /**\n   * Hook to add additional parameters to the wallet generation\n   * @param walletParams\n   * @param keychains\n   * @return {*}\n   */\n  supplementGenerateWallet(walletParams: SupplementGenerateWalletOptions, keychains: KeychainsTriplet): Promise<any> {\n    return Promise.resolve(walletParams);\n  }\n\n  /**\n   * Get extra parameters for prebuilding a tx. Add things like hop transaction params\n   */\n  getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>> {\n    return Promise.resolve({});\n  }\n\n  /**\n   * Modify prebuild after receiving it from the server. Add things like nlocktime\n   */\n  postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild> {\n    return Promise.resolve(prebuildResponse);\n  }\n\n  /**\n   * Coin-specific things done before signing a transaction, i.e. verification\n   */\n  presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions> {\n    return Promise.resolve(params);\n  }\n\n  /**\n   * Create a new wallet object from a wallet data object\n   * @param walletParams\n   */\n  newWalletObject(walletParams: any): IWallet {\n    return new Wallet(this.bitgo, this, walletParams);\n  }\n\n  /**\n   * Fetch fee estimate information from the server\n   * @param {Object} params The params passed into the function\n   * @param {Integer} params.numBlocks The number of blocks to target for conformation (Only works for btc)\n   * @returns {Object} The info returned from the merchant server\n   */\n  async feeEstimate(params: FeeEstimateOptions): Promise<any> {\n    const query: any = {};\n    if (params && params.numBlocks) {\n      query.numBlocks = params.numBlocks;\n    }\n\n    return this.bitgo.get(this.url('/tx/fee')).query(query).result();\n  }\n\n  /**\n   * The cold wallet tool uses this function to derive an extended key that is based on the passed key and seed\n   * @param key\n   * @param seed\n   * @returns {{key: string, derivationPath: string}}\n   */\n  deriveKeyWithSeed({ key, seed }: { key: string; seed: string }): { key: string; derivationPath: string } {\n    function sha256(input) {\n      return crypto.createHash('sha256').update(input).digest();\n    }\n    const derivationPathInput = sha256(sha256(`${seed}`)).toString('hex');\n    const derivationPathParts = [\n      parseInt(derivationPathInput.slice(0, 7), 16),\n      parseInt(derivationPathInput.slice(7, 14), 16),\n    ];\n    const derivationPath = 'm/999999/' + derivationPathParts.join('/');\n    const keyNode = bip32.fromBase58(key);\n    const derivedKeyNode = keyNode.derivePath(derivationPath);\n    return {\n      key: derivedKeyNode.toBase58(),\n      derivationPath: derivationPath,\n    };\n  }\n\n  /**\n   * Specifies what key we will need for signing - right now we just need the\n   * user key.\n   */\n  keyIdsForSigning(): number[] {\n    return [KeyIndices.USER];\n  }\n\n  /**\n   * Perform additional checks before adding a bitgo key. Base controller\n   * is a no-op, but coin-specific controller may do something\n   * @param params\n   */\n  preCreateBitGo(params: PrecreateBitGoOptions): void {\n    return;\n  }\n\n  /**\n   * @deprecated - use getBip32Keys() in conjunction with isValidAddress instead\n   */\n  initiateRecovery(params: InitiateRecoveryOptions): never {\n    throw new Error('deprecated method');\n  }\n\n  /**\n   * Only used in PendingApproval for comparing PAYGo fees purpose\n   * @param params options for parsing\n   */\n  abstract parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;\n\n  /**\n   * Generate a key pair on the curve used by the coin\n   *\n   * @param seed\n   */\n  abstract generateKeyPair(seed?: Buffer): KeyPair;\n\n  /**\n   * Return boolean indicating whether input is valid public key for the coin.\n   *\n   * @param {String} pub the pub to be checked\n   * @returns {Boolean} is it valid?\n   */\n  abstract isValidPub(pub: string): boolean;\n\n  /**\n   * Return wether the given m of n wallet signers/ key amounts are valid for the coin\n   */\n  isValidMofNSetup({ m, n }: { m?: number; n?: number }): boolean {\n    return m === 2 && n === 3;\n  }\n\n  /**\n   * Check if `address` is a plausibly valid address for the given coin.\n   *\n   * Does not verify that the address belongs to a wallet. For that,\n   * use [[verifyAddress]]\n   * @param address\n   */\n  abstract isValidAddress(address: string): boolean;\n\n  /**\n   * Sign a transaction\n   */\n  abstract signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;\n\n  /**\n   * Returns the portion of the transaction that needs to be signed in Buffer format.\n   * Only needed for coins that support adding signatures directly (e.g. TSS).\n   *\n   * @param {String} serializedTx - the unsigned transaction in broadcast format\n   * @returns {Promise<Buffer>} - the portion of the transaction that needs to be signed\n   */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    return Buffer.from(serializedTx);\n  }\n\n  /**\n   * Returns the MPC algorithm (ecdsa or eddsa) used for coins that support TSS\n   */\n  getMPCAlgorithm(): MPCAlgorithm {\n    throw new Error('no MPC algorithm is defined for this coin');\n  }\n\n  async recoverToken(params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction> {\n    throw new NotImplementedError('recoverToken is not supported for this coin');\n  }\n\n  getInscriptionBuilder(wallet: Wallet): IInscriptionBuilder {\n    throw new NotImplementedError('Inscription Builder is not supported for this coin');\n  }\n\n  /**\n   * Function to get coin specific hash function used to generate transaction digests.\n   * @returns {@see Hash} hash function if implemented, otherwise throws exception\n   */\n  getHashFunction(): Hash {\n    throw new NotImplementedError('getHashFunction is not supported for this coin');\n  }\n}\n"]}
|
|
@@ -8,7 +8,7 @@ import { IPendingApprovals } from '../pendingApproval';
|
|
|
8
8
|
import { InitiateRecoveryOptions } from '../recovery';
|
|
9
9
|
import { EcdsaUtils } from '../utils/tss/ecdsa';
|
|
10
10
|
import EddsaUtils from '../utils/tss/eddsa';
|
|
11
|
-
import { IWallet, IWallets, Wallet, WalletData } from '../wallet';
|
|
11
|
+
import { CustomSigningFunction, IWallet, IWallets, Wallet, WalletData } from '../wallet';
|
|
12
12
|
import { IWebhooks } from '../webhook/iWebhooks';
|
|
13
13
|
import { BaseTokenConfig } from '@bitgo-beta/statics';
|
|
14
14
|
import { TransactionType } from '../../account-lib';
|
|
@@ -371,6 +371,14 @@ export interface IBaseCoin {
|
|
|
371
371
|
signMessage(key: {
|
|
372
372
|
prv: string;
|
|
373
373
|
}, message: string): Promise<Buffer>;
|
|
374
|
+
createKeySignatures(prv: string, backupKeychain: {
|
|
375
|
+
pub: string;
|
|
376
|
+
}, bitgoKeychain: {
|
|
377
|
+
pub: string;
|
|
378
|
+
}): Promise<{
|
|
379
|
+
backup: string;
|
|
380
|
+
bitgo: string;
|
|
381
|
+
}>;
|
|
374
382
|
explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined>;
|
|
375
383
|
verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
|
|
376
384
|
verifyAddress(params: VerifyAddressOptions): Promise<boolean>;
|
|
@@ -384,6 +392,10 @@ export interface IBaseCoin {
|
|
|
384
392
|
getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>>;
|
|
385
393
|
postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild>;
|
|
386
394
|
presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions>;
|
|
395
|
+
signWithCustomSigningFunction?(customSigningFunction: CustomSigningFunction, signTransactionParams: {
|
|
396
|
+
txPrebuild: TransactionPrebuild;
|
|
397
|
+
pubs?: string[];
|
|
398
|
+
}): Promise<SignedTransaction>;
|
|
387
399
|
newWalletObject(walletParams: any): IWallet;
|
|
388
400
|
feeEstimate(params: FeeEstimateOptions): Promise<any>;
|
|
389
401
|
deriveKeyWithSeed(params: DeriveKeyWithSeedOptions): {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"iBaseCoin.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/iBaseCoin.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"iBaseCoin.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/iBaseCoin.ts"],"names":[],"mappings":"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"}
|
|
@@ -7,4 +7,4 @@ var SignTypedDataVersion;
|
|
|
7
7
|
SignTypedDataVersion["V3"] = "V3";
|
|
8
8
|
SignTypedDataVersion["V4"] = "V4";
|
|
9
9
|
})(SignTypedDataVersion = exports.SignTypedDataVersion || (exports.SignTypedDataVersion = {}));
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iBaseCoin.js","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/iBaseCoin.ts"],"names":[],"mappings":";;;AA+QA,IAAY,oBAIX;AAJD,WAAY,oBAAoB;IAC9B,iCAAS,CAAA;IACT,iCAAS,CAAA;IACT,iCAAS,CAAA;AACX,CAAC,EAJW,oBAAoB,GAApB,4BAAoB,KAApB,4BAAoB,QAI/B","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { IRequestTracer } from '../../api';\nimport { IEnterprises } from '../enterprise';\nimport { Keychain, IKeychains } from '../keychain';\nimport { IMarkets } from '../market';\nimport { IPendingApprovals } from '../pendingApproval';\nimport { InitiateRecoveryOptions } from '../recovery';\nimport { EcdsaUtils } from '../utils/tss/ecdsa';\nimport EddsaUtils from '../utils/tss/eddsa';\nimport { IWallet, IWallets, Wallet, WalletData } from '../wallet';\n\nimport { IWebhooks } from '../webhook/iWebhooks';\nimport { BaseTokenConfig } from '@bitgo-beta/statics';\nimport { TransactionType } from '../../account-lib';\nimport { IInscriptionBuilder } from '../inscriptionBuilder';\nimport { Hash } from 'crypto';\n\nexport interface Output extends ITransactionRecipient {\n  address: string;\n  // of form coin:token\n  coinName?: string;\n  isPayGo?: boolean;\n  value?: number;\n  wallet?: string; // Types.ObjectId;\n  walletV1?: string; // Types.ObjectId;\n  baseAddress?: string;\n  enterprise?: string; // Types.ObjectId;\n  valueString: string;\n  data?: string;\n  // \"change\" is a utxo-specific concept and this property should\n  // be removed once it it's usage is refactored out of base coin logic\n  change?: boolean;\n}\n\nexport type Input = {\n  derivationIndex?: number;\n  value: number;\n  address?: string;\n  valueString: string;\n  // the properties below are utxo-related but are currently used in abstractBaseCoin\n  // these should be removed once their usage is removed from the base coin class\n  chain?: number;\n  index?: number;\n};\n\nexport type UnsignedTransaction = {\n  // unsigned transaction in broadcast format\n  serializedTxHex: string;\n  // portion of a transaction used to generate a signature\n  signableHex: string;\n  // transaction fees\n  feeInfo?: {\n    fee: number | BigNumber;\n    feeString: string;\n  };\n  // derivation path of the signer\n  derivationPath: string;\n  coinSpecific?: Record<string, unknown>;\n  entryValues: any;\n  parsedTx: UnsignedParsedTransaction;\n};\n\nexport interface ExplanationResult extends ITransactionExplanation {\n  sequenceId: number;\n  type?: string;\n  outputs: Output[];\n  blockNumber: number | unknown;\n}\n\nexport interface ITransactionRecipient {\n  address: string;\n  amount: string | number;\n  tokenName?: string;\n  memo?: string;\n}\n\nexport interface ITransactionFee<TAmount = string> {\n  fee: TAmount;\n  feeRate?: number;\n  size?: number;\n}\n\nexport interface ITransactionExplanation<TFee = any, TAmount = any> {\n  displayOrder: string[];\n  id: string;\n  outputs: ITransactionRecipient[];\n  outputAmount: TAmount;\n  changeOutputs: ITransactionRecipient[];\n  changeAmount: TAmount;\n  fee: TFee;\n  proxy?: string;\n  producers?: string[];\n}\n\nexport interface KeyPair {\n  pub?: string;\n  prv: string;\n}\n\nexport interface IBlsKeyPair extends KeyPair {\n  secretShares?: string[];\n  chaincode: string;\n  seed?: string;\n}\n\nexport interface VerifyAddressOptions {\n  address: string;\n  addressType?: string;\n  keychains?: {\n    pub: string;\n    commonKeychain?: string;\n  }[];\n  error?: string;\n  coinSpecific?: AddressCoinSpecific;\n  impliedForwarderVersion?: number;\n}\n\nexport interface TssVerifyAddressOptions extends VerifyAddressOptions {\n  chain: string;\n  index: string;\n}\n\nexport interface TransactionParams {\n  recipients?: ITransactionRecipient[];\n  walletPassphrase?: string;\n  type?: string;\n}\n\nexport interface AddressVerificationData {\n  coinSpecific?: AddressCoinSpecific;\n  chain?: number;\n  index?: number;\n}\n\nexport interface VerificationOptions {\n  disableNetworking?: boolean;\n  keychains?: {\n    user?: Keychain;\n    backup?: Keychain;\n    bitgo?: Keychain;\n  };\n  addresses?: { [address: string]: AddressVerificationData };\n  allowPaygoOutput?: boolean;\n  considerMigratedFromAddressInternal?: boolean;\n}\n\nexport interface VerifyTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  txParams: TransactionParams;\n  wallet: Wallet;\n  verification?: VerificationOptions;\n  reqId?: IRequestTracer;\n  walletType?: 'onchain' | 'tss';\n}\n\nexport interface SupplementGenerateWalletOptions {\n  label: string;\n  m: number;\n  n: number;\n  enterprise?: string;\n  disableTransactionNotifications?: boolean;\n  gasPrice?: number | string;\n  eip1559?: {\n    maxFeePerGas: number | string;\n    maxPriorityFeePerGas?: number | string;\n  };\n  walletVersion?: number;\n  keys: string[];\n  isCold: boolean;\n  keySignatures?: {\n    backup: string;\n    bitgo: string;\n  };\n  rootPrivateKey?: string;\n  disableKRSEmail?: boolean;\n  multisigType?: 'tss' | 'onchain' | 'blsdkg';\n}\n\nexport interface FeeEstimateOptions {\n  numBlocks?: number;\n  hop?: boolean;\n  recipient?: string;\n  data?: string;\n  amount?: string;\n  type?: keyof typeof TransactionType;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ExtraPrebuildParamsOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PresignTransactionOptions {\n  txPrebuild?: TransactionPrebuild;\n  walletData: WalletData;\n  tssUtils: EcdsaUtils | EddsaUtils | undefined;\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PrecreateBitGoOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface VerifyRecoveryTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParseTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParsedTransaction {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport type UnsignedParsedTransaction = {\n  inputs: Input[];\n  minerFee: number | string;\n  outputs: Output[];\n  spendAmount: number | string;\n  hasUnvalidatedData?: boolean;\n  payGoFee?: number;\n  type?: string;\n  sequenceId: number;\n  id: string;\n};\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface SignTransactionOptions {\n  [index: string]: unknown;\n}\n\nexport interface KeychainsTriplet {\n  userKeychain: Keychain;\n  backupKeychain: Keychain;\n  bitgoKeychain: Keychain;\n}\n\ninterface BaseSignable {\n  wallet?: IWallet;\n  buildParams?: any;\n  consolidateId?: string;\n  txRequestId?: string;\n}\n\nexport interface TransactionPrebuild extends BaseSignable {\n  txBase64?: string;\n  txHex?: string;\n  txInfo?: unknown;\n}\n\nexport interface Message extends BaseSignable {\n  messageRaw: string;\n  messageEncoded?: string;\n}\n\nexport interface MessageTypeProperty {\n  name: string;\n  type: string;\n}\nexport interface MessageTypes {\n  EIP712Domain: MessageTypeProperty[];\n  [additionalProperties: string]: MessageTypeProperty[];\n}\n\nexport enum SignTypedDataVersion {\n  V1 = 'V1',\n  V3 = 'V3',\n  V4 = 'V4',\n}\n\n/**\n * This is the message format used for `signTypeData`, for all versions\n * except `V1`.\n *\n * @template T - The custom types used by this message.\n * @property types - The custom types used by this message.\n * @property primaryType - The type of the message.\n * @property domain - Signing domain metadata. The signing domain is the intended context for the\n * signature (e.g. the dapp, protocol, etc. that it's intended for). This data is used to\n * construct the domain seperator of the message.\n * @property domain.name - The name of the signing domain.\n * @property domain.version - The current major version of the signing domain.\n * @property domain.chainId - The chain ID of the signing domain.\n * @property domain.verifyingContract - The address of the contract that can verify the signature.\n * @property domain.salt - A disambiguating salt for the protocol.\n * @property message - The message to be signed.\n */\nexport interface TypedMessage<T extends MessageTypes> {\n  types: T;\n  primaryType: keyof T;\n  domain: {\n    name?: string;\n    version?: string;\n    chainId?: number;\n    verifyingContract?: string;\n    salt?: ArrayBuffer;\n  };\n  message: Record<string, unknown>;\n}\n\nexport interface TypedData extends BaseSignable {\n  typedDataRaw: string;\n  version: SignTypedDataVersion;\n  typedDataEncoded?: Buffer;\n}\n\nexport interface AddressCoinSpecific {\n  outputScript?: string;\n  redeemScript?: string;\n  witnessScript?: string;\n  baseAddress?: string;\n  pendingChainInitialization?: boolean;\n  forwarderVersion?: number;\n}\n\nexport interface FullySignedTransaction {\n  txHex: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n}\n\nexport interface HalfSignedUtxoTransaction {\n  txHex: string;\n}\n\nexport interface HalfSignedAccountTransaction {\n  halfSigned?: {\n    txHex?: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n    payload?: string;\n    txBase64?: string;\n  };\n}\n\nexport interface HalfSignedTransaction extends HalfSignedAccountTransaction {\n  halfSigned: {\n    recipients: Recipient[];\n    expireTime?: number;\n    contractSequenceId?: number;\n    sequenceId?: number;\n    txHex?: never;\n  };\n}\n\nexport interface SignedTransactionRequest {\n  txRequestId: string;\n}\n\nexport interface DeriveKeyWithSeedOptions {\n  key: string;\n  seed: string;\n}\n\nexport interface ValidMofNOptions {\n  m?: number;\n  n?: number;\n}\n\nexport type SignedTransaction =\n  | HalfSignedAccountTransaction\n  | HalfSignedUtxoTransaction\n  | FullySignedTransaction\n  | SignedTransactionRequest;\n\nexport interface SignedMessage {\n  coin?: string;\n  txHash: string;\n  messageRaw: string;\n  txRequestId: string;\n}\n\nexport interface RecoverWalletTokenOptions {\n  tokenContractAddress: string;\n  wallet: IWallet;\n  recipient: string;\n  broadcast?: boolean;\n  walletPassphrase?: string;\n  prv?: string;\n}\n\nexport interface Recipient {\n  address: string;\n  amount: string;\n  data?: string;\n}\n\nexport interface RecoverTokenTransaction {\n  halfSigned: {\n    recipient: Recipient;\n    expireTime: number;\n    contractSequenceId: number;\n    operationHash: string;\n    signature: string;\n    gasLimit: number;\n    gasPrice: number;\n    tokenContractAddress: string;\n    walletId: string;\n  };\n}\n\nexport interface TokenEnablementConfig {\n  requiresTokenEnablement: boolean;\n  supportsMultipleTokenEnablements: boolean;\n}\n\nexport interface MessagePrep {\n  encodeMessage(message: string): string;\n}\n\nexport type MPCAlgorithm = 'ecdsa' | 'eddsa';\n\nexport interface IBaseCoin {\n  type: string;\n  tokenConfig?: BaseTokenConfig;\n  url(suffix: string): string;\n  wallets(): IWallets;\n  enterprises(): IEnterprises;\n  keychains(): IKeychains;\n  webhooks(): IWebhooks;\n  pendingApprovals(): IPendingApprovals;\n  markets(): IMarkets;\n  getChain(): string;\n  getFamily(): string;\n  getFullName(): string;\n  valuelessTransferAllowed(): boolean;\n  sweepWithSendMany(): boolean;\n  transactionDataAllowed(): boolean;\n  allowsAccountConsolidations(): boolean;\n  getTokenEnablementConfig(): TokenEnablementConfig;\n  supportsTss(): boolean;\n  isEVM(): boolean;\n  supportsBlsDkg(): boolean;\n  getBaseFactor(): number | string;\n  baseUnitsToBigUnits(baseUnits: string | number): string;\n  bigUnitsToBaseUnits(bigUnits: string | number): string;\n  signMessage(key: { prv: string }, message: string): Promise<Buffer>;\n  explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined>;\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;\n  verifyAddress(params: VerifyAddressOptions): Promise<boolean>;\n  isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;\n  canonicalAddress(address: string, format: unknown): string;\n  supportsBlockTarget(): boolean;\n  supportsLightning(): boolean;\n  supportsMessageSigning(): boolean;\n  supportsSigningTypedData(): boolean;\n  supplementGenerateWallet(walletParams: SupplementGenerateWalletOptions, keychains: KeychainsTriplet): Promise<any>;\n  getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>>;\n  postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild>;\n  presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions>;\n  newWalletObject(walletParams: any): IWallet;\n  feeEstimate(params: FeeEstimateOptions): Promise<any>;\n  deriveKeyWithSeed(params: DeriveKeyWithSeedOptions): { key: string; derivationPath: string };\n  keyIdsForSigning(): number[];\n  preCreateBitGo(params: PrecreateBitGoOptions): void;\n  initiateRecovery(params: InitiateRecoveryOptions): never;\n  parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;\n  generateKeyPair(seed?: Buffer): KeyPair;\n  isValidPub(pub: string): boolean;\n  isValidMofNSetup(params: ValidMofNOptions): boolean;\n  isValidAddress(address: string): boolean;\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;\n  getSignablePayload(serializedTx: string): Promise<Buffer>;\n  getMPCAlgorithm(): MPCAlgorithm;\n  // TODO - this only belongs in eth coins\n  recoverToken(params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction>;\n  getInscriptionBuilder(wallet: Wallet): IInscriptionBuilder;\n  getHashFunction(): Hash;\n}\n"]}
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iBaseCoin.js","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/iBaseCoin.ts"],"names":[],"mappings":";;;AA+QA,IAAY,oBAIX;AAJD,WAAY,oBAAoB;IAC9B,iCAAS,CAAA;IACT,iCAAS,CAAA;IACT,iCAAS,CAAA;AACX,CAAC,EAJW,oBAAoB,GAApB,4BAAoB,KAApB,4BAAoB,QAI/B","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { IRequestTracer } from '../../api';\nimport { IEnterprises } from '../enterprise';\nimport { Keychain, IKeychains } from '../keychain';\nimport { IMarkets } from '../market';\nimport { IPendingApprovals } from '../pendingApproval';\nimport { InitiateRecoveryOptions } from '../recovery';\nimport { EcdsaUtils } from '../utils/tss/ecdsa';\nimport EddsaUtils from '../utils/tss/eddsa';\nimport { CustomSigningFunction, IWallet, IWallets, Wallet, WalletData } from '../wallet';\n\nimport { IWebhooks } from '../webhook/iWebhooks';\nimport { BaseTokenConfig } from '@bitgo-beta/statics';\nimport { TransactionType } from '../../account-lib';\nimport { IInscriptionBuilder } from '../inscriptionBuilder';\nimport { Hash } from 'crypto';\n\nexport interface Output extends ITransactionRecipient {\n  address: string;\n  // of form coin:token\n  coinName?: string;\n  isPayGo?: boolean;\n  value?: number;\n  wallet?: string; // Types.ObjectId;\n  walletV1?: string; // Types.ObjectId;\n  baseAddress?: string;\n  enterprise?: string; // Types.ObjectId;\n  valueString: string;\n  data?: string;\n  // \"change\" is a utxo-specific concept and this property should\n  // be removed once it it's usage is refactored out of base coin logic\n  change?: boolean;\n}\n\nexport type Input = {\n  derivationIndex?: number;\n  value: number;\n  address?: string;\n  valueString: string;\n  // the properties below are utxo-related but are currently used in abstractBaseCoin\n  // these should be removed once their usage is removed from the base coin class\n  chain?: number;\n  index?: number;\n};\n\nexport type UnsignedTransaction = {\n  // unsigned transaction in broadcast format\n  serializedTxHex: string;\n  // portion of a transaction used to generate a signature\n  signableHex: string;\n  // transaction fees\n  feeInfo?: {\n    fee: number | BigNumber;\n    feeString: string;\n  };\n  // derivation path of the signer\n  derivationPath: string;\n  coinSpecific?: Record<string, unknown>;\n  entryValues: any;\n  parsedTx: UnsignedParsedTransaction;\n};\n\nexport interface ExplanationResult extends ITransactionExplanation {\n  sequenceId: number;\n  type?: string;\n  outputs: Output[];\n  blockNumber: number | unknown;\n}\n\nexport interface ITransactionRecipient {\n  address: string;\n  amount: string | number;\n  tokenName?: string;\n  memo?: string;\n}\n\nexport interface ITransactionFee<TAmount = string> {\n  fee: TAmount;\n  feeRate?: number;\n  size?: number;\n}\n\nexport interface ITransactionExplanation<TFee = any, TAmount = any> {\n  displayOrder: string[];\n  id: string;\n  outputs: ITransactionRecipient[];\n  outputAmount: TAmount;\n  changeOutputs: ITransactionRecipient[];\n  changeAmount: TAmount;\n  fee: TFee;\n  proxy?: string;\n  producers?: string[];\n}\n\nexport interface KeyPair {\n  pub?: string;\n  prv: string;\n}\n\nexport interface IBlsKeyPair extends KeyPair {\n  secretShares?: string[];\n  chaincode: string;\n  seed?: string;\n}\n\nexport interface VerifyAddressOptions {\n  address: string;\n  addressType?: string;\n  keychains?: {\n    pub: string;\n    commonKeychain?: string;\n  }[];\n  error?: string;\n  coinSpecific?: AddressCoinSpecific;\n  impliedForwarderVersion?: number;\n}\n\nexport interface TssVerifyAddressOptions extends VerifyAddressOptions {\n  chain: string;\n  index: string;\n}\n\nexport interface TransactionParams {\n  recipients?: ITransactionRecipient[];\n  walletPassphrase?: string;\n  type?: string;\n}\n\nexport interface AddressVerificationData {\n  coinSpecific?: AddressCoinSpecific;\n  chain?: number;\n  index?: number;\n}\n\nexport interface VerificationOptions {\n  disableNetworking?: boolean;\n  keychains?: {\n    user?: Keychain;\n    backup?: Keychain;\n    bitgo?: Keychain;\n  };\n  addresses?: { [address: string]: AddressVerificationData };\n  allowPaygoOutput?: boolean;\n  considerMigratedFromAddressInternal?: boolean;\n}\n\nexport interface VerifyTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  txParams: TransactionParams;\n  wallet: Wallet;\n  verification?: VerificationOptions;\n  reqId?: IRequestTracer;\n  walletType?: 'onchain' | 'tss';\n}\n\nexport interface SupplementGenerateWalletOptions {\n  label: string;\n  m: number;\n  n: number;\n  enterprise?: string;\n  disableTransactionNotifications?: boolean;\n  gasPrice?: number | string;\n  eip1559?: {\n    maxFeePerGas: number | string;\n    maxPriorityFeePerGas?: number | string;\n  };\n  walletVersion?: number;\n  keys: string[];\n  isCold: boolean;\n  keySignatures?: {\n    backup: string;\n    bitgo: string;\n  };\n  rootPrivateKey?: string;\n  disableKRSEmail?: boolean;\n  multisigType?: 'tss' | 'onchain' | 'blsdkg';\n}\n\nexport interface FeeEstimateOptions {\n  numBlocks?: number;\n  hop?: boolean;\n  recipient?: string;\n  data?: string;\n  amount?: string;\n  type?: keyof typeof TransactionType;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ExtraPrebuildParamsOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PresignTransactionOptions {\n  txPrebuild?: TransactionPrebuild;\n  walletData: WalletData;\n  tssUtils: EcdsaUtils | EddsaUtils | undefined;\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PrecreateBitGoOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface VerifyRecoveryTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParseTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParsedTransaction {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport type UnsignedParsedTransaction = {\n  inputs: Input[];\n  minerFee: number | string;\n  outputs: Output[];\n  spendAmount: number | string;\n  hasUnvalidatedData?: boolean;\n  payGoFee?: number;\n  type?: string;\n  sequenceId: number;\n  id: string;\n};\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface SignTransactionOptions {\n  [index: string]: unknown;\n}\n\nexport interface KeychainsTriplet {\n  userKeychain: Keychain;\n  backupKeychain: Keychain;\n  bitgoKeychain: Keychain;\n}\n\ninterface BaseSignable {\n  wallet?: IWallet;\n  buildParams?: any;\n  consolidateId?: string;\n  txRequestId?: string;\n}\n\nexport interface TransactionPrebuild extends BaseSignable {\n  txBase64?: string;\n  txHex?: string;\n  txInfo?: unknown;\n}\n\nexport interface Message extends BaseSignable {\n  messageRaw: string;\n  messageEncoded?: string;\n}\n\nexport interface MessageTypeProperty {\n  name: string;\n  type: string;\n}\nexport interface MessageTypes {\n  EIP712Domain: MessageTypeProperty[];\n  [additionalProperties: string]: MessageTypeProperty[];\n}\n\nexport enum SignTypedDataVersion {\n  V1 = 'V1',\n  V3 = 'V3',\n  V4 = 'V4',\n}\n\n/**\n * This is the message format used for `signTypeData`, for all versions\n * except `V1`.\n *\n * @template T - The custom types used by this message.\n * @property types - The custom types used by this message.\n * @property primaryType - The type of the message.\n * @property domain - Signing domain metadata. The signing domain is the intended context for the\n * signature (e.g. the dapp, protocol, etc. that it's intended for). This data is used to\n * construct the domain seperator of the message.\n * @property domain.name - The name of the signing domain.\n * @property domain.version - The current major version of the signing domain.\n * @property domain.chainId - The chain ID of the signing domain.\n * @property domain.verifyingContract - The address of the contract that can verify the signature.\n * @property domain.salt - A disambiguating salt for the protocol.\n * @property message - The message to be signed.\n */\nexport interface TypedMessage<T extends MessageTypes> {\n  types: T;\n  primaryType: keyof T;\n  domain: {\n    name?: string;\n    version?: string;\n    chainId?: number;\n    verifyingContract?: string;\n    salt?: ArrayBuffer;\n  };\n  message: Record<string, unknown>;\n}\n\nexport interface TypedData extends BaseSignable {\n  typedDataRaw: string;\n  version: SignTypedDataVersion;\n  typedDataEncoded?: Buffer;\n}\n\nexport interface AddressCoinSpecific {\n  outputScript?: string;\n  redeemScript?: string;\n  witnessScript?: string;\n  baseAddress?: string;\n  pendingChainInitialization?: boolean;\n  forwarderVersion?: number;\n}\n\nexport interface FullySignedTransaction {\n  txHex: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n}\n\nexport interface HalfSignedUtxoTransaction {\n  txHex: string;\n}\n\nexport interface HalfSignedAccountTransaction {\n  halfSigned?: {\n    txHex?: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n    payload?: string;\n    txBase64?: string;\n  };\n}\n\nexport interface HalfSignedTransaction extends HalfSignedAccountTransaction {\n  halfSigned: {\n    recipients: Recipient[];\n    expireTime?: number;\n    contractSequenceId?: number;\n    sequenceId?: number;\n    txHex?: never;\n  };\n}\n\nexport interface SignedTransactionRequest {\n  txRequestId: string;\n}\n\nexport interface DeriveKeyWithSeedOptions {\n  key: string;\n  seed: string;\n}\n\nexport interface ValidMofNOptions {\n  m?: number;\n  n?: number;\n}\n\nexport type SignedTransaction =\n  | HalfSignedAccountTransaction\n  | HalfSignedUtxoTransaction\n  | FullySignedTransaction\n  | SignedTransactionRequest;\n\nexport interface SignedMessage {\n  coin?: string;\n  txHash: string;\n  messageRaw: string;\n  txRequestId: string;\n}\n\nexport interface RecoverWalletTokenOptions {\n  tokenContractAddress: string;\n  wallet: IWallet;\n  recipient: string;\n  broadcast?: boolean;\n  walletPassphrase?: string;\n  prv?: string;\n}\n\nexport interface Recipient {\n  address: string;\n  amount: string;\n  data?: string;\n}\n\nexport interface RecoverTokenTransaction {\n  halfSigned: {\n    recipient: Recipient;\n    expireTime: number;\n    contractSequenceId: number;\n    operationHash: string;\n    signature: string;\n    gasLimit: number;\n    gasPrice: number;\n    tokenContractAddress: string;\n    walletId: string;\n  };\n}\n\nexport interface TokenEnablementConfig {\n  requiresTokenEnablement: boolean;\n  supportsMultipleTokenEnablements: boolean;\n}\n\nexport interface MessagePrep {\n  encodeMessage(message: string): string;\n}\n\nexport type MPCAlgorithm = 'ecdsa' | 'eddsa';\n\nexport interface IBaseCoin {\n  type: string;\n  tokenConfig?: BaseTokenConfig;\n  url(suffix: string): string;\n  wallets(): IWallets;\n  enterprises(): IEnterprises;\n  keychains(): IKeychains;\n  webhooks(): IWebhooks;\n  pendingApprovals(): IPendingApprovals;\n  markets(): IMarkets;\n  getChain(): string;\n  getFamily(): string;\n  getFullName(): string;\n  valuelessTransferAllowed(): boolean;\n  sweepWithSendMany(): boolean;\n  transactionDataAllowed(): boolean;\n  allowsAccountConsolidations(): boolean;\n  getTokenEnablementConfig(): TokenEnablementConfig;\n  supportsTss(): boolean;\n  isEVM(): boolean;\n  supportsBlsDkg(): boolean;\n  getBaseFactor(): number | string;\n  baseUnitsToBigUnits(baseUnits: string | number): string;\n  bigUnitsToBaseUnits(bigUnits: string | number): string;\n  signMessage(key: { prv: string }, message: string): Promise<Buffer>;\n  createKeySignatures(\n    prv: string,\n    backupKeychain: { pub: string },\n    bitgoKeychain: { pub: string }\n  ): Promise<{\n    backup: string;\n    bitgo: string;\n  }>;\n  explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined>;\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;\n  verifyAddress(params: VerifyAddressOptions): Promise<boolean>;\n  isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;\n  canonicalAddress(address: string, format: unknown): string;\n  supportsBlockTarget(): boolean;\n  supportsLightning(): boolean;\n  supportsMessageSigning(): boolean;\n  supportsSigningTypedData(): boolean;\n  supplementGenerateWallet(walletParams: SupplementGenerateWalletOptions, keychains: KeychainsTriplet): Promise<any>;\n  getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>>;\n  postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild>;\n  presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions>;\n  signWithCustomSigningFunction?(\n    customSigningFunction: CustomSigningFunction,\n    signTransactionParams: { txPrebuild: TransactionPrebuild; pubs?: string[] }\n  ): Promise<SignedTransaction>;\n  newWalletObject(walletParams: any): IWallet;\n  feeEstimate(params: FeeEstimateOptions): Promise<any>;\n  deriveKeyWithSeed(params: DeriveKeyWithSeedOptions): { key: string; derivationPath: string };\n  keyIdsForSigning(): number[];\n  preCreateBitGo(params: PrecreateBitGoOptions): void;\n  initiateRecovery(params: InitiateRecoveryOptions): never;\n  parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;\n  generateKeyPair(seed?: Buffer): KeyPair;\n  isValidPub(pub: string): boolean;\n  isValidMofNSetup(params: ValidMofNOptions): boolean;\n  isValidAddress(address: string): boolean;\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;\n  getSignablePayload(serializedTx: string): Promise<Buffer>;\n  getMPCAlgorithm(): MPCAlgorithm;\n  // TODO - this only belongs in eth coins\n  recoverToken(params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction>;\n  getInscriptionBuilder(wallet: Wallet): IInscriptionBuilder;\n  getHashFunction(): Hash;\n}\n"]}
|
|
@@ -5,7 +5,7 @@ import { EnterpriseData, EnterpriseFeatureFlag, IEnterprise } from '../enterpris
|
|
|
5
5
|
import { Affirmations, Settlements } from '../trading';
|
|
6
6
|
import { Wallet } from '../wallet';
|
|
7
7
|
import { BitGoProofSignatures } from '../utils/tss/ecdsa';
|
|
8
|
-
import {
|
|
8
|
+
import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
|
|
9
9
|
export declare class Enterprise implements IEnterprise {
|
|
10
10
|
private readonly bitgo;
|
|
11
11
|
private readonly baseCoin;
|
|
@@ -75,13 +75,13 @@ export declare class Enterprise implements IEnterprise {
|
|
|
75
75
|
* @param bitgoNitroChallengeProofSignature
|
|
76
76
|
* @param challenge
|
|
77
77
|
*/
|
|
78
|
-
uploadAndEnableTssEcdsaSigning(userPassword: string, bitgoInstChallengeProofSignature: Buffer, bitgoNitroChallengeProofSignature: Buffer, challenge?:
|
|
78
|
+
uploadAndEnableTssEcdsaSigning(userPassword: string, bitgoInstChallengeProofSignature: Buffer, bitgoNitroChallengeProofSignature: Buffer, challenge?: EcdsaTypes.DeserializedNtildeWithProofs): Promise<void>;
|
|
79
79
|
/**
|
|
80
80
|
* Fetches the existing TSS ECDSA enterprise challenge if one exists.
|
|
81
81
|
* Can be used with uploadAndEnableTssEcdsaSigning to re-sign the
|
|
82
82
|
* enterprise challenge with new signatures.
|
|
83
83
|
*/
|
|
84
|
-
getExistingTssEcdsaChallenge(): Promise<
|
|
84
|
+
getExistingTssEcdsaChallenge(): Promise<EcdsaTypes.DeserializedNtildeWithProofs>;
|
|
85
85
|
/**
|
|
86
86
|
* Check if the enterprise has a set of featureFlags
|
|
87
87
|
* @param flags
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"enterprise.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/enterprise.ts"],"names":[],"mappings":";AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAEnF,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,oBAAoB,EAAc,MAAM,oBAAoB,CAAC;AACtE,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"enterprise.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/enterprise.ts"],"names":[],"mappings":";AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAEnF,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,oBAAoB,EAAc,MAAM,oBAAoB,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,qBAAa,UAAW,YAAW,WAAW;IAC5C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAY;IAClC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAY;IACrC,SAAgB,EAAE,EAAE,MAAM,CAAC;IAC3B,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,WAAW,EAAE,cAAc,CAAC;gBAEhC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc;IAiBjF;;;OAGG;IACH,GAAG,CAAC,KAAK,SAAK,GAAG,MAAM;IAIvB;;;OAGG;IACH,OAAO,CAAC,KAAK,SAAK,GAAG,MAAM;IAI3B;;;OAGG;IACG,WAAW,CAAC,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAQxE;;;OAGG;IACG,KAAK,CAAC,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAI7D;;;OAGG;IACG,oBAAoB,CAAC,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAI5E;;;OAGG;IACG,OAAO,CAAC,MAAM,GAAE,GAAQ,GAAG,OAAO,CAAC,GAAG,CAAC;IAI7C;;;OAGG;IACG,UAAU,CAAC,MAAM,GAAE,GAAQ,GAAG,OAAO,CAAC,GAAG,CAAC;IAIhD;;;OAGG;IACG,0BAA0B,CAAC,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAIlF;;OAEG;IACH,WAAW,IAAI,WAAW;IAI1B;;OAEG;IACH,YAAY,IAAI,YAAY;IAI5B;;;OAGG;IACG,+BAA+B,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAI1F;;;;;;;;OAQG;IACG,8BAA8B,CAClC,YAAY,EAAE,MAAM,EACpB,gCAAgC,EAAE,MAAM,EACxC,iCAAiC,EAAE,MAAM,EACzC,SAAS,CAAC,EAAE,UAAU,CAAC,4BAA4B,GAClD,OAAO,CAAC,IAAI,CAAC;IAWhB;;;;OAIG;IACG,4BAA4B,IAAI,OAAO,CAAC,UAAU,CAAC,4BAA4B,CAAC;IAoBtF;;;OAGG;IACH,eAAe,CAAC,KAAK,EAAE,qBAAqB,EAAE,GAAG,OAAO;CAGzD"}
|