Socket
Socket
Sign inDemoInstall

@bitgo/sdk-core

Package Overview
Dependencies
Maintainers
14
Versions
185
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bitgo/sdk-core - npm Package Compare versions

Comparing version 27.7.0 to 27.8.0

1

dist/src/bitgo/environments.d.ts

@@ -51,2 +51,3 @@ /**

hmacVerificationEnforced: boolean;
suiNodeUrl: string;
}

@@ -53,0 +54,0 @@ export interface Environment extends EnvironmentTemplate {

4

dist/src/bitgo/environments.js

@@ -67,2 +67,3 @@ "use strict";

hmacVerificationEnforced: true,
suiNodeUrl: 'https://fullnode.mainnet.sui.io',
};

@@ -116,2 +117,3 @@ const testnetBase = {

hmacVerificationEnforced: false,
suiNodeUrl: 'https://fullnode.testnet.sui.io',
};

@@ -199,2 +201,2 @@ const devBase = Object.assign({}, testnetBase, {

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environments.js","sourceRoot":"","sources":["../../../src/bitgo/environments.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport { V1Network } from './types';\n\ninterface EnvironmentTemplate {\n  uri?: string;\n  network: V1Network;\n  signingAddress: string;\n  serverXpub: string;\n  hsmXpub: string;\n  btcExplorerBaseUrl: string;\n  etherscanBaseUrl: string;\n  etherscanApiToken?: string;\n  avaxcNetworkBaseUrl: string;\n  eth2ExplorerBaseUrl: string;\n  ethwFullNodeRPCBaseUrl: string;\n  polygonscanBaseUrl?: string;\n  bscscanBaseUrl?: string;\n  bscscanApiToken?: string;\n  polygonscanApiToken?: string;\n  arbiscanBaseUrl?: string;\n  arbiscanApiToken?: string;\n  optimisticEtherscanBaseUrl?: string;\n  optimisticEtherscanApiToken?: string;\n  zksyncExplorerBaseUrl?: string;\n  zksyncExplorerApiToken?: string;\n  baseethExplorerUrl?: string;\n  baseethApiToken?: string;\n  stellarFederationServerUrl?: string;\n  eosNodeUrls: string[];\n  nearNodeUrls: string[];\n  solNodeUrl: string;\n  adaNodeUrl: string;\n  hashNodeUrl: string;\n  injNodeUrl: string;\n  atomNodeUrl: string;\n  osmoNodeUrl: string;\n  tiaNodeUrl: string;\n  seiNodeUrl: string;\n  bldNodeUrl: string;\n  beraNodeUrl: string;\n  zetaNodeUrl: string;\n  coreumNodeUrl: string;\n  islmNodeUrl: string;\n  dotNodeUrls: string[];\n  tronNodes: {\n    full: string;\n    solidity: string;\n  };\n  hmacVerificationEnforced: boolean;\n}\n\nexport interface Environment extends EnvironmentTemplate {\n  uri: string;\n  stellarFederationServerUrl: string;\n}\n\nexport const hardcodedPublicKeys = Object.freeze({\n  serverXpub: {\n    prod: 'xpub661MyMwAqRbcEtUgu9HF8ai4ipuVKKHBzUqks4jSFypW8dwwQL1zygLgQx99NmC7zJJznSiwKG6RQfVjAKMtCsx8VjR6kQW8x7HrkXFZdnQ',\n    test: 'xpub661MyMwAqRbcErFqVXGiUFv9YeoPbhN72UiNCUdj9nj3T6M8h7iKNmbCYpMVWVZP7LA2ma3HWcPngz1gRTm4FPdtm9mHfrNvU93MCoszsGL',\n  },\n  hsmXpub: {\n    prod: 'xpub661MyMwAqRbcGEtTFgMAoxMFoqsRdDaiaR63byNfZdV7cBZFvovQSNJ5bpyeoQtuKVgXBk6sFQ7TtvyWqadt41DnKwveYgM5KoU2EKYjdY2',\n    test: 'xpub661MyMwAqRbcGFKe4Bqvk4Sgric4gNFC8pUbw4tUkVjZxubjCA522gPzc1YaXb3bQVmDWc7CjG8AGNWRpcdAU38RETBh8n2bnqEU4kbV4oK',\n    dev: 'xpub661MyMwAqRbcFWzoz8qnYRDYEFQpPLYwxVFoG6WLy3ck5ZupRGJTG4ju6yGb7Dj3ey6GsC4kstLRER2nKzgjLtmxyPgC4zHy7kVhUt6yfGn',\n  },\n});\n\nexport type EnvironmentName =\n  | 'prod'\n  | 'staging'\n  | 'test'\n  | 'dev'\n  | 'latest'\n  | 'local'\n  | 'localNonSecure'\n  | 'mock'\n  | 'adminProd'\n  | 'adminTest'\n  | 'adminDev'\n  | 'adminLatest'\n  | 'custom'\n  | 'branch';\n\nexport type AliasEnvironmentName = 'production' | 'msProd' | 'msTest' | 'msDev' | 'msLatest';\n\nexport type Environments = { [k in EnvironmentName]: Environment };\n\n// alias environments are environment names which are aliases of a supported environment\nexport const AliasEnvironments: { [k in AliasEnvironmentName]: EnvironmentName } = {\n  production: 'prod',\n  msProd: 'prod',\n  msTest: 'test',\n  msDev: 'dev',\n  msLatest: 'latest',\n};\n\nconst mainnetBase: EnvironmentTemplate = {\n  network: 'bitcoin' as V1Network,\n  signingAddress: '1BitGo3gxRZ6mQSEH52dvCKSUgVCAH4Rja',\n  serverXpub: hardcodedPublicKeys.serverXpub.prod,\n  hsmXpub: hardcodedPublicKeys.hsmXpub.prod,\n  btcExplorerBaseUrl: 'https://blockstream.info/api',\n  etherscanBaseUrl: 'https://api.etherscan.io',\n  etherscanApiToken: process.env.ETHERSCAN_API_TOKEN,\n  avaxcNetworkBaseUrl: 'https://api.avax.network',\n  eth2ExplorerBaseUrl: 'https://beaconscan.com/api',\n  ethwFullNodeRPCBaseUrl: 'https://mainnet.ethereumpow.org',\n  bscscanBaseUrl: 'https://api.bscscan.com',\n  bscscanApiToken: process.env.BSC_API_TOKEN,\n  polygonscanBaseUrl: 'https://api.polygonscan.com',\n  polygonscanApiToken: process.env.POLYGONSCAN_API_TOKEN,\n  arbiscanBaseUrl: 'https://api.arbiscan.io',\n  arbiscanApiToken: process.env.ARBISCAN_API_TOKEN,\n  optimisticEtherscanBaseUrl: 'https://api-optimistic.etherscan.io',\n  optimisticEtherscanApiToken: process.env.OPTIMISTIC_ETHERSCAN_API_TOKEN,\n  zksyncExplorerBaseUrl: 'https://block-explorer-api.mainnet.zksync.io',\n  zksyncExplorerApiToken: process.env.ZKSYNC_EXPLORER_API_TOKEN,\n  baseethExplorerUrl: 'https://api.basescan.org',\n  baseethApiToken: process.env.BASESCAN_API_TOKEN,\n  eosNodeUrls: ['https://bp.cryptolions.io', 'https://api.eosnewyork.io', 'https://api.eosdetroit.io'],\n  nearNodeUrls: ['https://rpc.mainnet.near.org'],\n  solNodeUrl: 'https://api.mainnet-beta.solana.com',\n  adaNodeUrl: 'https://api.koios.rest/api/v0',\n  hashNodeUrl: 'https://api.provenance.io',\n  injNodeUrl: 'https://sentry.lcd.injective.network', // reference https://docs.injective.network/develop/public-endpoints/\n  atomNodeUrl: 'https://rest.cosmos.directory/cosmoshub/',\n  osmoNodeUrl: 'https://lcd.osmosis.zone',\n  tiaNodeUrl: 'https://public-celestia-lcd.numia.xyz', // reference https://docs.celestia.org/nodes/mainnet#api-endpoints\n  seiNodeUrl: 'https://sei-api.polkachu.com',\n  bldNodeUrl: 'https://agoric-api.polkachu.com',\n  beraNodeUrl: '', // TODO(WIN-693): update url when mainnet goes live\n  zetaNodeUrl: 'https://zetachain.blockpi.network', // reference https://www.zetachain.com/docs/reference/api/\n  coreumNodeUrl: 'https://full-node.mainnet-1.coreum.dev:1317',\n  islmNodeUrl: 'https://rest.cosmos.haqq.network',\n  dotNodeUrls: ['wss://rpc.polkadot.io'],\n  tronNodes: {\n    full: 'https://api.trongrid.io',\n    solidity: 'https://api.trongrid.io',\n  },\n  hmacVerificationEnforced: true,\n};\n\nconst testnetBase: EnvironmentTemplate = {\n  network: 'testnet' as V1Network,\n  signingAddress: 'msignBdFXteehDEgB6DNm7npRt7AcEZJP3',\n  serverXpub: hardcodedPublicKeys.serverXpub.test,\n  hsmXpub: hardcodedPublicKeys.hsmXpub.test,\n  btcExplorerBaseUrl: 'https://blockstream.info/testnet/api',\n  etherscanBaseUrl: 'https://api-holesky.etherscan.io',\n  etherscanApiToken: process.env.ETHERSCAN_API_TOKEN,\n  avaxcNetworkBaseUrl: 'https://api.avax-test.network',\n  eth2ExplorerBaseUrl: 'https://beaconscan.com/api',\n  ethwFullNodeRPCBaseUrl: 'https://mainnet.ethereumpow.org',\n  polygonscanBaseUrl: 'https://api-amoy.polygonscan.com',\n  polygonscanApiToken: process.env.POLYGONSCAN_API_TOKEN,\n  bscscanBaseUrl: 'https://api-testnet.bscscan.com',\n  bscscanApiToken: process.env.BSC_API_TOKEN,\n  arbiscanBaseUrl: 'https://api-sepolia.arbiscan.io',\n  arbiscanApiToken: process.env.ARBISCAN_API_TOKEN,\n  optimisticEtherscanBaseUrl: 'https://api-sepolia-optimistic.etherscan.io',\n  optimisticEtherscanApiToken: process.env.OPTIMISTIC_ETHERSCAN_API_TOKEN,\n  zksyncExplorerBaseUrl: 'https://block-explorer-api.sepolia.zksync.dev',\n  zksyncExplorerApiToken: process.env.ZKSYNC_EXPLORER_API_TOKEN,\n  baseethExplorerUrl: 'https://api-sepolia.basescan.org',\n  baseethApiToken: process.env.BASESCAN_API_TOKEN,\n  // kylin eos endpoints found here\n  // https://github.com/cryptokylin/CryptoKylin-Testnet#http-api-list\n  // https://docs.liquidapps.io/liquidapps-documentation/eosio-guides/testnet-creation-guides/creating-cryptokylin-account#setup\n  eosNodeUrls: ['https://kylin.eosn.io', 'https://api.kylin.alohaeos.com'],\n  nearNodeUrls: ['https://rpc.testnet.near.org'],\n  solNodeUrl: 'https://api.devnet.solana.com',\n  adaNodeUrl: 'https://preprod.koios.rest/api/v0',\n  hashNodeUrl: 'https://api.test.provenance.io',\n  injNodeUrl: 'https://testnet.sentry.lcd.injective.network', // COIN-1219 : reference  https://docs.injective.network/develop/public-endpoints/#testnet\n  atomNodeUrl: 'https://rest.sentry-02.theta-testnet.polypore.xyz/',\n  osmoNodeUrl: 'https://lcd.osmotest5.osmosis.zone',\n  tiaNodeUrl: 'https://api-mocha.pops.one',\n  seiNodeUrl: 'https://rest.atlantic-2.seinetwork.io',\n  bldNodeUrl: 'https://devnet.api.agoric.net',\n  beraNodeUrl: '', // TODO(WIN-693): update url when testnet goes live\n  zetaNodeUrl: 'https://rest.nodejumper.io/zetachaintestnet', // reference : https://www.zetachain.com/docs/reference/api/\n  coreumNodeUrl: 'https://full-node.testnet-1.coreum.dev:1317',\n  islmNodeUrl: 'https://rest.cosmos.testedge2.haqq.network ',\n  dotNodeUrls: ['wss://westend-rpc.polkadot.io'],\n  tronNodes: {\n    full: 'https://api.shasta.trongrid.io',\n    solidity: 'https://api.shasta.trongrid.io',\n  },\n  hmacVerificationEnforced: false,\n};\n\nconst devBase: EnvironmentTemplate = Object.assign({}, testnetBase, {\n  hsmXpub: hardcodedPublicKeys.hsmXpub.dev,\n  hmacVerificationEnforced: false,\n});\n\n// eslint-disable-next-line no-redeclare\nexport const Environments: Environments = {\n  prod: Object.assign({}, mainnetBase, {\n    uri: 'https://app.bitgo.com',\n    stellarFederationServerUrl: 'https://app.bitgo.com/api/v2/xlm/federation',\n  }),\n  test: Object.assign({}, testnetBase, {\n    uri: 'https://app.bitgo-test.com',\n    stellarFederationServerUrl: 'https://app.bitgo-test.com/api/v2/txlm/federation',\n  }),\n  dev: Object.assign({}, devBase, {\n    uri: 'https://app.bitgo-dev.com',\n    stellarFederationServerUrl: 'https://app.bitgo-dev.com/api/v2/txlm/federation',\n  }),\n  latest: Object.assign({}, devBase, {\n    uri: 'https://app.bitgo-latest.com',\n    stellarFederationServerUrl: 'https://app.bitgo-latest.com/api/v2/xlm/federation',\n  }),\n  staging: Object.assign({}, testnetBase, {\n    uri: 'https://app.bitgo-staging.com',\n    stellarFederationServerUrl: 'https://app.bitgo-staging.com/api/v2/txlm/federation',\n  }),\n  local: Object.assign({}, devBase, {\n    uri: 'https://localhost:3000',\n    stellarFederationServerUrl: 'https://localhost:3000/api/v2/txlm/federation',\n  }),\n  localNonSecure: Object.assign({}, devBase, {\n    uri: 'http://localhost:3000',\n    stellarFederationServerUrl: 'http://localhost:3000/api/v2/txlm/federation',\n  }),\n  mock: Object.assign({}, devBase, {\n    uri: 'https://bitgo.fakeurl',\n    stellarFederationServerUrl: 'https://bitgo.fakeurl/api/v2/txlm/federation',\n    etherscanBaseUrl: 'https://api-holesky.etherscan.fakeurl',\n    etherscanApiToken: process.env.ETHERSCAN_API_TOKEN,\n    avaxcNetworkBaseUrl: 'https://api.avax-test.network.fakeurl',\n    eth2ExplorerBaseUrl: 'https://beaconscan.com/api',\n  }),\n  adminProd: Object.assign({}, mainnetBase, {\n    uri: 'https://admin.bitgo.com',\n    stellarFederationServerUrl: 'https://admin.bitgo.com/api/v2/xlm/federation',\n  }),\n  adminTest: Object.assign({}, testnetBase, {\n    uri: 'https://admin.bitgo-test.com',\n    stellarFederationServerUrl: 'https://admin.bitgo-test.com/api/v2/txlm/federation',\n  }),\n  adminDev: Object.assign({}, devBase, {\n    uri: 'https://admin.bitgo-dev.com',\n    stellarFederationServerUrl: 'https://admin.bitgo-dev.com/api/v2/txlm/federation',\n  }),\n  adminLatest: Object.assign({}, devBase, {\n    uri: 'https://admin.bitgo-latest.com',\n    stellarFederationServerUrl: 'https://admin.bitgo-latest.com/api/v2/xlm/federation',\n  }),\n  custom: Object.assign({}, mainnetBase, {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    uri: process.env.BITGO_CUSTOM_ROOT_URI!,\n    network: process.env.BITGO_CUSTOM_BITCOIN_NETWORK as V1Network,\n    hsmXpub:\n      process.env.NODE_ENV === 'production' ? hardcodedPublicKeys.hsmXpub.prod : hardcodedPublicKeys.hsmXpub.test,\n    btcExplorerBaseUrl:\n      process.env.BITGO_CUSTOM_BITCOIN_NETWORK !== 'bitcoin'\n        ? 'https://blockstream.info/testnet/api'\n        : 'https://blockstream.info/api',\n    etherscanBaseUrl:\n      process.env.BITGO_CUSTOM_ETHEREUM_NETWORK !== 'ethereum'\n        ? 'https://api-holesky.etherscan.io'\n        : 'https://api.etherscan.io',\n    stellarFederationServerUrl:\n      process.env.BITGO_CUSTOM_STELLAR_NETWORK !== 'stellar'\n        ? `https://${process.env.BITGO_CUSTOM_ROOT_URI}/api/v2/txlm/federation`\n        : `https://${process.env.BITGO_CUSTOM_ROOT_URI}/api/v2/xlm/federation`,\n    serverXpub:\n      process.env.BITGO_CUSTOM_BITCOIN_NETWORK !== 'bitcoin'\n        ? hardcodedPublicKeys.serverXpub.test\n        : hardcodedPublicKeys.serverXpub.prod,\n  }),\n  branch: Object.assign({}, devBase, {\n    uri: 'https://app.bitgo-dev.com',\n    stellarFederationServerUrl: 'https://app.bitgo-dev.com/api/v2/txlm/federation',\n  }),\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environments.js","sourceRoot":"","sources":["../../../src/bitgo/environments.ts"],"names":[],"mappings":";;;AA2Da,QAAA,mBAAmB,GAAG,MAAM,CAAC,MAAM,CAAC;IAC/C,UAAU,EAAE;QACV,IAAI,EAAE,iHAAiH;QACvH,IAAI,EAAE,iHAAiH;KACxH;IACD,OAAO,EAAE;QACP,IAAI,EAAE,iHAAiH;QACvH,IAAI,EAAE,iHAAiH;QACvH,GAAG,EAAE,iHAAiH;KACvH;CACF,CAAC,CAAC;AAsBH,wFAAwF;AAC3E,QAAA,iBAAiB,GAAqD;IACjF,UAAU,EAAE,MAAM;IAClB,MAAM,EAAE,MAAM;IACd,MAAM,EAAE,MAAM;IACd,KAAK,EAAE,KAAK;IACZ,QAAQ,EAAE,QAAQ;CACnB,CAAC;AAEF,MAAM,WAAW,GAAwB;IACvC,OAAO,EAAE,SAAsB;IAC/B,cAAc,EAAE,oCAAoC;IACpD,UAAU,EAAE,2BAAmB,CAAC,UAAU,CAAC,IAAI;IAC/C,OAAO,EAAE,2BAAmB,CAAC,OAAO,CAAC,IAAI;IACzC,kBAAkB,EAAE,8BAA8B;IAClD,gBAAgB,EAAE,0BAA0B;IAC5C,iBAAiB,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB;IAClD,mBAAmB,EAAE,0BAA0B;IAC/C,mBAAmB,EAAE,4BAA4B;IACjD,sBAAsB,EAAE,iCAAiC;IACzD,cAAc,EAAE,yBAAyB;IACzC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa;IAC1C,kBAAkB,EAAE,6BAA6B;IACjD,mBAAmB,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB;IACtD,eAAe,EAAE,yBAAyB;IAC1C,gBAAgB,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB;IAChD,0BAA0B,EAAE,qCAAqC;IACjE,2BAA2B,EAAE,OAAO,CAAC,GAAG,CAAC,8BAA8B;IACvE,qBAAqB,EAAE,8CAA8C;IACrE,sBAAsB,EAAE,OAAO,CAAC,GAAG,CAAC,yBAAyB;IAC7D,kBAAkB,EAAE,0BAA0B;IAC9C,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB;IAC/C,WAAW,EAAE,CAAC,2BAA2B,EAAE,2BAA2B,EAAE,2BAA2B,CAAC;IACpG,YAAY,EAAE,CAAC,8BAA8B,CAAC;IAC9C,UAAU,EAAE,qCAAqC;IACjD,UAAU,EAAE,+BAA+B;IAC3C,WAAW,EAAE,2BAA2B;IACxC,UAAU,EAAE,sCAAsC;IAClD,WAAW,EAAE,0CAA0C;IACvD,WAAW,EAAE,0BAA0B;IACvC,UAAU,EAAE,uCAAuC;IACnD,UAAU,EAAE,8BAA8B;IAC1C,UAAU,EAAE,iCAAiC;IAC7C,WAAW,EAAE,EAAE;IACf,WAAW,EAAE,mCAAmC;IAChD,aAAa,EAAE,6CAA6C;IAC5D,WAAW,EAAE,kCAAkC;IAC/C,WAAW,EAAE,CAAC,uBAAuB,CAAC;IACtC,SAAS,EAAE;QACT,IAAI,EAAE,yBAAyB;QAC/B,QAAQ,EAAE,yBAAyB;KACpC;IACD,wBAAwB,EAAE,IAAI;IAC9B,UAAU,EAAE,iCAAiC;CAC9C,CAAC;AAEF,MAAM,WAAW,GAAwB;IACvC,OAAO,EAAE,SAAsB;IAC/B,cAAc,EAAE,oCAAoC;IACpD,UAAU,EAAE,2BAAmB,CAAC,UAAU,CAAC,IAAI;IAC/C,OAAO,EAAE,2BAAmB,CAAC,OAAO,CAAC,IAAI;IACzC,kBAAkB,EAAE,sCAAsC;IAC1D,gBAAgB,EAAE,kCAAkC;IACpD,iBAAiB,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB;IAClD,mBAAmB,EAAE,+BAA+B;IACpD,mBAAmB,EAAE,4BAA4B;IACjD,sBAAsB,EAAE,iCAAiC;IACzD,kBAAkB,EAAE,kCAAkC;IACtD,mBAAmB,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB;IACtD,cAAc,EAAE,iCAAiC;IACjD,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa;IAC1C,eAAe,EAAE,iCAAiC;IAClD,gBAAgB,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB;IAChD,0BAA0B,EAAE,6CAA6C;IACzE,2BAA2B,EAAE,OAAO,CAAC,GAAG,CAAC,8BAA8B;IACvE,qBAAqB,EAAE,+CAA+C;IACtE,sBAAsB,EAAE,OAAO,CAAC,GAAG,CAAC,yBAAyB;IAC7D,kBAAkB,EAAE,kCAAkC;IACtD,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB;IAC/C,iCAAiC;IACjC,mEAAmE;IACnE,8HAA8H;IAC9H,WAAW,EAAE,CAAC,uBAAuB,EAAE,gCAAgC,CAAC;IACxE,YAAY,EAAE,CAAC,8BAA8B,CAAC;IAC9C,UAAU,EAAE,+BAA+B;IAC3C,UAAU,EAAE,mCAAmC;IAC/C,WAAW,EAAE,gCAAgC;IAC7C,UAAU,EAAE,8CAA8C;IAC1D,WAAW,EAAE,oDAAoD;IACjE,WAAW,EAAE,oCAAoC;IACjD,UAAU,EAAE,4BAA4B;IACxC,UAAU,EAAE,uCAAuC;IACnD,UAAU,EAAE,+BAA+B;IAC3C,WAAW,EAAE,EAAE;IACf,WAAW,EAAE,6CAA6C;IAC1D,aAAa,EAAE,6CAA6C;IAC5D,WAAW,EAAE,6CAA6C;IAC1D,WAAW,EAAE,CAAC,+BAA+B,CAAC;IAC9C,SAAS,EAAE;QACT,IAAI,EAAE,gCAAgC;QACtC,QAAQ,EAAE,gCAAgC;KAC3C;IACD,wBAAwB,EAAE,KAAK;IAC/B,UAAU,EAAE,iCAAiC;CAC9C,CAAC;AAEF,MAAM,OAAO,GAAwB,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;IAClE,OAAO,EAAE,2BAAmB,CAAC,OAAO,CAAC,GAAG;IACxC,wBAAwB,EAAE,KAAK;CAChC,CAAC,CAAC;AAEH,wCAAwC;AAC3B,QAAA,YAAY,GAAiB;IACxC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;QACnC,GAAG,EAAE,uBAAuB;QAC5B,0BAA0B,EAAE,6CAA6C;KAC1E,CAAC;IACF,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;QACnC,GAAG,EAAE,4BAA4B;QACjC,0BAA0B,EAAE,mDAAmD;KAChF,CAAC;IACF,GAAG,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QAC9B,GAAG,EAAE,2BAA2B;QAChC,0BAA0B,EAAE,kDAAkD;KAC/E,CAAC;IACF,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QACjC,GAAG,EAAE,8BAA8B;QACnC,0BAA0B,EAAE,oDAAoD;KACjF,CAAC;IACF,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;QACtC,GAAG,EAAE,+BAA+B;QACpC,0BAA0B,EAAE,sDAAsD;KACnF,CAAC;IACF,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QAChC,GAAG,EAAE,wBAAwB;QAC7B,0BAA0B,EAAE,+CAA+C;KAC5E,CAAC;IACF,cAAc,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QACzC,GAAG,EAAE,uBAAuB;QAC5B,0BAA0B,EAAE,8CAA8C;KAC3E,CAAC;IACF,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QAC/B,GAAG,EAAE,uBAAuB;QAC5B,0BAA0B,EAAE,8CAA8C;QAC1E,gBAAgB,EAAE,uCAAuC;QACzD,iBAAiB,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB;QAClD,mBAAmB,EAAE,uCAAuC;QAC5D,mBAAmB,EAAE,4BAA4B;KAClD,CAAC;IACF,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;QACxC,GAAG,EAAE,yBAAyB;QAC9B,0BAA0B,EAAE,+CAA+C;KAC5E,CAAC;IACF,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;QACxC,GAAG,EAAE,8BAA8B;QACnC,0BAA0B,EAAE,qDAAqD;KAClF,CAAC;IACF,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QACnC,GAAG,EAAE,6BAA6B;QAClC,0BAA0B,EAAE,oDAAoD;KACjF,CAAC;IACF,WAAW,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QACtC,GAAG,EAAE,gCAAgC;QACrC,0BAA0B,EAAE,sDAAsD;KACnF,CAAC;IACF,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE;QACrC,oEAAoE;QACpE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAsB;QACvC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,4BAAyC;QAC9D,OAAO,EACL,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,CAAC,CAAC,CAAC,2BAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,2BAAmB,CAAC,OAAO,CAAC,IAAI;QAC7G,kBAAkB,EAChB,OAAO,CAAC,GAAG,CAAC,4BAA4B,KAAK,SAAS;YACpD,CAAC,CAAC,sCAAsC;YACxC,CAAC,CAAC,8BAA8B;QACpC,gBAAgB,EACd,OAAO,CAAC,GAAG,CAAC,6BAA6B,KAAK,UAAU;YACtD,CAAC,CAAC,kCAAkC;YACpC,CAAC,CAAC,0BAA0B;QAChC,0BAA0B,EACxB,OAAO,CAAC,GAAG,CAAC,4BAA4B,KAAK,SAAS;YACpD,CAAC,CAAC,WAAW,OAAO,CAAC,GAAG,CAAC,qBAAqB,yBAAyB;YACvE,CAAC,CAAC,WAAW,OAAO,CAAC,GAAG,CAAC,qBAAqB,wBAAwB;QAC1E,UAAU,EACR,OAAO,CAAC,GAAG,CAAC,4BAA4B,KAAK,SAAS;YACpD,CAAC,CAAC,2BAAmB,CAAC,UAAU,CAAC,IAAI;YACrC,CAAC,CAAC,2BAAmB,CAAC,UAAU,CAAC,IAAI;KAC1C,CAAC;IACF,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE;QACjC,GAAG,EAAE,2BAA2B;QAChC,0BAA0B,EAAE,kDAAkD;KAC/E,CAAC;CACH,CAAC","sourcesContent":["/**\n * @prettier\n */\nimport { V1Network } from './types';\n\ninterface EnvironmentTemplate {\n  uri?: string;\n  network: V1Network;\n  signingAddress: string;\n  serverXpub: string;\n  hsmXpub: string;\n  btcExplorerBaseUrl: string;\n  etherscanBaseUrl: string;\n  etherscanApiToken?: string;\n  avaxcNetworkBaseUrl: string;\n  eth2ExplorerBaseUrl: string;\n  ethwFullNodeRPCBaseUrl: string;\n  polygonscanBaseUrl?: string;\n  bscscanBaseUrl?: string;\n  bscscanApiToken?: string;\n  polygonscanApiToken?: string;\n  arbiscanBaseUrl?: string;\n  arbiscanApiToken?: string;\n  optimisticEtherscanBaseUrl?: string;\n  optimisticEtherscanApiToken?: string;\n  zksyncExplorerBaseUrl?: string;\n  zksyncExplorerApiToken?: string;\n  baseethExplorerUrl?: string;\n  baseethApiToken?: string;\n  stellarFederationServerUrl?: string;\n  eosNodeUrls: string[];\n  nearNodeUrls: string[];\n  solNodeUrl: string;\n  adaNodeUrl: string;\n  hashNodeUrl: string;\n  injNodeUrl: string;\n  atomNodeUrl: string;\n  osmoNodeUrl: string;\n  tiaNodeUrl: string;\n  seiNodeUrl: string;\n  bldNodeUrl: string;\n  beraNodeUrl: string;\n  zetaNodeUrl: string;\n  coreumNodeUrl: string;\n  islmNodeUrl: string;\n  dotNodeUrls: string[];\n  tronNodes: {\n    full: string;\n    solidity: string;\n  };\n  hmacVerificationEnforced: boolean;\n  suiNodeUrl: string;\n}\n\nexport interface Environment extends EnvironmentTemplate {\n  uri: string;\n  stellarFederationServerUrl: string;\n}\n\nexport const hardcodedPublicKeys = Object.freeze({\n  serverXpub: {\n    prod: 'xpub661MyMwAqRbcEtUgu9HF8ai4ipuVKKHBzUqks4jSFypW8dwwQL1zygLgQx99NmC7zJJznSiwKG6RQfVjAKMtCsx8VjR6kQW8x7HrkXFZdnQ',\n    test: 'xpub661MyMwAqRbcErFqVXGiUFv9YeoPbhN72UiNCUdj9nj3T6M8h7iKNmbCYpMVWVZP7LA2ma3HWcPngz1gRTm4FPdtm9mHfrNvU93MCoszsGL',\n  },\n  hsmXpub: {\n    prod: 'xpub661MyMwAqRbcGEtTFgMAoxMFoqsRdDaiaR63byNfZdV7cBZFvovQSNJ5bpyeoQtuKVgXBk6sFQ7TtvyWqadt41DnKwveYgM5KoU2EKYjdY2',\n    test: 'xpub661MyMwAqRbcGFKe4Bqvk4Sgric4gNFC8pUbw4tUkVjZxubjCA522gPzc1YaXb3bQVmDWc7CjG8AGNWRpcdAU38RETBh8n2bnqEU4kbV4oK',\n    dev: 'xpub661MyMwAqRbcFWzoz8qnYRDYEFQpPLYwxVFoG6WLy3ck5ZupRGJTG4ju6yGb7Dj3ey6GsC4kstLRER2nKzgjLtmxyPgC4zHy7kVhUt6yfGn',\n  },\n});\n\nexport type EnvironmentName =\n  | 'prod'\n  | 'staging'\n  | 'test'\n  | 'dev'\n  | 'latest'\n  | 'local'\n  | 'localNonSecure'\n  | 'mock'\n  | 'adminProd'\n  | 'adminTest'\n  | 'adminDev'\n  | 'adminLatest'\n  | 'custom'\n  | 'branch';\n\nexport type AliasEnvironmentName = 'production' | 'msProd' | 'msTest' | 'msDev' | 'msLatest';\n\nexport type Environments = { [k in EnvironmentName]: Environment };\n\n// alias environments are environment names which are aliases of a supported environment\nexport const AliasEnvironments: { [k in AliasEnvironmentName]: EnvironmentName } = {\n  production: 'prod',\n  msProd: 'prod',\n  msTest: 'test',\n  msDev: 'dev',\n  msLatest: 'latest',\n};\n\nconst mainnetBase: EnvironmentTemplate = {\n  network: 'bitcoin' as V1Network,\n  signingAddress: '1BitGo3gxRZ6mQSEH52dvCKSUgVCAH4Rja',\n  serverXpub: hardcodedPublicKeys.serverXpub.prod,\n  hsmXpub: hardcodedPublicKeys.hsmXpub.prod,\n  btcExplorerBaseUrl: 'https://blockstream.info/api',\n  etherscanBaseUrl: 'https://api.etherscan.io',\n  etherscanApiToken: process.env.ETHERSCAN_API_TOKEN,\n  avaxcNetworkBaseUrl: 'https://api.avax.network',\n  eth2ExplorerBaseUrl: 'https://beaconscan.com/api',\n  ethwFullNodeRPCBaseUrl: 'https://mainnet.ethereumpow.org',\n  bscscanBaseUrl: 'https://api.bscscan.com',\n  bscscanApiToken: process.env.BSC_API_TOKEN,\n  polygonscanBaseUrl: 'https://api.polygonscan.com',\n  polygonscanApiToken: process.env.POLYGONSCAN_API_TOKEN,\n  arbiscanBaseUrl: 'https://api.arbiscan.io',\n  arbiscanApiToken: process.env.ARBISCAN_API_TOKEN,\n  optimisticEtherscanBaseUrl: 'https://api-optimistic.etherscan.io',\n  optimisticEtherscanApiToken: process.env.OPTIMISTIC_ETHERSCAN_API_TOKEN,\n  zksyncExplorerBaseUrl: 'https://block-explorer-api.mainnet.zksync.io',\n  zksyncExplorerApiToken: process.env.ZKSYNC_EXPLORER_API_TOKEN,\n  baseethExplorerUrl: 'https://api.basescan.org',\n  baseethApiToken: process.env.BASESCAN_API_TOKEN,\n  eosNodeUrls: ['https://bp.cryptolions.io', 'https://api.eosnewyork.io', 'https://api.eosdetroit.io'],\n  nearNodeUrls: ['https://rpc.mainnet.near.org'],\n  solNodeUrl: 'https://api.mainnet-beta.solana.com',\n  adaNodeUrl: 'https://api.koios.rest/api/v0',\n  hashNodeUrl: 'https://api.provenance.io',\n  injNodeUrl: 'https://sentry.lcd.injective.network', // reference https://docs.injective.network/develop/public-endpoints/\n  atomNodeUrl: 'https://rest.cosmos.directory/cosmoshub/',\n  osmoNodeUrl: 'https://lcd.osmosis.zone',\n  tiaNodeUrl: 'https://public-celestia-lcd.numia.xyz', // reference https://docs.celestia.org/nodes/mainnet#api-endpoints\n  seiNodeUrl: 'https://sei-api.polkachu.com',\n  bldNodeUrl: 'https://agoric-api.polkachu.com',\n  beraNodeUrl: '', // TODO(WIN-693): update url when mainnet goes live\n  zetaNodeUrl: 'https://zetachain.blockpi.network', // reference https://www.zetachain.com/docs/reference/api/\n  coreumNodeUrl: 'https://full-node.mainnet-1.coreum.dev:1317',\n  islmNodeUrl: 'https://rest.cosmos.haqq.network',\n  dotNodeUrls: ['wss://rpc.polkadot.io'],\n  tronNodes: {\n    full: 'https://api.trongrid.io',\n    solidity: 'https://api.trongrid.io',\n  },\n  hmacVerificationEnforced: true,\n  suiNodeUrl: 'https://fullnode.mainnet.sui.io',\n};\n\nconst testnetBase: EnvironmentTemplate = {\n  network: 'testnet' as V1Network,\n  signingAddress: 'msignBdFXteehDEgB6DNm7npRt7AcEZJP3',\n  serverXpub: hardcodedPublicKeys.serverXpub.test,\n  hsmXpub: hardcodedPublicKeys.hsmXpub.test,\n  btcExplorerBaseUrl: 'https://blockstream.info/testnet/api',\n  etherscanBaseUrl: 'https://api-holesky.etherscan.io',\n  etherscanApiToken: process.env.ETHERSCAN_API_TOKEN,\n  avaxcNetworkBaseUrl: 'https://api.avax-test.network',\n  eth2ExplorerBaseUrl: 'https://beaconscan.com/api',\n  ethwFullNodeRPCBaseUrl: 'https://mainnet.ethereumpow.org',\n  polygonscanBaseUrl: 'https://api-amoy.polygonscan.com',\n  polygonscanApiToken: process.env.POLYGONSCAN_API_TOKEN,\n  bscscanBaseUrl: 'https://api-testnet.bscscan.com',\n  bscscanApiToken: process.env.BSC_API_TOKEN,\n  arbiscanBaseUrl: 'https://api-sepolia.arbiscan.io',\n  arbiscanApiToken: process.env.ARBISCAN_API_TOKEN,\n  optimisticEtherscanBaseUrl: 'https://api-sepolia-optimistic.etherscan.io',\n  optimisticEtherscanApiToken: process.env.OPTIMISTIC_ETHERSCAN_API_TOKEN,\n  zksyncExplorerBaseUrl: 'https://block-explorer-api.sepolia.zksync.dev',\n  zksyncExplorerApiToken: process.env.ZKSYNC_EXPLORER_API_TOKEN,\n  baseethExplorerUrl: 'https://api-sepolia.basescan.org',\n  baseethApiToken: process.env.BASESCAN_API_TOKEN,\n  // kylin eos endpoints found here\n  // https://github.com/cryptokylin/CryptoKylin-Testnet#http-api-list\n  // https://docs.liquidapps.io/liquidapps-documentation/eosio-guides/testnet-creation-guides/creating-cryptokylin-account#setup\n  eosNodeUrls: ['https://kylin.eosn.io', 'https://api.kylin.alohaeos.com'],\n  nearNodeUrls: ['https://rpc.testnet.near.org'],\n  solNodeUrl: 'https://api.devnet.solana.com',\n  adaNodeUrl: 'https://preprod.koios.rest/api/v0',\n  hashNodeUrl: 'https://api.test.provenance.io',\n  injNodeUrl: 'https://testnet.sentry.lcd.injective.network', // COIN-1219 : reference  https://docs.injective.network/develop/public-endpoints/#testnet\n  atomNodeUrl: 'https://rest.sentry-02.theta-testnet.polypore.xyz/',\n  osmoNodeUrl: 'https://lcd.osmotest5.osmosis.zone',\n  tiaNodeUrl: 'https://api-mocha.pops.one',\n  seiNodeUrl: 'https://rest.atlantic-2.seinetwork.io',\n  bldNodeUrl: 'https://devnet.api.agoric.net',\n  beraNodeUrl: '', // TODO(WIN-693): update url when testnet goes live\n  zetaNodeUrl: 'https://rest.nodejumper.io/zetachaintestnet', // reference : https://www.zetachain.com/docs/reference/api/\n  coreumNodeUrl: 'https://full-node.testnet-1.coreum.dev:1317',\n  islmNodeUrl: 'https://rest.cosmos.testedge2.haqq.network ',\n  dotNodeUrls: ['wss://westend-rpc.polkadot.io'],\n  tronNodes: {\n    full: 'https://api.shasta.trongrid.io',\n    solidity: 'https://api.shasta.trongrid.io',\n  },\n  hmacVerificationEnforced: false,\n  suiNodeUrl: 'https://fullnode.testnet.sui.io',\n};\n\nconst devBase: EnvironmentTemplate = Object.assign({}, testnetBase, {\n  hsmXpub: hardcodedPublicKeys.hsmXpub.dev,\n  hmacVerificationEnforced: false,\n});\n\n// eslint-disable-next-line no-redeclare\nexport const Environments: Environments = {\n  prod: Object.assign({}, mainnetBase, {\n    uri: 'https://app.bitgo.com',\n    stellarFederationServerUrl: 'https://app.bitgo.com/api/v2/xlm/federation',\n  }),\n  test: Object.assign({}, testnetBase, {\n    uri: 'https://app.bitgo-test.com',\n    stellarFederationServerUrl: 'https://app.bitgo-test.com/api/v2/txlm/federation',\n  }),\n  dev: Object.assign({}, devBase, {\n    uri: 'https://app.bitgo-dev.com',\n    stellarFederationServerUrl: 'https://app.bitgo-dev.com/api/v2/txlm/federation',\n  }),\n  latest: Object.assign({}, devBase, {\n    uri: 'https://app.bitgo-latest.com',\n    stellarFederationServerUrl: 'https://app.bitgo-latest.com/api/v2/xlm/federation',\n  }),\n  staging: Object.assign({}, testnetBase, {\n    uri: 'https://app.bitgo-staging.com',\n    stellarFederationServerUrl: 'https://app.bitgo-staging.com/api/v2/txlm/federation',\n  }),\n  local: Object.assign({}, devBase, {\n    uri: 'https://localhost:3000',\n    stellarFederationServerUrl: 'https://localhost:3000/api/v2/txlm/federation',\n  }),\n  localNonSecure: Object.assign({}, devBase, {\n    uri: 'http://localhost:3000',\n    stellarFederationServerUrl: 'http://localhost:3000/api/v2/txlm/federation',\n  }),\n  mock: Object.assign({}, devBase, {\n    uri: 'https://bitgo.fakeurl',\n    stellarFederationServerUrl: 'https://bitgo.fakeurl/api/v2/txlm/federation',\n    etherscanBaseUrl: 'https://api-holesky.etherscan.fakeurl',\n    etherscanApiToken: process.env.ETHERSCAN_API_TOKEN,\n    avaxcNetworkBaseUrl: 'https://api.avax-test.network.fakeurl',\n    eth2ExplorerBaseUrl: 'https://beaconscan.com/api',\n  }),\n  adminProd: Object.assign({}, mainnetBase, {\n    uri: 'https://admin.bitgo.com',\n    stellarFederationServerUrl: 'https://admin.bitgo.com/api/v2/xlm/federation',\n  }),\n  adminTest: Object.assign({}, testnetBase, {\n    uri: 'https://admin.bitgo-test.com',\n    stellarFederationServerUrl: 'https://admin.bitgo-test.com/api/v2/txlm/federation',\n  }),\n  adminDev: Object.assign({}, devBase, {\n    uri: 'https://admin.bitgo-dev.com',\n    stellarFederationServerUrl: 'https://admin.bitgo-dev.com/api/v2/txlm/federation',\n  }),\n  adminLatest: Object.assign({}, devBase, {\n    uri: 'https://admin.bitgo-latest.com',\n    stellarFederationServerUrl: 'https://admin.bitgo-latest.com/api/v2/xlm/federation',\n  }),\n  custom: Object.assign({}, mainnetBase, {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    uri: process.env.BITGO_CUSTOM_ROOT_URI!,\n    network: process.env.BITGO_CUSTOM_BITCOIN_NETWORK as V1Network,\n    hsmXpub:\n      process.env.NODE_ENV === 'production' ? hardcodedPublicKeys.hsmXpub.prod : hardcodedPublicKeys.hsmXpub.test,\n    btcExplorerBaseUrl:\n      process.env.BITGO_CUSTOM_BITCOIN_NETWORK !== 'bitcoin'\n        ? 'https://blockstream.info/testnet/api'\n        : 'https://blockstream.info/api',\n    etherscanBaseUrl:\n      process.env.BITGO_CUSTOM_ETHEREUM_NETWORK !== 'ethereum'\n        ? 'https://api-holesky.etherscan.io'\n        : 'https://api.etherscan.io',\n    stellarFederationServerUrl:\n      process.env.BITGO_CUSTOM_STELLAR_NETWORK !== 'stellar'\n        ? `https://${process.env.BITGO_CUSTOM_ROOT_URI}/api/v2/txlm/federation`\n        : `https://${process.env.BITGO_CUSTOM_ROOT_URI}/api/v2/xlm/federation`,\n    serverXpub:\n      process.env.BITGO_CUSTOM_BITCOIN_NETWORK !== 'bitcoin'\n        ? hardcodedPublicKeys.serverXpub.test\n        : hardcodedPublicKeys.serverXpub.prod,\n  }),\n  branch: Object.assign({}, devBase, {\n    uri: 'https://app.bitgo-dev.com',\n    stellarFederationServerUrl: 'https://app.bitgo-dev.com/api/v2/txlm/federation',\n  }),\n};\n"]}

