@bitgo-beta/sdk-core 8.2.1-beta.475 → 8.2.1-beta.477
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 +11 -0
- package/dist/src/bitgo/lightning/lightningUtils.d.ts +9 -2
- package/dist/src/bitgo/lightning/lightningUtils.d.ts.map +1 -1
- package/dist/src/bitgo/lightning/lightningUtils.js +24 -7
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts +9 -0
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.js +22 -1
- package/dist/src/bitgo/wallet/iWallet.d.ts +43 -0
- 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/iWallets.d.ts +19 -1
- package/dist/src/bitgo/wallet/iWallets.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/iWallets.js +1 -1
- package/dist/src/bitgo/wallet/wallet.d.ts +31 -1
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +109 -2
- package/dist/src/bitgo/wallet/wallets.d.ts +25 -1
- package/dist/src/bitgo/wallet/wallets.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallets.js +75 -1
- package/dist/test/unit/bitgo/lightning/lightningUtils.js +38 -23
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +8 -8
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,17 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [28.4.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@28.3.0...@bitgo/sdk-core@28.4.0) (2024-09-10)
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
- **sdk-core:** generate wallet cleanup ([9cb02bd](https://github.com/BitGo/BitGoJS/commit/9cb02bd60f775da5332fa0fd142db87d2415a2a4))
|
|
11
|
+
|
|
12
|
+
### Features
|
|
13
|
+
|
|
14
|
+
- **express:** add apis to init lnd signer at express ([5c84196](https://github.com/BitGo/BitGoJS/commit/5c84196856194390bfda98cec64058915903da82))
|
|
15
|
+
- **sdk-core:** mark buildSignAndSend and expose buildAndSign ([2ef604d](https://github.com/BitGo/BitGoJS/commit/2ef604df7b337455bd7530575cf089a0eb510301))
|
|
16
|
+
|
|
6
17
|
# [28.3.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@28.2.0...@bitgo/sdk-core@28.3.0) (2024-09-03)
|
|
7
18
|
|
|
8
19
|
### Features
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import * as statics from '@bitgo-beta/statics';
|
|
1
3
|
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
2
4
|
import { WatchOnly } from './codecs';
|
|
3
5
|
export declare const signerMacaroonPermissions: {
|
|
@@ -27,9 +29,9 @@ export declare function isValidLightningNetworkName(networkName: unknown): netwo
|
|
|
27
29
|
*/
|
|
28
30
|
export declare function isValidLightningNetwork(network: unknown): network is utxolib.Network;
|
|
29
31
|
/**
|
|
30
|
-
* Returns the
|
|
32
|
+
* Returns the statics network data for a lightning coin.
|
|
31
33
|
*/
|
|
32
|
-
export declare function
|
|
34
|
+
export declare function getStaticsLightningNetwork(coinName: string): statics.LightningNetwork;
|
|
33
35
|
/**
|
|
34
36
|
* Returns the utxolib network for a lightning coin.
|
|
35
37
|
*/
|
|
@@ -50,4 +52,9 @@ export declare function addIPCaveatToMacaroon(macaroonBase64: string, ip: string
|
|
|
50
52
|
* Creates a watch-only wallet init data from the provided signer root key and network.
|
|
51
53
|
*/
|
|
52
54
|
export declare function createWatchOnly(signerRootKey: string, network: utxolib.Network): WatchOnly;
|
|
55
|
+
/**
|
|
56
|
+
* Derives the shared Elliptic Curve Diffie-Hellman (ECDH) secret between the user's auth extended private key
|
|
57
|
+
* and the Lightning service's public key for secure communication.
|
|
58
|
+
*/
|
|
59
|
+
export declare function deriveLightningServiceSharedSecret(coinName: 'lnbtc' | 'tlnbtc', userAuthXprv: string): Buffer;
|
|
53
60
|
//# sourceMappingURL=lightningUtils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lightningUtils.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/lightning/lightningUtils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"lightningUtils.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/lightning/lightningUtils.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,OAAO,MAAM,qBAAqB,CAAC;AAC/C,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAGhD,OAAO,EAAE,SAAS,EAAoB,MAAM,UAAU,CAAC;AAIvD,eAAO,MAAM,yBAAyB;;;GAiBrC,CAAC;AAEF,eAAO,MAAM,oBAAoB,iCAAkC,CAAC;AACpE,MAAM,MAAM,oBAAoB,GAAG,CAAC,OAAO,oBAAoB,CAAC,CAAC,MAAM,CAAC,CAAC;AAEzE;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,OAAO,GAAG,QAAQ,IAAI,OAAO,GAAG,QAAQ,CAErF;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,WAAW,EAAE,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAEtF;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAErE;AAED;;GAEG;AACH,wBAAgB,2BAA2B,CAAC,WAAW,EAAE,OAAO,GAAG,WAAW,IAAI,oBAAoB,CAErG;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,IAAI,OAAO,CAAC,OAAO,CAEpF;AAED;;GAEG;AACH,wBAAgB,0BAA0B,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CASrF;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAMnE;AAED;;GAEG;AACH,wBAAgB,2BAA2B,CAAC,CAAC,EAAE,GAAG,EAAE;IAAE,KAAK,EAAE,CAAC,CAAA;CAAE,GAAG;IAAE,MAAM,EAAE,CAAC,CAAA;CAAE,EAAE,gBAAgB,EAAE,MAAM,GAAG,CAAC,CAW7G;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,cAAc,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAIhF;AAwED;;GAEG;AACH,wBAAgB,eAAe,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,SAAS,CAS1F;AAED;;;GAGG;AACH,wBAAgB,kCAAkC,CAAC,QAAQ,EAAE,OAAO,GAAG,QAAQ,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAI7G"}
|
|
@@ -23,11 +23,12 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.createWatchOnly = exports.addIPCaveatToMacaroon = exports.unwrapLightningCoinSpecific = exports.getUtxolibNetwork = exports.
|
|
26
|
+
exports.deriveLightningServiceSharedSecret = exports.createWatchOnly = exports.addIPCaveatToMacaroon = exports.unwrapLightningCoinSpecific = exports.getUtxolibNetwork = exports.getStaticsLightningNetwork = exports.isValidLightningNetwork = exports.isValidLightningNetworkName = exports.getLightningCoinName = exports.getLightningNetwork = exports.isLightningCoinName = exports.lightningNetworkName = exports.signerMacaroonPermissions = void 0;
|
|
27
27
|
const statics = __importStar(require("@bitgo-beta/statics"));
|
|
28
28
|
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
29
29
|
const macaroon_1 = require("macaroon");
|
|
30
30
|
const bs58check = __importStar(require("bs58check"));
|
|
31
|
+
const ecdh_1 = require("../ecdh");
|
|
31
32
|
// https://github.com/lightningnetwork/lnd/blob/master/docs/remote-signing.md#the-signer-node
|
|
32
33
|
exports.signerMacaroonPermissions = [
|
|
33
34
|
{
|
|
@@ -84,18 +85,24 @@ function isValidLightningNetwork(network) {
|
|
|
84
85
|
}
|
|
85
86
|
exports.isValidLightningNetwork = isValidLightningNetwork;
|
|
86
87
|
/**
|
|
87
|
-
* Returns the
|
|
88
|
+
* Returns the statics network data for a lightning coin.
|
|
88
89
|
*/
|
|
89
|
-
function
|
|
90
|
+
function getStaticsLightningNetwork(coinName) {
|
|
91
|
+
if (!isLightningCoinName(coinName)) {
|
|
92
|
+
throw new Error(`${coinName} is not a lightning coin`);
|
|
93
|
+
}
|
|
90
94
|
const coin = statics.coins.get(coinName);
|
|
91
|
-
|
|
95
|
+
if (!(coin instanceof statics.LightningCoin)) {
|
|
96
|
+
throw new Error('coin is not a lightning coin');
|
|
97
|
+
}
|
|
98
|
+
return coin.network;
|
|
92
99
|
}
|
|
93
|
-
exports.
|
|
100
|
+
exports.getStaticsLightningNetwork = getStaticsLightningNetwork;
|
|
94
101
|
/**
|
|
95
102
|
* Returns the utxolib network for a lightning coin.
|
|
96
103
|
*/
|
|
97
104
|
function getUtxolibNetwork(coinName) {
|
|
98
|
-
const networkName =
|
|
105
|
+
const networkName = getStaticsLightningNetwork(coinName).utxolibName;
|
|
99
106
|
if (!isValidLightningNetworkName(networkName)) {
|
|
100
107
|
throw new Error('invalid lightning network');
|
|
101
108
|
}
|
|
@@ -194,4 +201,14 @@ function createWatchOnly(signerRootKey, network) {
|
|
|
194
201
|
return { master_key_birthday_timestamp, master_key_fingerprint, accounts };
|
|
195
202
|
}
|
|
196
203
|
exports.createWatchOnly = createWatchOnly;
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightningUtils.js","sourceRoot":"","sources":["../../../../src/bitgo/lightning/lightningUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as statics from '@bitgo-beta/statics';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { importMacaroon, bytesToBase64 } from 'macaroon';\nimport * as bs58check from 'bs58check';\nimport { WatchOnly, WatchOnlyAccount } from './codecs';\n\n// https://github.com/lightningnetwork/lnd/blob/master/docs/remote-signing.md#the-signer-node\nexport const signerMacaroonPermissions = [\n  {\n    entity: 'message',\n    action: 'write',\n  },\n  {\n    entity: 'signer',\n    action: 'generate',\n  },\n  {\n    entity: 'address',\n    action: 'read',\n  },\n  {\n    entity: 'onchain',\n    action: 'write',\n  },\n];\n\nexport const lightningNetworkName = ['bitcoin', 'testnet'] as const;\nexport type LightningNetworkName = (typeof lightningNetworkName)[number];\n\n/**\n * Checks if the coin name is a lightning coin name.\n */\nexport function isLightningCoinName(coinName: unknown): coinName is 'lnbtc' | 'tlnbtc' {\n  return coinName === 'lnbtc' || coinName === 'tlnbtc';\n}\n\n/**\n * Get the utxolib network for a lightning network.\n */\nexport function getLightningNetwork(networkName: LightningNetworkName): utxolib.Network {\n  return utxolib.networks[networkName];\n}\n\n/**\n * Get the lightning coin name for a utxolib network.\n */\nexport function getLightningCoinName(network: utxolib.Network): string {\n  return network === utxolib.networks.bitcoin ? 'lnbtc' : 'tlnbtc';\n}\n\n/**\n * Checks if the network name is a valid lightning network name.\n */\nexport function isValidLightningNetworkName(networkName: unknown): networkName is LightningNetworkName {\n  return lightningNetworkName.includes(networkName as LightningNetworkName);\n}\n\n/**\n * Checks if the network is a valid lightning network.\n */\nexport function isValidLightningNetwork(network: unknown): network is utxolib.Network {\n  return utxolib.isValidNetwork(network) && isValidLightningNetworkName(utxolib.getNetworkName(network));\n}\n\n/**\n * Returns the utxolib network name for a lightning coin.\n */\nexport function getUtxolibNetworkName(coinName: string): string | undefined {\n  const coin = statics.coins.get(coinName);\n  return coin instanceof statics.LightningCoin ? coin.network.utxolibName : undefined;\n}\n\n/**\n * Returns the utxolib network for a lightning coin.\n */\nexport function getUtxolibNetwork(coinName: string): utxolib.Network {\n  const networkName = getUtxolibNetworkName(coinName);\n  if (!isValidLightningNetworkName(networkName)) {\n    throw new Error('invalid lightning network');\n  }\n  return getLightningNetwork(networkName);\n}\n\n/**\n * Returns coin specific data for a lightning coin.\n */\nexport function unwrapLightningCoinSpecific<V>(obj: { lnbtc: V } | { tlnbtc: V }, coinSpecificPath: string): V {\n  if (coinSpecificPath !== 'lnbtc' && coinSpecificPath !== 'tlnbtc') {\n    throw new Error(`invalid coinSpecificPath ${coinSpecificPath} for lightning coin`);\n  }\n  if (coinSpecificPath === 'lnbtc' && 'lnbtc' in obj) {\n    return obj.lnbtc;\n  }\n  if (coinSpecificPath === 'tlnbtc' && 'tlnbtc' in obj) {\n    return obj.tlnbtc;\n  }\n  throw new Error('invalid lightning coin specific');\n}\n\n/**\n * Adds an IP caveat to a macaroon and returns the modified macaroon as a Base64 string.\n */\nexport function addIPCaveatToMacaroon(macaroonBase64: string, ip: string): string {\n  const macaroon = importMacaroon(macaroonBase64);\n  macaroon.addFirstPartyCaveat(`ipaddr ${ip}`);\n  return bytesToBase64(macaroon.exportBinary());\n}\n\nconst PURPOSE_WRAPPED_P2WKH = 49;\nconst PURPOSE_P2WKH = 84;\nconst PURPOSE_P2TR = 86;\nconst PURPOSE_ALL_OTHERS = 1017;\n\ntype ExtendedKeyPurpose =\n  | typeof PURPOSE_WRAPPED_P2WKH\n  | typeof PURPOSE_P2WKH\n  | typeof PURPOSE_P2TR\n  | typeof PURPOSE_ALL_OTHERS;\n\n/**\n * Converts an extended public key (xpub) to the appropriate prefix (ypub, vpub, etc.) based on its purpose and network.\n */\nfunction convertXpubPrefix(xpub: string, purpose: ExtendedKeyPurpose, isMainnet: boolean): string {\n  if (purpose === PURPOSE_P2TR || purpose === PURPOSE_ALL_OTHERS) {\n    return xpub;\n  }\n  const data = bs58check.decode(xpub);\n\n  let versionBytes: Buffer;\n\n  switch (purpose) {\n    case PURPOSE_WRAPPED_P2WKH:\n      versionBytes = isMainnet ? Buffer.from([0x04, 0x9d, 0x7c, 0xb2]) : Buffer.from([0x04, 0x4a, 0x52, 0x62]); // ypub/upub for p2sh-p2wpkh\n      break;\n    case PURPOSE_P2WKH:\n      versionBytes = isMainnet ? Buffer.from([0x04, 0xb2, 0x47, 0x46]) : Buffer.from([0x04, 0x5f, 0x1c, 0xf6]); // zpub/vpub for p2wpkh\n      break;\n    default:\n      throw new Error('Unsupported purpose');\n  }\n\n  versionBytes.copy(data, 0, 0, 4);\n  return bs58check.encode(data);\n}\n\n/**\n * Derives watch-only accounts from the master HD node for the given purposes and network.\n */\nfunction deriveWatchOnlyAccounts(masterHDNode: utxolib.BIP32Interface, isMainnet: boolean): WatchOnlyAccount[] {\n  // https://github.com/lightningnetwork/lnd/blob/master/docs/remote-signing.md#required-accounts\n  if (masterHDNode.isNeutered()) {\n    throw new Error('masterHDNode must not be neutered');\n  }\n\n  const purposes = [PURPOSE_WRAPPED_P2WKH, PURPOSE_P2WKH, PURPOSE_P2TR, PURPOSE_ALL_OTHERS] as const;\n\n  return purposes.flatMap((purpose) => {\n    const maxAccount = purpose === PURPOSE_ALL_OTHERS ? 255 : 0;\n    const coinType = purpose !== PURPOSE_ALL_OTHERS || isMainnet ? 0 : 1;\n\n    return Array.from({ length: maxAccount + 1 }, (_, account) => {\n      const path = `m/${purpose}'/${coinType}'/${account}'`;\n      const derivedNode = masterHDNode.derivePath(path);\n\n      // Ensure the node is neutered (i.e., converted to public key only)\n      const neuteredNode = derivedNode.neutered();\n      const xpub = convertXpubPrefix(neuteredNode.toBase58(), purpose, isMainnet);\n\n      return {\n        purpose,\n        coin_type: coinType,\n        account,\n        xpub,\n      };\n    });\n  });\n}\n\n/**\n * Creates a watch-only wallet init data from the provided signer root key and network.\n */\nexport function createWatchOnly(signerRootKey: string, network: utxolib.Network): WatchOnly {\n  const masterHDNode = utxolib.bip32.fromBase58(signerRootKey, network);\n  const getCurrentUnixTimestamp = () => {\n    return Math.floor(Date.now() / 1000);\n  };\n  const master_key_birthday_timestamp = getCurrentUnixTimestamp().toString();\n  const master_key_fingerprint = masterHDNode.fingerprint.toString('hex');\n  const accounts = deriveWatchOnlyAccounts(masterHDNode, utxolib.isMainnet(network));\n  return { master_key_birthday_timestamp, master_key_fingerprint, accounts };\n}\n"]}
|
|
204
|
+
/**
|
|
205
|
+
* Derives the shared Elliptic Curve Diffie-Hellman (ECDH) secret between the user's auth extended private key
|
|
206
|
+
* and the Lightning service's public key for secure communication.
|
|
207
|
+
*/
|
|
208
|
+
function deriveLightningServiceSharedSecret(coinName, userAuthXprv) {
|
|
209
|
+
const publicKey = Buffer.from(getStaticsLightningNetwork(coinName).lightningServicePubKey, 'hex');
|
|
210
|
+
const userAuthHdNode = utxolib.bip32.fromBase58(userAuthXprv);
|
|
211
|
+
return (0, ecdh_1.getSharedSecret)(userAuthHdNode, publicKey);
|
|
212
|
+
}
|
|
213
|
+
exports.deriveLightningServiceSharedSecret = deriveLightningServiceSharedSecret;
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightningUtils.js","sourceRoot":"","sources":["../../../../src/bitgo/lightning/lightningUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as statics from '@bitgo-beta/statics';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { importMacaroon, bytesToBase64 } from 'macaroon';\nimport * as bs58check from 'bs58check';\nimport { WatchOnly, WatchOnlyAccount } from './codecs';\nimport { getSharedSecret } from '../ecdh';\n\n// https://github.com/lightningnetwork/lnd/blob/master/docs/remote-signing.md#the-signer-node\nexport const signerMacaroonPermissions = [\n  {\n    entity: 'message',\n    action: 'write',\n  },\n  {\n    entity: 'signer',\n    action: 'generate',\n  },\n  {\n    entity: 'address',\n    action: 'read',\n  },\n  {\n    entity: 'onchain',\n    action: 'write',\n  },\n];\n\nexport const lightningNetworkName = ['bitcoin', 'testnet'] as const;\nexport type LightningNetworkName = (typeof lightningNetworkName)[number];\n\n/**\n * Checks if the coin name is a lightning coin name.\n */\nexport function isLightningCoinName(coinName: unknown): coinName is 'lnbtc' | 'tlnbtc' {\n  return coinName === 'lnbtc' || coinName === 'tlnbtc';\n}\n\n/**\n * Get the utxolib network for a lightning network.\n */\nexport function getLightningNetwork(networkName: LightningNetworkName): utxolib.Network {\n  return utxolib.networks[networkName];\n}\n\n/**\n * Get the lightning coin name for a utxolib network.\n */\nexport function getLightningCoinName(network: utxolib.Network): string {\n  return network === utxolib.networks.bitcoin ? 'lnbtc' : 'tlnbtc';\n}\n\n/**\n * Checks if the network name is a valid lightning network name.\n */\nexport function isValidLightningNetworkName(networkName: unknown): networkName is LightningNetworkName {\n  return lightningNetworkName.includes(networkName as LightningNetworkName);\n}\n\n/**\n * Checks if the network is a valid lightning network.\n */\nexport function isValidLightningNetwork(network: unknown): network is utxolib.Network {\n  return utxolib.isValidNetwork(network) && isValidLightningNetworkName(utxolib.getNetworkName(network));\n}\n\n/**\n * Returns the statics network data for a lightning coin.\n */\nexport function getStaticsLightningNetwork(coinName: string): statics.LightningNetwork {\n  if (!isLightningCoinName(coinName)) {\n    throw new Error(`${coinName} is not a lightning coin`);\n  }\n  const coin = statics.coins.get(coinName);\n  if (!(coin instanceof statics.LightningCoin)) {\n    throw new Error('coin is not a lightning coin');\n  }\n  return coin.network;\n}\n\n/**\n * Returns the utxolib network for a lightning coin.\n */\nexport function getUtxolibNetwork(coinName: string): utxolib.Network {\n  const networkName = getStaticsLightningNetwork(coinName).utxolibName;\n  if (!isValidLightningNetworkName(networkName)) {\n    throw new Error('invalid lightning network');\n  }\n  return getLightningNetwork(networkName);\n}\n\n/**\n * Returns coin specific data for a lightning coin.\n */\nexport function unwrapLightningCoinSpecific<V>(obj: { lnbtc: V } | { tlnbtc: V }, coinSpecificPath: string): V {\n  if (coinSpecificPath !== 'lnbtc' && coinSpecificPath !== 'tlnbtc') {\n    throw new Error(`invalid coinSpecificPath ${coinSpecificPath} for lightning coin`);\n  }\n  if (coinSpecificPath === 'lnbtc' && 'lnbtc' in obj) {\n    return obj.lnbtc;\n  }\n  if (coinSpecificPath === 'tlnbtc' && 'tlnbtc' in obj) {\n    return obj.tlnbtc;\n  }\n  throw new Error('invalid lightning coin specific');\n}\n\n/**\n * Adds an IP caveat to a macaroon and returns the modified macaroon as a Base64 string.\n */\nexport function addIPCaveatToMacaroon(macaroonBase64: string, ip: string): string {\n  const macaroon = importMacaroon(macaroonBase64);\n  macaroon.addFirstPartyCaveat(`ipaddr ${ip}`);\n  return bytesToBase64(macaroon.exportBinary());\n}\n\nconst PURPOSE_WRAPPED_P2WKH = 49;\nconst PURPOSE_P2WKH = 84;\nconst PURPOSE_P2TR = 86;\nconst PURPOSE_ALL_OTHERS = 1017;\n\ntype ExtendedKeyPurpose =\n  | typeof PURPOSE_WRAPPED_P2WKH\n  | typeof PURPOSE_P2WKH\n  | typeof PURPOSE_P2TR\n  | typeof PURPOSE_ALL_OTHERS;\n\n/**\n * Converts an extended public key (xpub) to the appropriate prefix (ypub, vpub, etc.) based on its purpose and network.\n */\nfunction convertXpubPrefix(xpub: string, purpose: ExtendedKeyPurpose, isMainnet: boolean): string {\n  if (purpose === PURPOSE_P2TR || purpose === PURPOSE_ALL_OTHERS) {\n    return xpub;\n  }\n  const data = bs58check.decode(xpub);\n\n  let versionBytes: Buffer;\n\n  switch (purpose) {\n    case PURPOSE_WRAPPED_P2WKH:\n      versionBytes = isMainnet ? Buffer.from([0x04, 0x9d, 0x7c, 0xb2]) : Buffer.from([0x04, 0x4a, 0x52, 0x62]); // ypub/upub for p2sh-p2wpkh\n      break;\n    case PURPOSE_P2WKH:\n      versionBytes = isMainnet ? Buffer.from([0x04, 0xb2, 0x47, 0x46]) : Buffer.from([0x04, 0x5f, 0x1c, 0xf6]); // zpub/vpub for p2wpkh\n      break;\n    default:\n      throw new Error('Unsupported purpose');\n  }\n\n  versionBytes.copy(data, 0, 0, 4);\n  return bs58check.encode(data);\n}\n\n/**\n * Derives watch-only accounts from the master HD node for the given purposes and network.\n */\nfunction deriveWatchOnlyAccounts(masterHDNode: utxolib.BIP32Interface, isMainnet: boolean): WatchOnlyAccount[] {\n  // https://github.com/lightningnetwork/lnd/blob/master/docs/remote-signing.md#required-accounts\n  if (masterHDNode.isNeutered()) {\n    throw new Error('masterHDNode must not be neutered');\n  }\n\n  const purposes = [PURPOSE_WRAPPED_P2WKH, PURPOSE_P2WKH, PURPOSE_P2TR, PURPOSE_ALL_OTHERS] as const;\n\n  return purposes.flatMap((purpose) => {\n    const maxAccount = purpose === PURPOSE_ALL_OTHERS ? 255 : 0;\n    const coinType = purpose !== PURPOSE_ALL_OTHERS || isMainnet ? 0 : 1;\n\n    return Array.from({ length: maxAccount + 1 }, (_, account) => {\n      const path = `m/${purpose}'/${coinType}'/${account}'`;\n      const derivedNode = masterHDNode.derivePath(path);\n\n      // Ensure the node is neutered (i.e., converted to public key only)\n      const neuteredNode = derivedNode.neutered();\n      const xpub = convertXpubPrefix(neuteredNode.toBase58(), purpose, isMainnet);\n\n      return {\n        purpose,\n        coin_type: coinType,\n        account,\n        xpub,\n      };\n    });\n  });\n}\n\n/**\n * Creates a watch-only wallet init data from the provided signer root key and network.\n */\nexport function createWatchOnly(signerRootKey: string, network: utxolib.Network): WatchOnly {\n  const masterHDNode = utxolib.bip32.fromBase58(signerRootKey, network);\n  const getCurrentUnixTimestamp = () => {\n    return Math.floor(Date.now() / 1000);\n  };\n  const master_key_birthday_timestamp = getCurrentUnixTimestamp().toString();\n  const master_key_fingerprint = masterHDNode.fingerprint.toString('hex');\n  const accounts = deriveWatchOnlyAccounts(masterHDNode, utxolib.isMainnet(network));\n  return { master_key_birthday_timestamp, master_key_fingerprint, accounts };\n}\n\n/**\n * Derives the shared Elliptic Curve Diffie-Hellman (ECDH) secret between the user's auth extended private key\n * and the Lightning service's public key for secure communication.\n */\nexport function deriveLightningServiceSharedSecret(coinName: 'lnbtc' | 'tlnbtc', userAuthXprv: string): Buffer {\n  const publicKey = Buffer.from(getStaticsLightningNetwork(coinName).lightningServicePubKey, 'hex');\n  const userAuthHdNode = utxolib.bip32.fromBase58(userAuthXprv);\n  return getSharedSecret(userAuthHdNode, publicKey);\n}\n"]}
|
|
@@ -6,6 +6,7 @@ import { MPCv2BroadcastMessage, MPCv2KeyGenRound1Response, MPCv2KeyGenRound2Resp
|
|
|
6
6
|
import { Ecdsa } from '../../../../account-lib';
|
|
7
7
|
import { Keychain } from '../../../keychain';
|
|
8
8
|
import { DecryptedRetrofitPayload } from '../../../keychain/iKeychains';
|
|
9
|
+
import { MPCv2PartiesEnum } from './typesMPCv2';
|
|
9
10
|
import { CustomMPCv2SigningRound1GeneratingFunction, CustomMPCv2SigningRound2GeneratingFunction, CustomMPCv2SigningRound3GeneratingFunction, RequestType, SignatureShareRecord, TSSParams, TSSParamsForMessage, TSSParamsForMessageWithPrv, TSSParamsWithPrv, TxRequest } from '../baseTypes';
|
|
10
11
|
import { BaseEcdsaUtils } from './base';
|
|
11
12
|
export declare class EcdsaMPCv2Utils extends BaseEcdsaUtils {
|
|
@@ -17,6 +18,14 @@ export declare class EcdsaMPCv2Utils extends BaseEcdsaUtils {
|
|
|
17
18
|
retrofit?: DecryptedRetrofitPayload;
|
|
18
19
|
}): Promise<KeychainsTriplet>;
|
|
19
20
|
createParticipantKeychain(participantIndex: MPCv2PartyFromStringOrNumber, commonKeychain: string, privateMaterial?: Buffer, reducedPrivateMaterial?: Buffer, passphrase?: string, originalPasscodeEncryptionCode?: string): Promise<Keychain>;
|
|
21
|
+
/**
|
|
22
|
+
* Converts a User or Backup MPCv1 SigningMaterial to RetrofitData needed by MPCv2 DKG.
|
|
23
|
+
*
|
|
24
|
+
* @param decryptedKeyshare - MPCv1 decrypted signing material for user or backup as a json.stringify string and bitgo's Big Si.
|
|
25
|
+
* @param partyId - The party ID of the MPCv1 keyshare.
|
|
26
|
+
* @returns The retrofit data needed to start an MPCv2 DKG session.
|
|
27
|
+
*/
|
|
28
|
+
getKeyDataForRetrofit(decryptedKeyshare: string, partyId: MPCv2PartiesEnum.BACKUP | MPCv2PartiesEnum.USER): DklsTypes.RetrofitData;
|
|
20
29
|
/**
|
|
21
30
|
* Converts user and backup MPCv1 SigningMaterial to RetrofitData needed by MPCv2 DKG.
|
|
22
31
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ecdsaMPCv2.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.ts"],"names":[],"mappings":";AAAA,OAAO,EAAiD,SAAS,EAAa,MAAM,yBAAyB,CAAC;AAG9G,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAKhC,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAEL,qBAAqB,EACrB,yBAAyB,EACzB,yBAAyB,EACzB,yBAAyB,EAGzB,eAAe,EACf,4BAA4B,EAG7B,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AAChD,OAAO,EAAsB,QAAQ,EAAW,MAAM,mBAAmB,CAAC;AAC1E,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"ecdsaMPCv2.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.ts"],"names":[],"mappings":"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"}
|