@@ -140,2 +140,42 @@ /// <reference types="node" />

}
/**
* Checks if the given key share, when decrypted, contains valid GG18 signing material.
*
* @param {string} keyShare - The encrypted key share string.
* @param {string|undefined} walletPassphrase - The passphrase used to decrypt the key share
* @returns {boolean} - Returns `true` if the decrypted data contains valid signing material, otherwise `false`.
*/
export declare function isGG18SigningMaterial(keyShare: string, walletPassphrase: string | undefined): boolean;
/**
* Retrieves the MPC v2 recovery key shares from the provided user and backup key shares.
*
* @param {string} userPublicOrPrivateKeyShare
* @param {string} backupPrivateOrPublicKeyShare
* @param {string} [walletPassphrase] - The passphrase used to decrypt the key shares
* @returns {Promise<{ userKeyShare: KeyShare, backupKeyShare: KeyShare, commonKeyChain: string }>}
*
* @async
*/
export declare function getMpcV2RecoveryKeyShares(userPublicOrPrivateKeyShare: string, backupPrivateOrPublicKeyShare: string, walletPassphrase?: string): Promise<{
userKeyShare: Buffer;
backupKeyShare: Buffer;
commonKeyChain: string;
}>;
/**
* Signs a message hash using MPC v2 recovery key shares.
*
* @param {Buffer} messageHash
* @param {Buffer} userKeyShare
* @param {Buffer} backupKeyShare
* @param {string} commonKeyChain
* @returns {Promise<{ recid: number, r: string, s: string, y: string }>}
*
* @async
*/
export declare function signRecoveryMpcV2(messageHash: Buffer, userKeyShare: Buffer, backupKeyShare: Buffer, commonKeyChain: string): Promise<{
recid: number;
r: string;
s: string;
y: string;
}>;
//# sourceMappingURL=ecdsaMPCv2.d.ts.map

@@ -6,3 +6,2 @@ export * from './ecdsa';

export * from './SMC/utils';
export * from './SMC/types';
//# sourceMappingURL=index.d.ts.map

@@ -22,3 +22,2 @@ "use strict";

__exportStar(require("./SMC/utils"), exports);
__exportStar(require("./SMC/types"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYml0Z28vdXRpbHMvdHNzL2VjZHNhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwwQ0FBd0I7QUFDeEIsK0NBQTZCO0FBQzdCLDBDQUF3QjtBQUN4QiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDhDQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZWNkc2EnO1xuZXhwb3J0ICogZnJvbSAnLi9lY2RzYU1QQ3YyJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlc01QQ3YyJztcbmV4cG9ydCAqIGZyb20gJy4vU01DL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vU01DL3R5cGVzJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYml0Z28vdXRpbHMvdHNzL2VjZHNhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwwQ0FBd0I7QUFDeEIsK0NBQTZCO0FBQzdCLDBDQUF3QjtBQUN4QiwrQ0FBNkI7QUFDN0IsOENBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lY2RzYSc7XG5leHBvcnQgKiBmcm9tICcuL2VjZHNhTVBDdjInO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzTVBDdjInO1xuZXhwb3J0ICogZnJvbSAnLi9TTUMvdXRpbHMnO1xuIl19

@@ -0,4 +1,4 @@

import { BitgoToOVC1Round1Response, BitgoToOVC1Round2Response, BitgoToOVC1Round3Response, OVC1ToBitgoRound3Payload, OVC2ToBitgoRound1Payload, OVC2ToBitgoRound2Payload } from '@bitgo/public-types';
import { IBaseCoin } from '../../../../baseCoin';
import { BitGoBase } from '../../../../bitgoBase';
import { BitgoToOVC1Round1Response, BitgoToOVC1Round2Response, BitgoToOVC1Round3Response, OVC1ToBitgoRound3Payload, OVC2ToBitgoRound1Payload, OVC2ToBitgoRound2Payload } from './types';
import { Keychain } from '../../../..';

@@ -5,0 +5,0 @@ export declare class MPCv2SMCUtils {

@@ -8,4 +8,5 @@ "use strict";

const assert_1 = __importDefault(require("assert"));
const public_types_1 = require("@bitgo/public-types");
const ecdsaMPCv2_1 = require("../ecdsaMPCv2");
const types_1 = require("./types");
const __1 = require("../../../..");
class MPCv2SMCUtils {

@@ -17,5 +18,7 @@ constructor(bitgo, baseCoin) {

async keyGenRound1(enterprise, payload) {
(0, assert_1.default)(payload.state === types_1.KeyCreationMPCv2States.WaitingForBitgoRound1Data, `Invalid state for round 1, got: ${payload.state}`);
const ovc1 = payload.ovc[types_1.OVC_ONE];
const ovc2 = payload.ovc[types_1.OVC_TWO];
(0, __1.decodeOrElse)(public_types_1.OVC2ToBitgoRound1Payload.name, public_types_1.OVC2ToBitgoRound1Payload, payload, (errors) => {
throw new Error(`error(s) parsing payload: ${errors}`);
});
const ovc1 = payload.ovc[public_types_1.OVCIndexEnum.ONE];
const ovc2 = payload.ovc[public_types_1.OVCIndexEnum.TWO];
const userGpgPublicKey = ovc1.gpgPubKey;

@@ -25,3 +28,3 @@ const backupGpgPublicKey = ovc2.gpgPubKey;

const result = await this.MPCv2Utils.sendKeyGenerationRound1(enterprise, userGpgPublicKey, backupGpgPublicKey, messages);
return {
const response = {
wallet: {

@@ -32,3 +35,3 @@ tssVersion: payload.tssVersion,

ovc: payload.ovc,
state: types_1.KeyCreationMPCv2States.WaitingForOVC1Round2Data,
state: public_types_1.KeyCreationMPCv2StateEnum.WaitingForOVC1Round2Data,
platform: {

@@ -39,4 +42,4 @@ walletGpgPubKeySigs: result.walletGpgPubKeySigs,

ovc: {
[types_1.OVC_ONE]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg2) },
[types_1.OVC_TWO]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg2) },
[public_types_1.OVCIndexEnum.ONE]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg2) },
[public_types_1.OVCIndexEnum.TWO]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg2) },
},

@@ -46,11 +49,16 @@ },

};
return (0, __1.decodeOrElse)(public_types_1.BitgoToOVC1Round1Response.name, public_types_1.BitgoToOVC1Round1Response, response, (errors) => {
throw new Error(`error(s) parsing response: ${errors}`);
});
}
async keyGenRound2(enterprise, payload) {
(0, assert_1.default)(payload.state === types_1.KeyCreationMPCv2States.WaitingForBitgoRound2Data, `Invalid state for round 2, got: ${payload.state}`);
const ovc1 = payload.ovc[types_1.OVC_ONE];
const ovc2 = payload.ovc[types_1.OVC_TWO];
(0, __1.decodeOrElse)(public_types_1.OVC2ToBitgoRound2Payload.name, public_types_1.OVC2ToBitgoRound2Payload, payload, (errors) => {
throw new Error(`error(s) parsing payload: ${errors}`);
});
const ovc1 = payload.ovc[public_types_1.OVCIndexEnum.ONE];
const ovc2 = payload.ovc[public_types_1.OVCIndexEnum.TWO];
const sessionId = payload.platform.sessionId;
const messages = { p2pMessages: [ovc1.ovcToBitgoMsg2, ovc2.ovcToBitgoMsg2], broadcastMessages: [] };
const result = await this.MPCv2Utils.sendKeyGenerationRound2(enterprise, sessionId, messages);
return {
const response = {
wallet: {

@@ -61,3 +69,3 @@ tssVersion: payload.tssVersion,

ovc: payload.ovc,
state: types_1.KeyCreationMPCv2States.WaitingForOVC1Round3aData,
state: public_types_1.KeyCreationMPCv2StateEnum.WaitingForOVC1Round3aData,
platform: {

@@ -68,8 +76,8 @@ ...payload.platform,

ovc: {
[types_1.OVC_ONE]: {
...payload.platform.ovc[types_1.OVC_ONE],
[public_types_1.OVCIndexEnum.ONE]: {
...payload.platform.ovc[public_types_1.OVCIndexEnum.ONE],
bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg3),
},
[types_1.OVC_TWO]: {
...payload.platform.ovc[2],
[public_types_1.OVCIndexEnum.TWO]: {
...payload.platform.ovc[public_types_1.OVCIndexEnum.TWO],
bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg3),

@@ -81,7 +89,12 @@ },

};
return (0, __1.decodeOrElse)(public_types_1.BitgoToOVC1Round2Response.name, public_types_1.BitgoToOVC1Round2Response, response, (errors) => {
throw new Error(`error(s) parsing response: ${errors}`);
});
}
async keyGenRound3(enterprise, payload) {
(0, assert_1.default)(payload.state === types_1.KeyCreationMPCv2States.WaitingForBitgoRound3Data, `Invalid state for round 3, got: ${payload.state}`);
const ovc1 = payload.ovc[types_1.OVC_ONE];
const ovc2 = payload.ovc[types_1.OVC_TWO];
(0, __1.decodeOrElse)(public_types_1.OVC1ToBitgoRound3Payload.name, public_types_1.OVC1ToBitgoRound3Payload, payload, (errors) => {
throw new Error(`error(s) parsing payload: ${errors}`);
});
const ovc1 = payload.ovc[public_types_1.OVCIndexEnum.ONE];
const ovc2 = payload.ovc[public_types_1.OVCIndexEnum.TWO];
const sessionId = payload.platform.sessionId;

@@ -100,3 +113,3 @@ const messages = {

});
return {
const response = {
bitGoKeyId: bitgoKeychain.id,

@@ -108,3 +121,3 @@ wallet: {

ovc: payload.ovc,
state: types_1.KeyCreationMPCv2States.WaitingForOVC1GenerateKey,
state: public_types_1.KeyCreationMPCv2StateEnum.WaitingForOVC1GenerateKey,
platform: {

@@ -117,2 +130,5 @@ ...payload.platform,

};
return (0, __1.decodeOrElse)(public_types_1.BitgoToOVC1Round3Response.name, public_types_1.BitgoToOVC1Round3Response, response, (errors) => {
throw new Error(`error(s) parsing response: ${errors}`);
});
}

@@ -145,2 +161,2 @@ async uploadClientKeys(bitgoKeyId, userCommonKeychain, backupCommonKeychain) {

exports.MPCv2SMCUtils = MPCv2SMCUtils;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../src/bitgo/utils/tss/ecdsa/SMC/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { IBaseCoin } from '../../../../baseCoin';\nimport { BitGoBase } from '../../../../bitgoBase';\nimport { EcdsaMPCv2Utils } from '../ecdsaMPCv2';\nimport {\n  BitgoToOVC1Round1Response,\n  BitgoToOVC1Round2Response,\n  BitgoToOVC1Round3Response,\n  KeyCreationMPCv2States,\n  OVC1ToBitgoRound3Payload,\n  OVC2ToBitgoRound1Payload,\n  OVC2ToBitgoRound2Payload,\n  OVC_ONE,\n  OVC_TWO,\n} from './types';\n\nimport { Keychain } from '../../../..';\n\nexport class MPCv2SMCUtils {\n  private MPCv2Utils: EcdsaMPCv2Utils;\n\n  constructor(bitgo: BitGoBase, private baseCoin: IBaseCoin) {\n    this.MPCv2Utils = new EcdsaMPCv2Utils(bitgo, baseCoin);\n  }\n\n  public async keyGenRound1(enterprise: string, payload: OVC2ToBitgoRound1Payload): Promise<BitgoToOVC1Round1Response> {\n    assert(\n      payload.state === KeyCreationMPCv2States.WaitingForBitgoRound1Data,\n      `Invalid state for round 1, got: ${payload.state}`\n    );\n    const ovc1 = payload.ovc[OVC_ONE];\n    const ovc2 = payload.ovc[OVC_TWO];\n    const userGpgPublicKey = ovc1.gpgPubKey;\n    const backupGpgPublicKey = ovc2.gpgPubKey;\n    const messages = { p2pMessages: [], broadcastMessages: [ovc1.ovcMsg1, ovc2.ovcMsg1] };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound1(\n      enterprise,\n      userGpgPublicKey,\n      backupGpgPublicKey,\n      messages\n    );\n\n    return {\n      wallet: {\n        tssVersion: payload.tssVersion,\n        walletType: payload.walletType,\n        coin: payload.coin,\n        ovc: payload.ovc,\n        state: KeyCreationMPCv2States.WaitingForOVC1Round2Data,\n        platform: {\n          walletGpgPubKeySigs: result.walletGpgPubKeySigs,\n          sessionId: result.sessionId,\n          bitgoMsg1: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg1),\n          ovc: {\n            [OVC_ONE]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg2) },\n            [OVC_TWO]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg2) },\n          },\n        },\n      },\n    };\n  }\n\n  public async keyGenRound2(enterprise: string, payload: OVC2ToBitgoRound2Payload): Promise<BitgoToOVC1Round2Response> {\n    assert(\n      payload.state === KeyCreationMPCv2States.WaitingForBitgoRound2Data,\n      `Invalid state for round 2, got: ${payload.state}`\n    );\n    const ovc1 = payload.ovc[OVC_ONE];\n    const ovc2 = payload.ovc[OVC_TWO];\n    const sessionId = payload.platform.sessionId;\n    const messages = { p2pMessages: [ovc1.ovcToBitgoMsg2, ovc2.ovcToBitgoMsg2], broadcastMessages: [] };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound2(enterprise, sessionId, messages);\n\n    return {\n      wallet: {\n        tssVersion: payload.tssVersion,\n        walletType: payload.walletType,\n        coin: payload.coin,\n        ovc: payload.ovc,\n        state: KeyCreationMPCv2States.WaitingForOVC1Round3aData,\n        platform: {\n          ...payload.platform,\n          sessionId: result.sessionId,\n          bitgoCommitment2: result.bitgoCommitment2,\n          ovc: {\n            [OVC_ONE]: {\n              ...payload.platform.ovc[OVC_ONE],\n              bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg3),\n            },\n            [OVC_TWO]: {\n              ...payload.platform.ovc[2],\n              bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg3),\n            },\n          },\n        },\n      },\n    };\n  }\n\n  public async keyGenRound3(enterprise: string, payload: OVC1ToBitgoRound3Payload): Promise<BitgoToOVC1Round3Response> {\n    assert(\n      payload.state === KeyCreationMPCv2States.WaitingForBitgoRound3Data,\n      `Invalid state for round 3, got: ${payload.state}`\n    );\n    const ovc1 = payload.ovc[OVC_ONE];\n    const ovc2 = payload.ovc[OVC_TWO];\n    const sessionId = payload.platform.sessionId;\n    const messages = {\n      p2pMessages: [ovc1.ovcToBitgoMsg3, ovc2.ovcToBitgoMsg3],\n      broadcastMessages: [ovc1.ovcMsg4, ovc2.ovcMsg4],\n    };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound3(enterprise, sessionId, messages);\n\n    const keychains = this.baseCoin.keychains();\n    const bitgoKeychain = await keychains.add({\n      source: 'bitgo',\n      keyType: 'tss',\n      commonKeychain: result.commonKeychain,\n      isMPCv2: true,\n    });\n\n    return {\n      bitGoKeyId: bitgoKeychain.id,\n      wallet: {\n        tssVersion: payload.tssVersion,\n        walletType: payload.walletType,\n        coin: payload.coin,\n        ovc: payload.ovc,\n        state: KeyCreationMPCv2States.WaitingForOVC1GenerateKey,\n        platform: {\n          ...payload.platform,\n          commonKeychain: result.commonKeychain,\n          bitgoMsg4: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg4),\n        },\n      },\n    };\n  }\n\n  public async uploadClientKeys(\n    bitgoKeyId: string,\n    userCommonKeychain: string,\n    backupCommonKeychain: string\n  ): Promise<{ userKeychain: Keychain; backupKeychain: Keychain; bitgoKeychain: Keychain }> {\n    assert(\n      userCommonKeychain === backupCommonKeychain,\n      'Common keychain mismatch between the user and backup keychains'\n    );\n\n    const keychains = this.baseCoin.keychains();\n    const bitgoKeychain = await keychains.get({ id: bitgoKeyId });\n    assert(bitgoKeychain, 'Keychain not found');\n    assert(bitgoKeychain.source === 'bitgo', 'The keychain is not a BitGo keychain');\n    assert(bitgoKeychain.type === 'tss', 'BitGo keychain is not a TSS keychain');\n    assert(bitgoKeychain.commonKeychain, 'BitGo keychain does not have a common keychain');\n    assert(bitgoKeychain.commonKeychain === userCommonKeychain, 'Common keychain mismatch between the OVCs and BitGo');\n\n    const userKeychainPromise = keychains.add({\n      source: 'user',\n      keyType: 'tss',\n      commonKeychain: userCommonKeychain,\n      isMPCv2: true,\n    });\n    const backupKeychainPromise = keychains.add({\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: backupCommonKeychain,\n      isMPCv2: true,\n    });\n\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n    return { userKeychain, backupKeychain, bitgoKeychain };\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../src/bitgo/utils/tss/ecdsa/SMC/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport {\n  BitgoToOVC1Round1Response,\n  BitgoToOVC1Round2Response,\n  BitgoToOVC1Round3Response,\n  KeyCreationMPCv2StateEnum,\n  OVC1ToBitgoRound3Payload,\n  OVC2ToBitgoRound1Payload,\n  OVC2ToBitgoRound2Payload,\n  OVCIndexEnum,\n} from '@bitgo/public-types';\nimport { IBaseCoin } from '../../../../baseCoin';\nimport { BitGoBase } from '../../../../bitgoBase';\nimport { EcdsaMPCv2Utils } from '../ecdsaMPCv2';\nimport { decodeOrElse, Keychain } from '../../../..';\n\nexport class MPCv2SMCUtils {\n  private MPCv2Utils: EcdsaMPCv2Utils;\n\n  constructor(bitgo: BitGoBase, private baseCoin: IBaseCoin) {\n    this.MPCv2Utils = new EcdsaMPCv2Utils(bitgo, baseCoin);\n  }\n\n  public async keyGenRound1(enterprise: string, payload: OVC2ToBitgoRound1Payload): Promise<BitgoToOVC1Round1Response> {\n    decodeOrElse(OVC2ToBitgoRound1Payload.name, OVC2ToBitgoRound1Payload, payload, (errors) => {\n      throw new Error(`error(s) parsing payload: ${errors}`);\n    });\n    const ovc1 = payload.ovc[OVCIndexEnum.ONE];\n    const ovc2 = payload.ovc[OVCIndexEnum.TWO];\n    const userGpgPublicKey = ovc1.gpgPubKey;\n    const backupGpgPublicKey = ovc2.gpgPubKey;\n    const messages = { p2pMessages: [], broadcastMessages: [ovc1.ovcMsg1, ovc2.ovcMsg1] };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound1(\n      enterprise,\n      userGpgPublicKey,\n      backupGpgPublicKey,\n      messages\n    );\n\n    const response = {\n      wallet: {\n        tssVersion: payload.tssVersion,\n        walletType: payload.walletType,\n        coin: payload.coin,\n        ovc: payload.ovc,\n        state: KeyCreationMPCv2StateEnum.WaitingForOVC1Round2Data,\n        platform: {\n          walletGpgPubKeySigs: result.walletGpgPubKeySigs,\n          sessionId: result.sessionId,\n          bitgoMsg1: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg1),\n          ovc: {\n            [OVCIndexEnum.ONE]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg2) },\n            [OVCIndexEnum.TWO]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg2) },\n          },\n        },\n      },\n    };\n\n    return decodeOrElse(BitgoToOVC1Round1Response.name, BitgoToOVC1Round1Response, response, (errors) => {\n      throw new Error(`error(s) parsing response: ${errors}`);\n    });\n  }\n\n  public async keyGenRound2(enterprise: string, payload: OVC2ToBitgoRound2Payload): Promise<BitgoToOVC1Round2Response> {\n    decodeOrElse(OVC2ToBitgoRound2Payload.name, OVC2ToBitgoRound2Payload, payload, (errors) => {\n      throw new Error(`error(s) parsing payload: ${errors}`);\n    });\n    const ovc1 = payload.ovc[OVCIndexEnum.ONE];\n    const ovc2 = payload.ovc[OVCIndexEnum.TWO];\n    const sessionId = payload.platform.sessionId;\n    const messages = { p2pMessages: [ovc1.ovcToBitgoMsg2, ovc2.ovcToBitgoMsg2], broadcastMessages: [] };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound2(enterprise, sessionId, messages);\n\n    const response = {\n      wallet: {\n        tssVersion: payload.tssVersion,\n        walletType: payload.walletType,\n        coin: payload.coin,\n        ovc: payload.ovc,\n        state: KeyCreationMPCv2StateEnum.WaitingForOVC1Round3aData,\n        platform: {\n          ...payload.platform,\n          sessionId: result.sessionId,\n          bitgoCommitment2: result.bitgoCommitment2,\n          ovc: {\n            [OVCIndexEnum.ONE]: {\n              ...payload.platform.ovc[OVCIndexEnum.ONE],\n              bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg3),\n            },\n            [OVCIndexEnum.TWO]: {\n              ...payload.platform.ovc[OVCIndexEnum.TWO],\n              bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg3),\n            },\n          },\n        },\n      },\n    };\n\n    return decodeOrElse(BitgoToOVC1Round2Response.name, BitgoToOVC1Round2Response, response, (errors) => {\n      throw new Error(`error(s) parsing response: ${errors}`);\n    });\n  }\n\n  public async keyGenRound3(enterprise: string, payload: OVC1ToBitgoRound3Payload): Promise<BitgoToOVC1Round3Response> {\n    decodeOrElse(OVC1ToBitgoRound3Payload.name, OVC1ToBitgoRound3Payload, payload, (errors) => {\n      throw new Error(`error(s) parsing payload: ${errors}`);\n    });\n    const ovc1 = payload.ovc[OVCIndexEnum.ONE];\n    const ovc2 = payload.ovc[OVCIndexEnum.TWO];\n    const sessionId = payload.platform.sessionId;\n    const messages = {\n      p2pMessages: [ovc1.ovcToBitgoMsg3, ovc2.ovcToBitgoMsg3],\n      broadcastMessages: [ovc1.ovcMsg4, ovc2.ovcMsg4],\n    };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound3(enterprise, sessionId, messages);\n\n    const keychains = this.baseCoin.keychains();\n    const bitgoKeychain = await keychains.add({\n      source: 'bitgo',\n      keyType: 'tss',\n      commonKeychain: result.commonKeychain,\n      isMPCv2: true,\n    });\n\n    const response = {\n      bitGoKeyId: bitgoKeychain.id,\n      wallet: {\n        tssVersion: payload.tssVersion,\n        walletType: payload.walletType,\n        coin: payload.coin,\n        ovc: payload.ovc,\n        state: KeyCreationMPCv2StateEnum.WaitingForOVC1GenerateKey,\n        platform: {\n          ...payload.platform,\n          commonKeychain: result.commonKeychain,\n          bitgoMsg4: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg4),\n        },\n      },\n    };\n\n    return decodeOrElse(BitgoToOVC1Round3Response.name, BitgoToOVC1Round3Response, response, (errors) => {\n      throw new Error(`error(s) parsing response: ${errors}`);\n    });\n  }\n\n  public async uploadClientKeys(\n    bitgoKeyId: string,\n    userCommonKeychain: string,\n    backupCommonKeychain: string\n  ): Promise<{ userKeychain: Keychain; backupKeychain: Keychain; bitgoKeychain: Keychain }> {\n    assert(\n      userCommonKeychain === backupCommonKeychain,\n      'Common keychain mismatch between the user and backup keychains'\n    );\n\n    const keychains = this.baseCoin.keychains();\n    const bitgoKeychain = await keychains.get({ id: bitgoKeyId });\n    assert(bitgoKeychain, 'Keychain not found');\n    assert(bitgoKeychain.source === 'bitgo', 'The keychain is not a BitGo keychain');\n    assert(bitgoKeychain.type === 'tss', 'BitGo keychain is not a TSS keychain');\n    assert(bitgoKeychain.commonKeychain, 'BitGo keychain does not have a common keychain');\n    assert(bitgoKeychain.commonKeychain === userCommonKeychain, 'Common keychain mismatch between the OVCs and BitGo');\n\n    const userKeychainPromise = keychains.add({\n      source: 'user',\n      keyType: 'tss',\n      commonKeychain: userCommonKeychain,\n      isMPCv2: true,\n    });\n    const backupKeychainPromise = keychains.add({\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: backupCommonKeychain,\n      isMPCv2: true,\n    });\n\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n    return { userKeychain, backupKeychain, bitgoKeychain };\n  }\n}\n"]}
{
"name": "@bitgo/sdk-core",
"version": "27.7.0",
"version": "27.8.0",
"description": "core library functions for BitGoJS",

@@ -41,7 +41,7 @@ "main": "./dist/src/index.js",

"@bitgo/bls-dkg": "^1.3.1",
"@bitgo/public-types": "2.25.1",
"@bitgo/sdk-lib-mpc": "^9.10.2",
"@bitgo/public-types": "2.33.3",
"@bitgo/sdk-lib-mpc": "^9.11.0",
"@bitgo/sjcl": "^1.0.1",
"@bitgo/statics": "^48.26.0",
"@bitgo/utxo-lib": "^10.0.0",
"@bitgo/statics": "^48.27.0",
"@bitgo/utxo-lib": "^10.1.0",
"@noble/secp256k1": "1.6.3",

@@ -82,3 +82,3 @@ "@stablelib/hex": "^1.0.0",

},
"gitHead": "4a5dc3b04c8995de00eb05dd2b5f43c9d61aa42b"
"gitHead": "653d427b18243535fea0e8b21b948fa70892fafd"
}

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc