@vultisig/core-mpc 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -0
- package/dist/MpcServerType.d.ts +4 -0
- package/dist/MpcServerType.d.ts.map +1 -0
- package/dist/MpcServerType.js +7 -0
- package/dist/MpcServerType.js.map +1 -0
- package/dist/compression/getSevenZip.d.ts +2 -0
- package/dist/compression/getSevenZip.d.ts.map +1 -0
- package/dist/compression/getSevenZip.js +8 -0
- package/dist/compression/getSevenZip.js.map +1 -0
- package/dist/constants/defaultMpcRelayRoundTimeoutMs.d.ts +11 -0
- package/dist/constants/defaultMpcRelayRoundTimeoutMs.d.ts.map +1 -0
- package/dist/constants/defaultMpcRelayRoundTimeoutMs.js +11 -0
- package/dist/constants/defaultMpcRelayRoundTimeoutMs.js.map +1 -0
- package/dist/derSignature.d.ts +2 -0
- package/dist/derSignature.d.ts.map +1 -0
- package/dist/derSignature.js +28 -0
- package/dist/derSignature.js.map +1 -0
- package/dist/devices/MpcDevice.d.ts +6 -0
- package/dist/devices/MpcDevice.d.ts.map +1 -0
- package/dist/devices/MpcDevice.js +41 -0
- package/dist/devices/MpcDevice.js.map +1 -0
- package/dist/devices/localPartyId.d.ts +9 -0
- package/dist/devices/localPartyId.d.ts.map +1 -0
- package/dist/devices/localPartyId.js +16 -0
- package/dist/devices/localPartyId.js.map +1 -0
- package/dist/dkls/dkls.d.ts +50 -0
- package/dist/dkls/dkls.d.ts.map +1 -0
- package/dist/dkls/dkls.js +382 -0
- package/dist/dkls/dkls.js.map +1 -0
- package/dist/fast/api/checkVaultExistsOnServer.d.ts +3 -0
- package/dist/fast/api/checkVaultExistsOnServer.d.ts.map +1 -0
- package/dist/fast/api/checkVaultExistsOnServer.js +7 -0
- package/dist/fast/api/checkVaultExistsOnServer.js.map +1 -0
- package/dist/fast/api/getVaultFromServer.d.ts +9 -0
- package/dist/fast/api/getVaultFromServer.d.ts.map +1 -0
- package/dist/fast/api/getVaultFromServer.js +16 -0
- package/dist/fast/api/getVaultFromServer.js.map +1 -0
- package/dist/fast/api/keyImportWithServer.d.ts +14 -0
- package/dist/fast/api/keyImportWithServer.d.ts.map +1 -0
- package/dist/fast/api/keyImportWithServer.js +7 -0
- package/dist/fast/api/keyImportWithServer.js.map +1 -0
- package/dist/fast/api/migrateWithServer.d.ts +10 -0
- package/dist/fast/api/migrateWithServer.d.ts.map +1 -0
- package/dist/fast/api/migrateWithServer.js +7 -0
- package/dist/fast/api/migrateWithServer.js.map +1 -0
- package/dist/fast/api/mldsaWithServer.d.ts +12 -0
- package/dist/fast/api/mldsaWithServer.d.ts.map +1 -0
- package/dist/fast/api/mldsaWithServer.js +7 -0
- package/dist/fast/api/mldsaWithServer.js.map +1 -0
- package/dist/fast/api/resendVaultShare.d.ts +8 -0
- package/dist/fast/api/resendVaultShare.d.ts.map +1 -0
- package/dist/fast/api/resendVaultShare.js +7 -0
- package/dist/fast/api/resendVaultShare.js.map +1 -0
- package/dist/fast/api/reshareWithServer.d.ts +17 -0
- package/dist/fast/api/reshareWithServer.d.ts.map +1 -0
- package/dist/fast/api/reshareWithServer.js +7 -0
- package/dist/fast/api/reshareWithServer.js.map +1 -0
- package/dist/fast/api/setupVaultWithServer.d.ts +15 -0
- package/dist/fast/api/setupVaultWithServer.d.ts.map +1 -0
- package/dist/fast/api/setupVaultWithServer.js +7 -0
- package/dist/fast/api/setupVaultWithServer.js.map +1 -0
- package/dist/fast/api/signWithServer.d.ts +17 -0
- package/dist/fast/api/signWithServer.d.ts.map +1 -0
- package/dist/fast/api/signWithServer.js +7 -0
- package/dist/fast/api/signWithServer.js.map +1 -0
- package/dist/fast/api/verifyVaultEmailCode.d.ts +9 -0
- package/dist/fast/api/verifyVaultEmailCode.d.ts.map +1 -0
- package/dist/fast/api/verifyVaultEmailCode.js +6 -0
- package/dist/fast/api/verifyVaultEmailCode.js.map +1 -0
- package/dist/fast/config.d.ts +2 -0
- package/dist/fast/config.d.ts.map +1 -0
- package/dist/fast/config.js +3 -0
- package/dist/fast/config.js.map +1 -0
- package/dist/getKeygenThreshold.d.ts +2 -0
- package/dist/getKeygenThreshold.d.ts.map +1 -0
- package/dist/getKeygenThreshold.js +2 -0
- package/dist/getKeygenThreshold.js.map +1 -0
- package/dist/getMessageHash.d.ts +7 -0
- package/dist/getMessageHash.d.ts.map +1 -0
- package/dist/getMessageHash.js +12 -0
- package/dist/getMessageHash.js.map +1 -0
- package/dist/keygen/KeygenOperation.d.ts +11 -0
- package/dist/keygen/KeygenOperation.d.ts.map +1 -0
- package/dist/keygen/KeygenOperation.js +2 -0
- package/dist/keygen/KeygenOperation.js.map +1 -0
- package/dist/keygen/KeygenStep.d.ts +3 -0
- package/dist/keygen/KeygenStep.d.ts.map +1 -0
- package/dist/keygen/KeygenStep.js +2 -0
- package/dist/keygen/KeygenStep.js.map +1 -0
- package/dist/keygen/KeygenType.d.ts +5 -0
- package/dist/keygen/KeygenType.d.ts.map +1 -0
- package/dist/keygen/KeygenType.js +2 -0
- package/dist/keygen/KeygenType.js.map +1 -0
- package/dist/keygen/ReshareType.d.ts +2 -0
- package/dist/keygen/ReshareType.d.ts.map +1 -0
- package/dist/keygen/ReshareType.js +2 -0
- package/dist/keygen/ReshareType.js.map +1 -0
- package/dist/keygen/server/uploadPayloadToServer.d.ts +7 -0
- package/dist/keygen/server/uploadPayloadToServer.d.ts.map +1 -0
- package/dist/keygen/server/uploadPayloadToServer.js +12 -0
- package/dist/keygen/server/uploadPayloadToServer.js.map +1 -0
- package/dist/keygenComplete.d.ts +14 -0
- package/dist/keygenComplete.d.ts.map +1 -0
- package/dist/keygenComplete.js +22 -0
- package/dist/keygenComplete.js.map +1 -0
- package/dist/keysign/KeysignResult.d.ts +7 -0
- package/dist/keysign/KeysignResult.d.ts.map +1 -0
- package/dist/keysign/KeysignResult.js +2 -0
- package/dist/keysign/KeysignResult.js.map +1 -0
- package/dist/keysign/KeysignSignature.d.ts +8 -0
- package/dist/keysign/KeysignSignature.d.ts.map +1 -0
- package/dist/keysign/KeysignSignature.js +2 -0
- package/dist/keysign/KeysignSignature.js.map +1 -0
- package/dist/keysign/chainSpecific/FeeSettings.d.ts +12 -0
- package/dist/keysign/chainSpecific/FeeSettings.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/FeeSettings.js +6 -0
- package/dist/keysign/chainSpecific/FeeSettings.js.map +1 -0
- package/dist/keysign/chainSpecific/KeysignChainSpecific.d.ts +49 -0
- package/dist/keysign/chainSpecific/KeysignChainSpecific.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/KeysignChainSpecific.js +48 -0
- package/dist/keysign/chainSpecific/KeysignChainSpecific.js.map +1 -0
- package/dist/keysign/chainSpecific/index.d.ts +4 -0
- package/dist/keysign/chainSpecific/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/index.js +43 -0
- package/dist/keysign/chainSpecific/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolver.d.ts +38 -0
- package/dist/keysign/chainSpecific/resolver.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolver.js +2 -0
- package/dist/keysign/chainSpecific/resolver.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/index.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/index.js +41 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/refine.d.ts +9 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/refine.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/refine.js +40 -0
- package/dist/keysign/chainSpecific/resolvers/bittensor/refine.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/cardano.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/cardano.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/cardano.js +21 -0
- package/dist/keysign/chainSpecific/resolvers/cardano.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/cosmos.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/cosmos.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/cosmos.js +23 -0
- package/dist/keysign/chainSpecific/resolvers/cosmos.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/evm.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/evm.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/evm.js +42 -0
- package/dist/keysign/chainSpecific/resolvers/evm.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/maya.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/maya.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/maya.js +14 -0
- package/dist/keysign/chainSpecific/resolvers/maya.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/index.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/index.js +27 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/refine.d.ts +11 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/refine.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/refine.js +62 -0
- package/dist/keysign/chainSpecific/resolvers/polkadot/refine.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/ripple.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/ripple.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/ripple.js +39 -0
- package/dist/keysign/chainSpecific/resolvers/ripple.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/solana/index.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/solana/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/solana/index.js +41 -0
- package/dist/keysign/chainSpecific/resolvers/solana/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/solana/refine.d.ts +11 -0
- package/dist/keysign/chainSpecific/resolvers/solana/refine.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/solana/refine.js +54 -0
- package/dist/keysign/chainSpecific/resolvers/solana/refine.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/sui/index.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/sui/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/sui/index.js +28 -0
- package/dist/keysign/chainSpecific/resolvers/sui/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/sui/refine.d.ts +11 -0
- package/dist/keysign/chainSpecific/resolvers/sui/refine.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/sui/refine.js +37 -0
- package/dist/keysign/chainSpecific/resolvers/sui/refine.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/thor.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/thor.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/thor.js +19 -0
- package/dist/keysign/chainSpecific/resolvers/thor.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/ton/index.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/ton/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/ton/index.js +61 -0
- package/dist/keysign/chainSpecific/resolvers/ton/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/tron/fee.d.ts +9 -0
- package/dist/keysign/chainSpecific/resolvers/tron/fee.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/tron/fee.js +39 -0
- package/dist/keysign/chainSpecific/resolvers/tron/fee.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/tron/index.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/tron/index.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/tron/index.js +42 -0
- package/dist/keysign/chainSpecific/resolvers/tron/index.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/utxo.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/utxo.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/utxo.js +24 -0
- package/dist/keysign/chainSpecific/resolvers/utxo.js.map +1 -0
- package/dist/keysign/circleWithdraw/build.d.ts +15 -0
- package/dist/keysign/circleWithdraw/build.d.ts.map +1 -0
- package/dist/keysign/circleWithdraw/build.js +58 -0
- package/dist/keysign/circleWithdraw/build.js.map +1 -0
- package/dist/keysign/cosigner.d.ts +16 -0
- package/dist/keysign/cosigner.d.ts.map +1 -0
- package/dist/keysign/cosigner.js +202 -0
- package/dist/keysign/cosigner.js.map +1 -0
- package/dist/keysign/error.d.ts +7 -0
- package/dist/keysign/error.d.ts.map +1 -0
- package/dist/keysign/error.js +8 -0
- package/dist/keysign/error.js.map +1 -0
- package/dist/keysign/fee/index.d.ts +11 -0
- package/dist/keysign/fee/index.d.ts.map +1 -0
- package/dist/keysign/fee/index.js +32 -0
- package/dist/keysign/fee/index.js.map +1 -0
- package/dist/keysign/fee/resolver.d.ts +12 -0
- package/dist/keysign/fee/resolver.d.ts.map +1 -0
- package/dist/keysign/fee/resolver.js +2 -0
- package/dist/keysign/fee/resolver.js.map +1 -0
- package/dist/keysign/fee/resolvers/bittensor.d.ts +3 -0
- package/dist/keysign/fee/resolvers/bittensor.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/bittensor.js +7 -0
- package/dist/keysign/fee/resolvers/bittensor.js.map +1 -0
- package/dist/keysign/fee/resolvers/cardano.d.ts +3 -0
- package/dist/keysign/fee/resolvers/cardano.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/cardano.js +6 -0
- package/dist/keysign/fee/resolvers/cardano.js.map +1 -0
- package/dist/keysign/fee/resolvers/cosmos.d.ts +3 -0
- package/dist/keysign/fee/resolvers/cosmos.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/cosmos.js +49 -0
- package/dist/keysign/fee/resolvers/cosmos.js.map +1 -0
- package/dist/keysign/fee/resolvers/evm/getEvmFeeQuote.d.ts +16 -0
- package/dist/keysign/fee/resolvers/evm/getEvmFeeQuote.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/evm/getEvmFeeQuote.js +123 -0
- package/dist/keysign/fee/resolvers/evm/getEvmFeeQuote.js.map +1 -0
- package/dist/keysign/fee/resolvers/evm.d.ts +3 -0
- package/dist/keysign/fee/resolvers/evm.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/evm.js +6 -0
- package/dist/keysign/fee/resolvers/evm.js.map +1 -0
- package/dist/keysign/fee/resolvers/polkadot.d.ts +3 -0
- package/dist/keysign/fee/resolvers/polkadot.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/polkadot.js +7 -0
- package/dist/keysign/fee/resolvers/polkadot.js.map +1 -0
- package/dist/keysign/fee/resolvers/ripple.d.ts +3 -0
- package/dist/keysign/fee/resolvers/ripple.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/ripple.js +6 -0
- package/dist/keysign/fee/resolvers/ripple.js.map +1 -0
- package/dist/keysign/fee/resolvers/solana.d.ts +3 -0
- package/dist/keysign/fee/resolvers/solana.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/solana.js +6 -0
- package/dist/keysign/fee/resolvers/solana.js.map +1 -0
- package/dist/keysign/fee/resolvers/sui.d.ts +3 -0
- package/dist/keysign/fee/resolvers/sui.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/sui.js +6 -0
- package/dist/keysign/fee/resolvers/sui.js.map +1 -0
- package/dist/keysign/fee/resolvers/ton.d.ts +5 -0
- package/dist/keysign/fee/resolvers/ton.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/ton.js +8 -0
- package/dist/keysign/fee/resolvers/ton.js.map +1 -0
- package/dist/keysign/fee/resolvers/tron.d.ts +3 -0
- package/dist/keysign/fee/resolvers/tron.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/tron.js +6 -0
- package/dist/keysign/fee/resolvers/tron.js.map +1 -0
- package/dist/keysign/fee/resolvers/utxo.d.ts +3 -0
- package/dist/keysign/fee/resolvers/utxo.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/utxo.js +7 -0
- package/dist/keysign/fee/resolvers/utxo.js.map +1 -0
- package/dist/keysign/index.d.ts +17 -0
- package/dist/keysign/index.d.ts.map +1 -0
- package/dist/keysign/index.js +137 -0
- package/dist/keysign/index.js.map +1 -0
- package/dist/keysign/keysignPayload/KeysignMessagePayload.d.ts +15 -0
- package/dist/keysign/keysignPayload/KeysignMessagePayload.d.ts.map +1 -0
- package/dist/keysign/keysignPayload/KeysignMessagePayload.js +10 -0
- package/dist/keysign/keysignPayload/KeysignMessagePayload.js.map +1 -0
- package/dist/keysign/preSigningOutput/index.d.ts +25 -0
- package/dist/keysign/preSigningOutput/index.d.ts.map +1 -0
- package/dist/keysign/preSigningOutput/index.js +29 -0
- package/dist/keysign/preSigningOutput/index.js.map +1 -0
- package/dist/keysign/referral/build.d.ts +16 -0
- package/dist/keysign/referral/build.d.ts.map +1 -0
- package/dist/keysign/referral/build.js +34 -0
- package/dist/keysign/referral/build.js.map +1 -0
- package/dist/keysign/refine/amount.d.ts +12 -0
- package/dist/keysign/refine/amount.d.ts.map +1 -0
- package/dist/keysign/refine/amount.js +30 -0
- package/dist/keysign/refine/amount.js.map +1 -0
- package/dist/keysign/refine/utxo.d.ts +11 -0
- package/dist/keysign/refine/utxo.d.ts.map +1 -0
- package/dist/keysign/refine/utxo.js +80 -0
- package/dist/keysign/refine/utxo.js.map +1 -0
- package/dist/keysign/send/build.d.ts +19 -0
- package/dist/keysign/send/build.d.ts.map +1 -0
- package/dist/keysign/send/build.js +45 -0
- package/dist/keysign/send/build.js.map +1 -0
- package/dist/keysign/send/getSendFeeEstimate.d.ts +3 -0
- package/dist/keysign/send/getSendFeeEstimate.d.ts.map +1 -0
- package/dist/keysign/send/getSendFeeEstimate.js +11 -0
- package/dist/keysign/send/getSendFeeEstimate.js.map +1 -0
- package/dist/keysign/setupMessage/make.d.ts +11 -0
- package/dist/keysign/setupMessage/make.d.ts.map +1 -0
- package/dist/keysign/setupMessage/make.js +8 -0
- package/dist/keysign/setupMessage/make.js.map +1 -0
- package/dist/keysign/signingInputs/core.d.ts +17 -0
- package/dist/keysign/signingInputs/core.d.ts.map +1 -0
- package/dist/keysign/signingInputs/core.js +15 -0
- package/dist/keysign/signingInputs/core.js.map +1 -0
- package/dist/keysign/signingInputs/index.d.ts +11 -0
- package/dist/keysign/signingInputs/index.d.ts.map +1 -0
- package/dist/keysign/signingInputs/index.js +41 -0
- package/dist/keysign/signingInputs/index.js.map +1 -0
- package/dist/keysign/signingInputs/resolver.d.ts +15 -0
- package/dist/keysign/signingInputs/resolver.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolver.js +2 -0
- package/dist/keysign/signingInputs/resolver.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/bittensor.d.ts +12 -0
- package/dist/keysign/signingInputs/resolvers/bittensor.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/bittensor.js +51 -0
- package/dist/keysign/signingInputs/resolvers/bittensor.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cardano.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/cardano.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cardano.js +28 -0
- package/dist/keysign/signingInputs/resolvers/cardano.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/chainSpecific.d.ts +10 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/chainSpecific.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/chainSpecific.js +9 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/chainSpecific.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/coinAmount.d.ts +6 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/coinAmount.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/coinAmount.js +14 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/coinAmount.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/index.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/index.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/index.js +338 -0
- package/dist/keysign/signingInputs/resolvers/cosmos/index.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/evm/erc20.d.ts +9 -0
- package/dist/keysign/signingInputs/resolvers/evm/erc20.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/evm/erc20.js +37 -0
- package/dist/keysign/signingInputs/resolvers/evm/erc20.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/evm/index.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/evm/index.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/evm/index.js +143 -0
- package/dist/keysign/signingInputs/resolvers/evm/index.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/polkadot.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/polkadot.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/polkadot.js +59 -0
- package/dist/keysign/signingInputs/resolvers/polkadot.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ripple.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/ripple.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ripple.js +66 -0
- package/dist/keysign/signingInputs/resolvers/ripple.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/solana/index.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/solana/index.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/solana/index.js +59 -0
- package/dist/keysign/signingInputs/resolvers/solana/index.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/solana/send.d.ts +9 -0
- package/dist/keysign/signingInputs/resolvers/solana/send.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/solana/send.js +69 -0
- package/dist/keysign/signingInputs/resolvers/solana/send.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/sui.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/sui.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/sui.js +53 -0
- package/dist/keysign/signingInputs/resolvers/sui.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/index.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/ton/index.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/index.js +34 -0
- package/dist/keysign/signingInputs/resolvers/ton/index.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/jetton.d.ts +12 -0
- package/dist/keysign/signingInputs/resolvers/ton/jetton.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/jetton.js +28 -0
- package/dist/keysign/signingInputs/resolvers/ton/jetton.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/native.d.ts +10 -0
- package/dist/keysign/signingInputs/resolvers/ton/native.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/native.js +20 -0
- package/dist/keysign/signingInputs/resolvers/ton/native.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/tron.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/tron.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/tron.js +246 -0
- package/dist/keysign/signingInputs/resolvers/tron.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/utxo.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/utxo.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/utxo.js +79 -0
- package/dist/keysign/signingInputs/resolvers/utxo.js.map +1 -0
- package/dist/keysign/swap/KeysignSwapPayload.d.ts +20 -0
- package/dist/keysign/swap/KeysignSwapPayload.d.ts.map +1 -0
- package/dist/keysign/swap/KeysignSwapPayload.js +2 -0
- package/dist/keysign/swap/KeysignSwapPayload.js.map +1 -0
- package/dist/keysign/swap/build.d.ts +20 -0
- package/dist/keysign/swap/build.d.ts.map +1 -0
- package/dist/keysign/swap/build.js +149 -0
- package/dist/keysign/swap/build.js.map +1 -0
- package/dist/keysign/swap/getKeysignSwapPayload.d.ts +4 -0
- package/dist/keysign/swap/getKeysignSwapPayload.d.ts.map +1 -0
- package/dist/keysign/swap/getKeysignSwapPayload.js +20 -0
- package/dist/keysign/swap/getKeysignSwapPayload.js.map +1 -0
- package/dist/keysign/swap/getKeysignSwapProviderName.d.ts +3 -0
- package/dist/keysign/swap/getKeysignSwapProviderName.d.ts.map +1 -0
- package/dist/keysign/swap/getKeysignSwapProviderName.js +10 -0
- package/dist/keysign/swap/getKeysignSwapProviderName.js.map +1 -0
- package/dist/keysign/tw/getKeysignTwPublicKey.d.ts +3 -0
- package/dist/keysign/tw/getKeysignTwPublicKey.d.ts.map +1 -0
- package/dist/keysign/tw/getKeysignTwPublicKey.js +6 -0
- package/dist/keysign/tw/getKeysignTwPublicKey.js.map +1 -0
- package/dist/keysign/tw/toTwAddress.d.ts +10 -0
- package/dist/keysign/tw/toTwAddress.d.ts.map +1 -0
- package/dist/keysign/tw/toTwAddress.js +13 -0
- package/dist/keysign/tw/toTwAddress.js.map +1 -0
- package/dist/keysign/utils/getJoinKeysignUrl.d.ts +14 -0
- package/dist/keysign/utils/getJoinKeysignUrl.d.ts.map +1 -0
- package/dist/keysign/utils/getJoinKeysignUrl.js +84 -0
- package/dist/keysign/utils/getJoinKeysignUrl.js.map +1 -0
- package/dist/keysign/utils/getKeysignAmount.d.ts +3 -0
- package/dist/keysign/utils/getKeysignAmount.d.ts.map +1 -0
- package/dist/keysign/utils/getKeysignAmount.js +2 -0
- package/dist/keysign/utils/getKeysignAmount.js.map +1 -0
- package/dist/keysign/utils/getKeysignChain.d.ts +4 -0
- package/dist/keysign/utils/getKeysignChain.d.ts.map +1 -0
- package/dist/keysign/utils/getKeysignChain.js +3 -0
- package/dist/keysign/utils/getKeysignChain.js.map +1 -0
- package/dist/keysign/utils/getKeysignCoin.d.ts +5 -0
- package/dist/keysign/utils/getKeysignCoin.d.ts.map +1 -0
- package/dist/keysign/utils/getKeysignCoin.js +4 -0
- package/dist/keysign/utils/getKeysignCoin.js.map +1 -0
- package/dist/keysign/utils/resolvePolkadotToAddress.d.ts +9 -0
- package/dist/keysign/utils/resolvePolkadotToAddress.d.ts.map +1 -0
- package/dist/keysign/utils/resolvePolkadotToAddress.js +14 -0
- package/dist/keysign/utils/resolvePolkadotToAddress.js.map +1 -0
- package/dist/keysign/utxo/getKeysignUtxoInfo.d.ts +3 -0
- package/dist/keysign/utxo/getKeysignUtxoInfo.d.ts.map +1 -0
- package/dist/keysign/utxo/getKeysignUtxoInfo.js +13 -0
- package/dist/keysign/utxo/getKeysignUtxoInfo.js.map +1 -0
- package/dist/keysignComplete.d.ts +10 -0
- package/dist/keysignComplete.d.ts.map +1 -0
- package/dist/keysignComplete.js +9 -0
- package/dist/keysignComplete.js.map +1 -0
- package/dist/lib/initialize.d.ts +3 -0
- package/dist/lib/initialize.d.ts.map +1 -0
- package/dist/lib/initialize.js +11 -0
- package/dist/lib/initialize.js.map +1 -0
- package/dist/lib/keyshare.d.ts +10 -0
- package/dist/lib/keyshare.d.ts.map +1 -0
- package/dist/lib/keyshare.js +8 -0
- package/dist/lib/keyshare.js.map +1 -0
- package/dist/lib/signSession.d.ts +13 -0
- package/dist/lib/signSession.d.ts.map +1 -0
- package/dist/lib/signSession.js +12 -0
- package/dist/lib/signSession.js.map +1 -0
- package/dist/message/relay/delete.d.ts +10 -0
- package/dist/message/relay/delete.d.ts.map +1 -0
- package/dist/message/relay/delete.js +10 -0
- package/dist/message/relay/delete.js.map +1 -0
- package/dist/message/relay/get.d.ts +10 -0
- package/dist/message/relay/get.d.ts.map +1 -0
- package/dist/message/relay/get.js +9 -0
- package/dist/message/relay/get.js.map +1 -0
- package/dist/message/relay/index.d.ts +9 -0
- package/dist/message/relay/index.d.ts.map +1 -0
- package/dist/message/relay/index.js +2 -0
- package/dist/message/relay/index.js.map +1 -0
- package/dist/message/relay/send.d.ts +10 -0
- package/dist/message/relay/send.d.ts.map +1 -0
- package/dist/message/relay/send.js +10 -0
- package/dist/message/relay/send.js.map +1 -0
- package/dist/message/server.d.ts +3 -0
- package/dist/message/server.d.ts.map +1 -0
- package/dist/message/server.js +13 -0
- package/dist/message/server.js.map +1 -0
- package/dist/message/setup/ensure.d.ts +15 -0
- package/dist/message/setup/ensure.d.ts.map +1 -0
- package/dist/message/setup/ensure.js +33 -0
- package/dist/message/setup/ensure.js.map +1 -0
- package/dist/message/setup/get.d.ts +8 -0
- package/dist/message/setup/get.d.ts.map +1 -0
- package/dist/message/setup/get.js +15 -0
- package/dist/message/setup/get.js.map +1 -0
- package/dist/message/setup/upload.d.ts +9 -0
- package/dist/message/setup/upload.d.ts.map +1 -0
- package/dist/message/setup/upload.js +10 -0
- package/dist/message/setup/upload.js.map +1 -0
- package/dist/mldsa/initializeMldsa.d.ts +2 -0
- package/dist/mldsa/initializeMldsa.d.ts.map +1 -0
- package/dist/mldsa/initializeMldsa.js +6 -0
- package/dist/mldsa/initializeMldsa.js.map +1 -0
- package/dist/mldsa/mldsaKeygen.d.ts +26 -0
- package/dist/mldsa/mldsaKeygen.d.ts.map +1 -0
- package/dist/mldsa/mldsaKeygen.js +176 -0
- package/dist/mldsa/mldsaKeygen.js.map +1 -0
- package/dist/mldsa/mldsaKeysign.d.ts +37 -0
- package/dist/mldsa/mldsaKeysign.d.ts.map +1 -0
- package/dist/mldsa/mldsaKeysign.js +185 -0
- package/dist/mldsa/mldsaKeysign.js.map +1 -0
- package/dist/mpcLib.d.ts +6 -0
- package/dist/mpcLib.d.ts.map +1 -0
- package/dist/mpcLib.js +3 -0
- package/dist/mpcLib.js.map +1 -0
- package/dist/reshareCommittee.d.ts +11 -0
- package/dist/reshareCommittee.d.ts.map +1 -0
- package/dist/reshareCommittee.js +19 -0
- package/dist/reshareCommittee.js.map +1 -0
- package/dist/schnorr/schnorrKeygen.d.ts +47 -0
- package/dist/schnorr/schnorrKeygen.d.ts.map +1 -0
- package/dist/schnorr/schnorrKeygen.js +353 -0
- package/dist/schnorr/schnorrKeygen.js.map +1 -0
- package/dist/session/joinMpcSession.d.ts +8 -0
- package/dist/session/joinMpcSession.d.ts.map +1 -0
- package/dist/session/joinMpcSession.js +6 -0
- package/dist/session/joinMpcSession.js.map +1 -0
- package/dist/session/startMpcSession.d.ts +8 -0
- package/dist/session/startMpcSession.d.ts.map +1 -0
- package/dist/session/startMpcSession.js +6 -0
- package/dist/session/startMpcSession.js.map +1 -0
- package/dist/types/plugin/constraint_pb.d.ts +205 -0
- package/dist/types/plugin/constraint_pb.d.ts.map +1 -0
- package/dist/types/plugin/constraint_pb.js +84 -0
- package/dist/types/plugin/constraint_pb.js.map +1 -0
- package/dist/types/plugin/parameter_constraint_pb.d.ts +41 -0
- package/dist/types/plugin/parameter_constraint_pb.d.ts.map +1 -0
- package/dist/types/plugin/parameter_constraint_pb.js +15 -0
- package/dist/types/plugin/parameter_constraint_pb.js.map +1 -0
- package/dist/types/plugin/policy_pb.d.ts +370 -0
- package/dist/types/plugin/policy_pb.d.ts.map +1 -0
- package/dist/types/plugin/policy_pb.js +86 -0
- package/dist/types/plugin/policy_pb.js.map +1 -0
- package/dist/types/plugin/recipe_specification_pb.d.ts +305 -0
- package/dist/types/plugin/recipe_specification_pb.d.ts.map +1 -0
- package/dist/types/plugin/recipe_specification_pb.js +33 -0
- package/dist/types/plugin/recipe_specification_pb.js.map +1 -0
- package/dist/types/plugin/resource_pb.d.ts +133 -0
- package/dist/types/plugin/resource_pb.d.ts.map +1 -0
- package/dist/types/plugin/resource_pb.js +19 -0
- package/dist/types/plugin/resource_pb.js.map +1 -0
- package/dist/types/plugin/rule_pb.d.ts +281 -0
- package/dist/types/plugin/rule_pb.d.ts.map +1 -0
- package/dist/types/plugin/rule_pb.js +72 -0
- package/dist/types/plugin/rule_pb.js.map +1 -0
- package/dist/types/utils/commCoin.d.ts +10 -0
- package/dist/types/utils/commCoin.d.ts.map +1 -0
- package/dist/types/utils/commCoin.js +29 -0
- package/dist/types/utils/commCoin.js.map +1 -0
- package/dist/types/utils/commVault.d.ts +5 -0
- package/dist/types/utils/commVault.d.ts.map +1 -0
- package/dist/types/utils/commVault.js +148 -0
- package/dist/types/utils/commVault.js.map +1 -0
- package/dist/types/utils/libType.d.ts +12 -0
- package/dist/types/utils/libType.d.ts.map +1 -0
- package/dist/types/utils/libType.js +32 -0
- package/dist/types/utils/libType.js.map +1 -0
- package/dist/types/utils/tssType.d.ts +12 -0
- package/dist/types/utils/tssType.d.ts.map +1 -0
- package/dist/types/utils/tssType.js +36 -0
- package/dist/types/utils/tssType.js.map +1 -0
- package/dist/types/vultisig/keygen/v1/keygen_message_pb.d.ts +54 -0
- package/dist/types/vultisig/keygen/v1/keygen_message_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keygen/v1/keygen_message_pb.js +15 -0
- package/dist/types/vultisig/keygen/v1/keygen_message_pb.js.map +1 -0
- package/dist/types/vultisig/keygen/v1/lib_type_message_pb.d.ts +31 -0
- package/dist/types/vultisig/keygen/v1/lib_type_message_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keygen/v1/lib_type_message_pb.js +35 -0
- package/dist/types/vultisig/keygen/v1/lib_type_message_pb.js.map +1 -0
- package/dist/types/vultisig/keygen/v1/reshare_message_pb.d.ts +60 -0
- package/dist/types/vultisig/keygen/v1/reshare_message_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keygen/v1/reshare_message_pb.js +15 -0
- package/dist/types/vultisig/keygen/v1/reshare_message_pb.js.map +1 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_message_pb.d.ts +55 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_message_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_message_pb.js +23 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_message_pb.js.map +1 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_type_pb.d.ts +21 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_type_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_type_pb.js +29 -0
- package/dist/types/vultisig/keygen/v1/single_keygen_type_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/1inch_swap_payload_pb.d.ts +98 -0
- package/dist/types/vultisig/keysign/v1/1inch_swap_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/1inch_swap_payload_pb.js +25 -0
- package/dist/types/vultisig/keysign/v1/1inch_swap_payload_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/blockchain_specific_pb.d.ts +484 -0
- package/dist/types/vultisig/keysign/v1/blockchain_specific_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/blockchain_specific_pb.js +130 -0
- package/dist/types/vultisig/keysign/v1/blockchain_specific_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/coin_pb.d.ts +55 -0
- package/dist/types/vultisig/keysign/v1/coin_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/coin_pb.js +14 -0
- package/dist/types/vultisig/keysign/v1/coin_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/custom_message_payload_pb.d.ts +37 -0
- package/dist/types/vultisig/keysign/v1/custom_message_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/custom_message_payload_pb.js +14 -0
- package/dist/types/vultisig/keysign/v1/custom_message_payload_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/erc20_approve_payload_pb.d.ts +25 -0
- package/dist/types/vultisig/keysign/v1/erc20_approve_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/erc20_approve_payload_pb.js +14 -0
- package/dist/types/vultisig/keysign/v1/erc20_approve_payload_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.d.ts +275 -0
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.js +29 -0
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/kyberswap_swap_payload_pb.d.ts +94 -0
- package/dist/types/vultisig/keysign/v1/kyberswap_swap_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/kyberswap_swap_payload_pb.js +25 -0
- package/dist/types/vultisig/keysign/v1/kyberswap_swap_payload_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/thorchain_swap_payload_pb.d.ts +70 -0
- package/dist/types/vultisig/keysign/v1/thorchain_swap_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/thorchain_swap_payload_pb.js +15 -0
- package/dist/types/vultisig/keysign/v1/thorchain_swap_payload_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/tron_contract_payload_pb.d.ts +89 -0
- package/dist/types/vultisig/keysign/v1/tron_contract_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/tron_contract_payload_pb.js +24 -0
- package/dist/types/vultisig/keysign/v1/tron_contract_payload_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/utxo_info_pb.d.ts +29 -0
- package/dist/types/vultisig/keysign/v1/utxo_info_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/utxo_info_pb.js +14 -0
- package/dist/types/vultisig/keysign/v1/utxo_info_pb.js.map +1 -0
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.d.ts +159 -0
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.d.ts.map +1 -0
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.js +44 -0
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.js.map +1 -0
- package/dist/types/vultisig/vault/v1/vault_container_pb.d.ts +35 -0
- package/dist/types/vultisig/vault/v1/vault_container_pb.d.ts.map +1 -0
- package/dist/types/vultisig/vault/v1/vault_container_pb.js +14 -0
- package/dist/types/vultisig/vault/v1/vault_container_pb.js.map +1 -0
- package/dist/types/vultisig/vault/v1/vault_pb.d.ts +109 -0
- package/dist/types/vultisig/vault/v1/vault_pb.d.ts.map +1 -0
- package/dist/types/vultisig/vault/v1/vault_pb.js +26 -0
- package/dist/types/vultisig/vault/v1/vault_pb.js.map +1 -0
- package/dist/utils/ed25519ScalarClamp.d.ts +2 -0
- package/dist/utils/ed25519ScalarClamp.d.ts.map +1 -0
- package/dist/utils/ed25519ScalarClamp.js +40 -0
- package/dist/utils/ed25519ScalarClamp.js.map +1 -0
- package/dist/utils/generateHexChainCode.d.ts +2 -0
- package/dist/utils/generateHexChainCode.d.ts.map +1 -0
- package/dist/utils/generateHexChainCode.js +3 -0
- package/dist/utils/generateHexChainCode.js.map +1 -0
- package/dist/utils/generateHexEncryptionKey.d.ts +2 -0
- package/dist/utils/generateHexEncryptionKey.d.ts.map +1 -0
- package/dist/utils/generateHexEncryptionKey.js +3 -0
- package/dist/utils/generateHexEncryptionKey.js.map +1 -0
- package/dist/vault/Vault.d.ts +32 -0
- package/dist/vault/Vault.d.ts.map +1 -0
- package/dist/vault/Vault.js +4 -0
- package/dist/vault/Vault.js.map +1 -0
- package/dist/vault/utils/vaultContainerFromString.d.ts +2 -0
- package/dist/vault/utils/vaultContainerFromString.d.ts.map +1 -0
- package/dist/vault/utils/vaultContainerFromString.js +6 -0
- package/dist/vault/utils/vaultContainerFromString.js.map +1 -0
- package/package.json +51 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { getMessageHash } from '@vultisig/core-mpc/getMessageHash';
|
|
2
|
+
import { prefixErrorWith } from '@vultisig/lib-utils/error/prefixErrorWith';
|
|
3
|
+
import { transformError } from '@vultisig/lib-utils/error/transformError';
|
|
4
|
+
import { makeSetupMessage } from '../../keysign/setupMessage/make.js';
|
|
5
|
+
import { fromMpcServerMessage, toMpcServerMessage } from '../server.js';
|
|
6
|
+
import { waitForSetupMessage } from './get.js';
|
|
7
|
+
import { uploadMpcSetupMessage } from './upload.js';
|
|
8
|
+
export const ensureSetupMessage = async ({ keyShare, signatureAlgorithm, message, chainPath, devices, serverUrl, sessionId, hexEncryptionKey, isInitiatingDevice, }) => {
|
|
9
|
+
const messageId = getMessageHash(message);
|
|
10
|
+
if (isInitiatingDevice) {
|
|
11
|
+
const setupMessage = makeSetupMessage({
|
|
12
|
+
keyShare,
|
|
13
|
+
chainPath,
|
|
14
|
+
message,
|
|
15
|
+
devices,
|
|
16
|
+
signatureAlgorithm,
|
|
17
|
+
});
|
|
18
|
+
await transformError(uploadMpcSetupMessage({
|
|
19
|
+
serverUrl,
|
|
20
|
+
sessionId,
|
|
21
|
+
message: toMpcServerMessage(setupMessage, hexEncryptionKey),
|
|
22
|
+
messageId,
|
|
23
|
+
}), prefixErrorWith('Failed to upload setup message'));
|
|
24
|
+
return setupMessage;
|
|
25
|
+
}
|
|
26
|
+
const serverSetupMessage = await transformError(waitForSetupMessage({
|
|
27
|
+
serverUrl,
|
|
28
|
+
sessionId,
|
|
29
|
+
messageId,
|
|
30
|
+
}), prefixErrorWith('Timed out while waiting for setup message'));
|
|
31
|
+
return fromMpcServerMessage(serverSetupMessage, hexEncryptionKey);
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=ensure.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensure.js","sourceRoot":"","sources":["../../../../../../packages/core/mpc/message/setup/ensure.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAA;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAA;AAC3E,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAA;AAEzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAA;AAClE,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAA;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,OAAO,CAAA;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAA;AAchD,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EAAE,EACvC,QAAQ,EACR,kBAAkB,EAClB,OAAO,EACP,SAAS,EACT,OAAO,EACP,SAAS,EACT,SAAS,EACT,gBAAgB,EAChB,kBAAkB,GACM,EAAE,EAAE;IAC5B,MAAM,SAAS,GAAG,cAAc,CAAC,OAAO,CAAC,CAAA;IAEzC,IAAI,kBAAkB,EAAE,CAAC;QACvB,MAAM,YAAY,GAAG,gBAAgB,CAAC;YACpC,QAAQ;YACR,SAAS;YACT,OAAO;YACP,OAAO;YACP,kBAAkB;SACnB,CAAC,CAAA;QAEF,MAAM,cAAc,CAClB,qBAAqB,CAAC;YACpB,SAAS;YACT,SAAS;YACT,OAAO,EAAE,kBAAkB,CAAC,YAAY,EAAE,gBAAgB,CAAC;YAC3D,SAAS;SACV,CAAC,EACF,eAAe,CAAC,gCAAgC,CAAC,CAClD,CAAA;QAED,OAAO,YAAY,CAAA;IACrB,CAAC;IAED,MAAM,kBAAkB,GAAG,MAAM,cAAc,CAC7C,mBAAmB,CAAC;QAClB,SAAS;QACT,SAAS;QACT,SAAS;KACV,CAAC,EACF,eAAe,CAAC,2CAA2C,CAAC,CAC7D,CAAA;IAED,OAAO,oBAAoB,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAA;AACnE,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get.d.ts","sourceRoot":"","sources":["../../../../../../packages/core/mpc/message/setup/get.ts"],"names":[],"mappings":"AAIA,KAAK,uBAAuB,GAAG;IAC7B,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAcD,eAAO,MAAM,mBAAmB,GAC9B,OAAO,uBAAuB,KAC7B,OAAO,CAAC,MAAM,CAKb,CAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { queryUrl } from '@vultisig/lib-utils/query/queryUrl';
|
|
2
|
+
import { retry } from '@vultisig/lib-utils/query/retry';
|
|
3
|
+
import { withoutUndefinedFields } from '@vultisig/lib-utils/record/withoutUndefinedFields';
|
|
4
|
+
const getMpcSetupMessage = async ({ serverUrl, sessionId, messageId, }) => queryUrl(`${serverUrl}/setup-message/${sessionId}`, {
|
|
5
|
+
headers: withoutUndefinedFields({
|
|
6
|
+
message_id: messageId,
|
|
7
|
+
}),
|
|
8
|
+
responseType: 'text',
|
|
9
|
+
});
|
|
10
|
+
export const waitForSetupMessage = async (input) => retry({
|
|
11
|
+
func: () => getMpcSetupMessage(input),
|
|
12
|
+
attempts: 10,
|
|
13
|
+
delay: 1000,
|
|
14
|
+
});
|
|
15
|
+
//# sourceMappingURL=get.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get.js","sourceRoot":"","sources":["../../../../../../packages/core/mpc/message/setup/get.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oCAAoC,CAAA;AAC7D,OAAO,EAAE,KAAK,EAAE,MAAM,iCAAiC,CAAA;AACvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,mDAAmD,CAAA;AAQ1F,MAAM,kBAAkB,GAAG,KAAK,EAAE,EAChC,SAAS,EACT,SAAS,EACT,SAAS,GACe,EAAE,EAAE,CAC5B,QAAQ,CAAC,GAAG,SAAS,kBAAkB,SAAS,EAAE,EAAE;IAClD,OAAO,EAAE,sBAAsB,CAAC;QAC9B,UAAU,EAAE,SAAS;KACtB,CAAC;IACF,YAAY,EAAE,MAAM;CACrB,CAAC,CAAA;AAEJ,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EACtC,KAA8B,EACb,EAAE,CACnB,KAAK,CAAC;IACJ,IAAI,EAAE,GAAG,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC;IACrC,QAAQ,EAAE,EAAE;IACZ,KAAK,EAAE,IAAI;CACZ,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
type UploadMpcSetupMessageInput = {
|
|
2
|
+
serverUrl: string;
|
|
3
|
+
message: string;
|
|
4
|
+
sessionId: string;
|
|
5
|
+
messageId?: string;
|
|
6
|
+
};
|
|
7
|
+
export declare const uploadMpcSetupMessage: ({ serverUrl, message, sessionId, messageId, }: UploadMpcSetupMessageInput) => Promise<void>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=upload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload.d.ts","sourceRoot":"","sources":["../../../../../../packages/core/mpc/message/setup/upload.ts"],"names":[],"mappings":"AAGA,KAAK,0BAA0B,GAAG;IAChC,SAAS,EAAE,MAAM,CAAA;IACjB,OAAO,EAAE,MAAM,CAAA;IACf,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,qBAAqB,GAAU,+CAKzC,0BAA0B,kBAOzB,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { queryUrl } from '@vultisig/lib-utils/query/queryUrl';
|
|
2
|
+
import { withoutUndefinedFields } from '@vultisig/lib-utils/record/withoutUndefinedFields';
|
|
3
|
+
export const uploadMpcSetupMessage = async ({ serverUrl, message, sessionId, messageId, }) => queryUrl(`${serverUrl}/setup-message/${sessionId}`, {
|
|
4
|
+
headers: withoutUndefinedFields({
|
|
5
|
+
message_id: messageId,
|
|
6
|
+
}),
|
|
7
|
+
body: message,
|
|
8
|
+
responseType: 'none',
|
|
9
|
+
});
|
|
10
|
+
//# sourceMappingURL=upload.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload.js","sourceRoot":"","sources":["../../../../../../packages/core/mpc/message/setup/upload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oCAAoC,CAAA;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,mDAAmD,CAAA;AAS1F,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,EAAE,EAC1C,SAAS,EACT,OAAO,EACP,SAAS,EACT,SAAS,GACkB,EAAE,EAAE,CAC/B,QAAQ,CAAC,GAAG,SAAS,kBAAkB,SAAS,EAAE,EAAE;IAClD,OAAO,EAAE,sBAAsB,CAAC;QAC9B,UAAU,EAAE,SAAS;KACtB,CAAC;IACF,IAAI,EAAE,OAAO;IACb,YAAY,EAAE,MAAM;CACrB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initializeMldsa.d.ts","sourceRoot":"","sources":["../../../../../packages/core/mpc/mldsa/initializeMldsa.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,kBAAkB,iEAK9B,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import initializeMldsa from '@vultisig/lib-mldsa/vs_wasm';
|
|
2
|
+
import { prefixErrorWith } from '@vultisig/lib-utils/error/prefixErrorWith';
|
|
3
|
+
import { transformError } from '@vultisig/lib-utils/error/transformError';
|
|
4
|
+
import { memoizeAsync } from '@vultisig/lib-utils/memoizeAsync';
|
|
5
|
+
export const initializeMldsaLib = memoizeAsync(() => transformError(initializeMldsa(), prefixErrorWith('Failed to initialize MLDSA lib')));
|
|
6
|
+
//# sourceMappingURL=initializeMldsa.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initializeMldsa.js","sourceRoot":"","sources":["../../../../../packages/core/mpc/mldsa/initializeMldsa.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,6BAA6B,CAAA;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAA;AAC3E,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAA;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAA;AAE/D,MAAM,CAAC,MAAM,kBAAkB,GAAG,YAAY,CAAC,GAAG,EAAE,CAClD,cAAc,CACZ,eAAe,EAAE,EACjB,eAAe,CAAC,gCAAgC,CAAC,CAClD,CACF,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
type MldsaKeygenResult = {
|
|
2
|
+
keyshare: string;
|
|
3
|
+
publicKey: string;
|
|
4
|
+
};
|
|
5
|
+
export declare class MldsaKeygen {
|
|
6
|
+
private readonly isInitiateDevice;
|
|
7
|
+
private readonly serverURL;
|
|
8
|
+
private readonly sessionId;
|
|
9
|
+
private readonly localPartyId;
|
|
10
|
+
private readonly keygenCommittee;
|
|
11
|
+
private readonly hexEncryptionKey;
|
|
12
|
+
private readonly timeoutMs;
|
|
13
|
+
private isKeygenComplete;
|
|
14
|
+
private sequenceNo;
|
|
15
|
+
private cache;
|
|
16
|
+
private setupMessage;
|
|
17
|
+
constructor(isInitiateDevice: boolean, serverURL: string, sessionId: string, localPartyId: string, keygenCommittee: string[], hexEncryptionKey: string, options?: {
|
|
18
|
+
timeoutMs?: number;
|
|
19
|
+
});
|
|
20
|
+
private processOutbound;
|
|
21
|
+
private processInbound;
|
|
22
|
+
private startKeygen;
|
|
23
|
+
startKeygenWithRetry(): Promise<MldsaKeygenResult>;
|
|
24
|
+
}
|
|
25
|
+
export {};
|
|
26
|
+
//# sourceMappingURL=mldsaKeygen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mldsaKeygen.d.ts","sourceRoot":"","sources":["../../../../../packages/core/mpc/mldsa/mldsaKeygen.ts"],"names":[],"mappings":"AAgBA,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAC1C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAQ;IACrC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAU;IAC1C,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAQ;IACzC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,gBAAgB,CAAiB;IACzC,OAAO,CAAC,UAAU,CAAY;IAC9B,OAAO,CAAC,KAAK,CAA6B;IAC1C,OAAO,CAAC,YAAY,CAA+B;gBAGjD,gBAAgB,EAAE,OAAO,EACzB,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,EACpB,eAAe,EAAE,MAAM,EAAE,EACzB,gBAAgB,EAAE,MAAM,EACxB,OAAO,CAAC,EAAE;QACR,SAAS,CAAC,EAAE,MAAM,CAAA;KACnB;YAWW,eAAe;YAuCf,cAAc;YA2Dd,WAAW;IA6DZ,oBAAoB,IAAI,OAAO,CAAC,iBAAiB,CAAC;CAYhE"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { KeygenSession } from '@vultisig/lib-mldsa/vs_wasm';
|
|
2
|
+
import { base64Encode } from '@vultisig/lib-utils/base64Encode';
|
|
3
|
+
import { getKeygenThreshold } from '../getKeygenThreshold.js';
|
|
4
|
+
import { getMessageHash } from '../getMessageHash.js';
|
|
5
|
+
import { deleteMpcRelayMessage } from '../message/relay/delete.js';
|
|
6
|
+
import { getMpcRelayMessages } from '../message/relay/get.js';
|
|
7
|
+
import { sendMpcRelayMessage } from '../message/relay/send.js';
|
|
8
|
+
import { fromMpcServerMessage, toMpcServerMessage } from '../message/server.js';
|
|
9
|
+
import { waitForSetupMessage } from '../message/setup/get.js';
|
|
10
|
+
import { uploadMpcSetupMessage } from '../message/setup/upload.js';
|
|
11
|
+
import { sleep } from '@vultisig/lib-utils/sleep';
|
|
12
|
+
import { initializeMldsaLib } from './initializeMldsa.js';
|
|
13
|
+
const mldsaLevel = 44;
|
|
14
|
+
export class MldsaKeygen {
|
|
15
|
+
isInitiateDevice;
|
|
16
|
+
serverURL;
|
|
17
|
+
sessionId;
|
|
18
|
+
localPartyId;
|
|
19
|
+
keygenCommittee;
|
|
20
|
+
hexEncryptionKey;
|
|
21
|
+
timeoutMs;
|
|
22
|
+
isKeygenComplete = false;
|
|
23
|
+
sequenceNo = 0;
|
|
24
|
+
cache = {};
|
|
25
|
+
setupMessage = new Uint8Array();
|
|
26
|
+
constructor(isInitiateDevice, serverURL, sessionId, localPartyId, keygenCommittee, hexEncryptionKey, options) {
|
|
27
|
+
this.isInitiateDevice = isInitiateDevice;
|
|
28
|
+
this.serverURL = serverURL;
|
|
29
|
+
this.sessionId = sessionId;
|
|
30
|
+
this.localPartyId = localPartyId;
|
|
31
|
+
this.keygenCommittee = keygenCommittee;
|
|
32
|
+
this.hexEncryptionKey = hexEncryptionKey;
|
|
33
|
+
this.timeoutMs = options?.timeoutMs ?? 60000;
|
|
34
|
+
}
|
|
35
|
+
async processOutbound(session) {
|
|
36
|
+
try {
|
|
37
|
+
const message = session.outputMessage();
|
|
38
|
+
if (message === undefined) {
|
|
39
|
+
if (this.isKeygenComplete) {
|
|
40
|
+
return true;
|
|
41
|
+
}
|
|
42
|
+
await sleep(100);
|
|
43
|
+
return this.processOutbound(session);
|
|
44
|
+
}
|
|
45
|
+
const body = toMpcServerMessage(message.body, this.hexEncryptionKey);
|
|
46
|
+
message.receivers.forEach(receiver => {
|
|
47
|
+
sendMpcRelayMessage({
|
|
48
|
+
serverUrl: this.serverURL,
|
|
49
|
+
sessionId: this.sessionId,
|
|
50
|
+
message: {
|
|
51
|
+
session_id: this.sessionId,
|
|
52
|
+
from: this.localPartyId,
|
|
53
|
+
to: [receiver],
|
|
54
|
+
body,
|
|
55
|
+
hash: getMessageHash(base64Encode(message.body)),
|
|
56
|
+
sequence_no: this.sequenceNo,
|
|
57
|
+
},
|
|
58
|
+
messageId: '',
|
|
59
|
+
});
|
|
60
|
+
this.sequenceNo++;
|
|
61
|
+
});
|
|
62
|
+
await sleep(100);
|
|
63
|
+
return this.processOutbound(session);
|
|
64
|
+
}
|
|
65
|
+
catch (error) {
|
|
66
|
+
console.error('MLDSA processOutbound error:', error);
|
|
67
|
+
await sleep(100);
|
|
68
|
+
return this.processOutbound(session);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
async processInbound(session, start) {
|
|
72
|
+
try {
|
|
73
|
+
const elapsed = Date.now() - start;
|
|
74
|
+
if (elapsed > this.timeoutMs * 2) {
|
|
75
|
+
this.isKeygenComplete = true;
|
|
76
|
+
return false;
|
|
77
|
+
}
|
|
78
|
+
const parsedMessages = await getMpcRelayMessages({
|
|
79
|
+
serverUrl: this.serverURL,
|
|
80
|
+
localPartyId: this.localPartyId,
|
|
81
|
+
sessionId: this.sessionId,
|
|
82
|
+
messageId: '',
|
|
83
|
+
});
|
|
84
|
+
if (parsedMessages.length === 0) {
|
|
85
|
+
await sleep(100);
|
|
86
|
+
return this.processInbound(session, start);
|
|
87
|
+
}
|
|
88
|
+
for (const msg of parsedMessages) {
|
|
89
|
+
const cacheKey = `${msg.session_id}-${msg.from}-${msg.hash}`;
|
|
90
|
+
if (this.cache[cacheKey]) {
|
|
91
|
+
continue;
|
|
92
|
+
}
|
|
93
|
+
const decryptedMessage = fromMpcServerMessage(msg.body, this.hexEncryptionKey);
|
|
94
|
+
const isFinish = session.inputMessage(decryptedMessage);
|
|
95
|
+
if (isFinish) {
|
|
96
|
+
await sleep(1000);
|
|
97
|
+
this.isKeygenComplete = true;
|
|
98
|
+
return true;
|
|
99
|
+
}
|
|
100
|
+
this.cache[cacheKey] = '';
|
|
101
|
+
await deleteMpcRelayMessage({
|
|
102
|
+
serverUrl: this.serverURL,
|
|
103
|
+
localPartyId: this.localPartyId,
|
|
104
|
+
sessionId: this.sessionId,
|
|
105
|
+
messageHash: msg.hash,
|
|
106
|
+
messageId: '',
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
await sleep(100);
|
|
110
|
+
return this.processInbound(session, start);
|
|
111
|
+
}
|
|
112
|
+
catch (error) {
|
|
113
|
+
console.error('MLDSA processInbound error:', error);
|
|
114
|
+
await sleep(100);
|
|
115
|
+
return this.processInbound(session, start);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
async startKeygen(attempt) {
|
|
119
|
+
this.isKeygenComplete = false;
|
|
120
|
+
this.cache = {};
|
|
121
|
+
this.sequenceNo = 0;
|
|
122
|
+
try {
|
|
123
|
+
if (this.isInitiateDevice && attempt === 0) {
|
|
124
|
+
const threshold = getKeygenThreshold(this.keygenCommittee.length);
|
|
125
|
+
this.setupMessage = KeygenSession.setup(mldsaLevel, undefined, threshold, this.keygenCommittee);
|
|
126
|
+
const encryptedSetupMsg = toMpcServerMessage(this.setupMessage, this.hexEncryptionKey);
|
|
127
|
+
await uploadMpcSetupMessage({
|
|
128
|
+
serverUrl: this.serverURL,
|
|
129
|
+
message: encryptedSetupMsg,
|
|
130
|
+
sessionId: this.sessionId,
|
|
131
|
+
messageId: '',
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
const encodedEncryptedSetupMsg = await waitForSetupMessage({
|
|
136
|
+
serverUrl: this.serverURL,
|
|
137
|
+
sessionId: this.sessionId,
|
|
138
|
+
messageId: '',
|
|
139
|
+
});
|
|
140
|
+
this.setupMessage = fromMpcServerMessage(encodedEncryptedSetupMsg, this.hexEncryptionKey);
|
|
141
|
+
}
|
|
142
|
+
const session = new KeygenSession(this.setupMessage, this.localPartyId);
|
|
143
|
+
const start = Date.now();
|
|
144
|
+
const outbound = this.processOutbound(session);
|
|
145
|
+
const inbound = this.processInbound(session, start);
|
|
146
|
+
const [, inboundResult] = await Promise.all([outbound, inbound]);
|
|
147
|
+
if (inboundResult) {
|
|
148
|
+
const keyShare = session.finish();
|
|
149
|
+
return {
|
|
150
|
+
keyshare: base64Encode(keyShare.toBytes()),
|
|
151
|
+
publicKey: Buffer.from(keyShare.publicKey()).toString('hex'),
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
throw new Error('MLDSA keygen failed');
|
|
155
|
+
}
|
|
156
|
+
catch (error) {
|
|
157
|
+
if (error instanceof Error) {
|
|
158
|
+
console.error('MLDSA keygen error:', error.message);
|
|
159
|
+
}
|
|
160
|
+
throw error;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
async startKeygenWithRetry() {
|
|
164
|
+
await initializeMldsaLib();
|
|
165
|
+
for (let i = 0; i < 3; i++) {
|
|
166
|
+
try {
|
|
167
|
+
return await this.startKeygen(i);
|
|
168
|
+
}
|
|
169
|
+
catch (error) {
|
|
170
|
+
console.error(`MLDSA keygen attempt ${i} failed:`, error);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
throw new Error('MLDSA keygen failed after 3 attempts');
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
//# sourceMappingURL=mldsaKeygen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mldsaKeygen.js","sourceRoot":"","sources":["../../../../../packages/core/mpc/mldsa/mldsaKeygen.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export type MldsaKeysignResult = {
|
|
2
|
+
msg: string;
|
|
3
|
+
signature: string;
|
|
4
|
+
};
|
|
5
|
+
export declare class MldsaKeysign {
|
|
6
|
+
private readonly keysignCommittee;
|
|
7
|
+
private readonly serverURL;
|
|
8
|
+
private readonly sessionId;
|
|
9
|
+
private readonly localPartyId;
|
|
10
|
+
private readonly messagesToSign;
|
|
11
|
+
private readonly keyShareBase64;
|
|
12
|
+
private readonly hexEncryptionKey;
|
|
13
|
+
private readonly chainPath;
|
|
14
|
+
private readonly isInitiatingDevice;
|
|
15
|
+
private readonly timeoutMs;
|
|
16
|
+
private isKeysignComplete;
|
|
17
|
+
private sequenceNo;
|
|
18
|
+
private cache;
|
|
19
|
+
constructor(input: {
|
|
20
|
+
keysignCommittee: string[];
|
|
21
|
+
serverURL: string;
|
|
22
|
+
sessionId: string;
|
|
23
|
+
localPartyId: string;
|
|
24
|
+
messagesToSign: string[];
|
|
25
|
+
keyShareBase64: string;
|
|
26
|
+
hexEncryptionKey: string;
|
|
27
|
+
chainPath: string;
|
|
28
|
+
isInitiatingDevice: boolean;
|
|
29
|
+
timeoutMs?: number;
|
|
30
|
+
});
|
|
31
|
+
private processOutbound;
|
|
32
|
+
private processInbound;
|
|
33
|
+
private signMessage;
|
|
34
|
+
startKeysign(): Promise<MldsaKeysignResult[]>;
|
|
35
|
+
startKeysignWithRetry(maxRetries?: number): Promise<MldsaKeysignResult[]>;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=mldsaKeysign.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mldsaKeysign.d.ts","sourceRoot":"","sources":["../../../../../packages/core/mpc/mldsa/mldsaKeysign.ts"],"names":[],"mappings":"AAeA,MAAM,MAAM,kBAAkB,GAAG;IAC/B,GAAG,EAAE,MAAM,CAAA;IACX,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAU;IAC3C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAQ;IACrC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAU;IACzC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAQ;IACvC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAQ;IACzC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAS;IAC5C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAElC,OAAO,CAAC,iBAAiB,CAAiB;IAC1C,OAAO,CAAC,UAAU,CAAY;IAC9B,OAAO,CAAC,KAAK,CAA6B;gBAE9B,KAAK,EAAE;QACjB,gBAAgB,EAAE,MAAM,EAAE,CAAA;QAC1B,SAAS,EAAE,MAAM,CAAA;QACjB,SAAS,EAAE,MAAM,CAAA;QACjB,YAAY,EAAE,MAAM,CAAA;QACpB,cAAc,EAAE,MAAM,EAAE,CAAA;QACxB,cAAc,EAAE,MAAM,CAAA;QACtB,gBAAgB,EAAE,MAAM,CAAA;QACxB,SAAS,EAAE,MAAM,CAAA;QACjB,kBAAkB,EAAE,OAAO,CAAA;QAC3B,SAAS,CAAC,EAAE,MAAM,CAAA;KACnB;YAaa,eAAe;YA0Cf,cAAc;YA4Dd,WAAW;IA6DZ,YAAY,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAW7C,qBAAqB,CAChC,UAAU,SAAI,GACb,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAYjC"}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import { Keyshare, SignSession } from '@vultisig/lib-mldsa/vs_wasm';
|
|
2
|
+
import { base64Encode } from '@vultisig/lib-utils/base64Encode';
|
|
3
|
+
import { getMessageHash } from '../getMessageHash.js';
|
|
4
|
+
import { deleteMpcRelayMessage } from '../message/relay/delete.js';
|
|
5
|
+
import { getMpcRelayMessages } from '../message/relay/get.js';
|
|
6
|
+
import { sendMpcRelayMessage } from '../message/relay/send.js';
|
|
7
|
+
import { fromMpcServerMessage, toMpcServerMessage } from '../message/server.js';
|
|
8
|
+
import { waitForSetupMessage } from '../message/setup/get.js';
|
|
9
|
+
import { uploadMpcSetupMessage } from '../message/setup/upload.js';
|
|
10
|
+
import { sleep } from '@vultisig/lib-utils/sleep';
|
|
11
|
+
import { initializeMldsaLib } from './initializeMldsa.js';
|
|
12
|
+
const mldsaLevel = 44;
|
|
13
|
+
export class MldsaKeysign {
|
|
14
|
+
keysignCommittee;
|
|
15
|
+
serverURL;
|
|
16
|
+
sessionId;
|
|
17
|
+
localPartyId;
|
|
18
|
+
messagesToSign;
|
|
19
|
+
keyShareBase64;
|
|
20
|
+
hexEncryptionKey;
|
|
21
|
+
chainPath;
|
|
22
|
+
isInitiatingDevice;
|
|
23
|
+
timeoutMs;
|
|
24
|
+
isKeysignComplete = false;
|
|
25
|
+
sequenceNo = 0;
|
|
26
|
+
cache = {};
|
|
27
|
+
constructor(input) {
|
|
28
|
+
this.keysignCommittee = input.keysignCommittee;
|
|
29
|
+
this.serverURL = input.serverURL;
|
|
30
|
+
this.sessionId = input.sessionId;
|
|
31
|
+
this.localPartyId = input.localPartyId;
|
|
32
|
+
this.messagesToSign = input.messagesToSign;
|
|
33
|
+
this.keyShareBase64 = input.keyShareBase64;
|
|
34
|
+
this.hexEncryptionKey = input.hexEncryptionKey;
|
|
35
|
+
this.chainPath = input.chainPath;
|
|
36
|
+
this.isInitiatingDevice = input.isInitiatingDevice;
|
|
37
|
+
this.timeoutMs = input.timeoutMs ?? 60000;
|
|
38
|
+
}
|
|
39
|
+
async processOutbound(session, messageId) {
|
|
40
|
+
try {
|
|
41
|
+
const message = session.outputMessage();
|
|
42
|
+
if (message === undefined) {
|
|
43
|
+
if (this.isKeysignComplete) {
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
await sleep(100);
|
|
47
|
+
return this.processOutbound(session, messageId);
|
|
48
|
+
}
|
|
49
|
+
const body = toMpcServerMessage(message.body, this.hexEncryptionKey);
|
|
50
|
+
message.receivers.forEach(receiver => {
|
|
51
|
+
sendMpcRelayMessage({
|
|
52
|
+
serverUrl: this.serverURL,
|
|
53
|
+
sessionId: this.sessionId,
|
|
54
|
+
message: {
|
|
55
|
+
session_id: this.sessionId,
|
|
56
|
+
from: this.localPartyId,
|
|
57
|
+
to: [receiver],
|
|
58
|
+
body,
|
|
59
|
+
hash: getMessageHash(base64Encode(message.body)),
|
|
60
|
+
sequence_no: this.sequenceNo,
|
|
61
|
+
},
|
|
62
|
+
messageId,
|
|
63
|
+
});
|
|
64
|
+
this.sequenceNo++;
|
|
65
|
+
});
|
|
66
|
+
await sleep(100);
|
|
67
|
+
return this.processOutbound(session, messageId);
|
|
68
|
+
}
|
|
69
|
+
catch (error) {
|
|
70
|
+
console.error('MLDSA keysign processOutbound error:', error);
|
|
71
|
+
await sleep(100);
|
|
72
|
+
return this.processOutbound(session, messageId);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
async processInbound(session, start, messageId) {
|
|
76
|
+
try {
|
|
77
|
+
const elapsed = Date.now() - start;
|
|
78
|
+
if (elapsed > this.timeoutMs * 2) {
|
|
79
|
+
this.isKeysignComplete = true;
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
const parsedMessages = await getMpcRelayMessages({
|
|
83
|
+
serverUrl: this.serverURL,
|
|
84
|
+
localPartyId: this.localPartyId,
|
|
85
|
+
sessionId: this.sessionId,
|
|
86
|
+
messageId,
|
|
87
|
+
});
|
|
88
|
+
if (parsedMessages.length === 0) {
|
|
89
|
+
await sleep(100);
|
|
90
|
+
return this.processInbound(session, start, messageId);
|
|
91
|
+
}
|
|
92
|
+
for (const msg of parsedMessages) {
|
|
93
|
+
const cacheKey = `${msg.session_id}-${msg.from}-${msg.hash}`;
|
|
94
|
+
if (this.cache[cacheKey]) {
|
|
95
|
+
continue;
|
|
96
|
+
}
|
|
97
|
+
const decryptedMessage = fromMpcServerMessage(msg.body, this.hexEncryptionKey);
|
|
98
|
+
const isFinish = session.inputMessage(decryptedMessage);
|
|
99
|
+
if (isFinish) {
|
|
100
|
+
await sleep(1000);
|
|
101
|
+
this.isKeysignComplete = true;
|
|
102
|
+
return true;
|
|
103
|
+
}
|
|
104
|
+
this.cache[cacheKey] = '';
|
|
105
|
+
await deleteMpcRelayMessage({
|
|
106
|
+
serverUrl: this.serverURL,
|
|
107
|
+
localPartyId: this.localPartyId,
|
|
108
|
+
sessionId: this.sessionId,
|
|
109
|
+
messageHash: msg.hash,
|
|
110
|
+
messageId,
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
await sleep(100);
|
|
114
|
+
return this.processInbound(session, start, messageId);
|
|
115
|
+
}
|
|
116
|
+
catch (error) {
|
|
117
|
+
console.error('MLDSA keysign processInbound error:', error);
|
|
118
|
+
await sleep(100);
|
|
119
|
+
return this.processInbound(session, start, messageId);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
async signMessage(messageHex) {
|
|
123
|
+
this.isKeysignComplete = false;
|
|
124
|
+
this.cache = {};
|
|
125
|
+
this.sequenceNo = 0;
|
|
126
|
+
const keyShare = Keyshare.fromBytes(Buffer.from(this.keyShareBase64, 'base64'));
|
|
127
|
+
const keyId = keyShare.keyId();
|
|
128
|
+
const messageHash = Buffer.from(messageHex, 'hex');
|
|
129
|
+
const messageId = getMessageHash(messageHex);
|
|
130
|
+
let setupMessage;
|
|
131
|
+
if (this.isInitiatingDevice) {
|
|
132
|
+
setupMessage = SignSession.setup(mldsaLevel, keyId, this.chainPath, messageHash, this.keysignCommittee);
|
|
133
|
+
const encryptedSetupMsg = toMpcServerMessage(setupMessage, this.hexEncryptionKey);
|
|
134
|
+
await uploadMpcSetupMessage({
|
|
135
|
+
serverUrl: this.serverURL,
|
|
136
|
+
message: encryptedSetupMsg,
|
|
137
|
+
sessionId: this.sessionId,
|
|
138
|
+
messageId,
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
const encodedEncryptedSetupMsg = await waitForSetupMessage({
|
|
143
|
+
serverUrl: this.serverURL,
|
|
144
|
+
sessionId: this.sessionId,
|
|
145
|
+
messageId,
|
|
146
|
+
});
|
|
147
|
+
setupMessage = fromMpcServerMessage(encodedEncryptedSetupMsg, this.hexEncryptionKey);
|
|
148
|
+
}
|
|
149
|
+
const session = new SignSession(setupMessage, this.localPartyId, keyShare);
|
|
150
|
+
const start = Date.now();
|
|
151
|
+
const outbound = this.processOutbound(session, messageId);
|
|
152
|
+
const inbound = this.processInbound(session, start, messageId);
|
|
153
|
+
const [, inboundResult] = await Promise.all([outbound, inbound]);
|
|
154
|
+
if (inboundResult) {
|
|
155
|
+
const signature = session.finish();
|
|
156
|
+
return {
|
|
157
|
+
msg: messageHex,
|
|
158
|
+
signature: Buffer.from(signature).toString('hex'),
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
throw new Error(`MLDSA keysign failed for message: ${messageHex}`);
|
|
162
|
+
}
|
|
163
|
+
async startKeysign() {
|
|
164
|
+
await initializeMldsaLib();
|
|
165
|
+
const results = [];
|
|
166
|
+
for (const msg of this.messagesToSign) {
|
|
167
|
+
const result = await this.signMessage(msg);
|
|
168
|
+
results.push(result);
|
|
169
|
+
}
|
|
170
|
+
return results;
|
|
171
|
+
}
|
|
172
|
+
async startKeysignWithRetry(maxRetries = 3) {
|
|
173
|
+
await initializeMldsaLib();
|
|
174
|
+
for (let i = 0; i < maxRetries; i++) {
|
|
175
|
+
try {
|
|
176
|
+
return await this.startKeysign();
|
|
177
|
+
}
|
|
178
|
+
catch (error) {
|
|
179
|
+
console.error(`MLDSA keysign attempt ${i} failed:`, error);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
throw new Error(`MLDSA keysign failed after ${maxRetries} attempts`);
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
//# sourceMappingURL=mldsaKeysign.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mldsaKeysign.js","sourceRoot":"","sources":["../../../../../packages/core/mpc/mldsa/mldsaKeysign.ts"],"names":[],"mappings":"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"}
|
package/dist/mpcLib.d.ts
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export type MpcLib = 'GG20' | 'DKLS';
|
|
2
|
+
/** MpcLib plus KeyImport; used in keysign payloads (protobuf uses string on wire). */
|
|
3
|
+
export type KeysignLibType = MpcLib | 'KeyImport';
|
|
4
|
+
export declare const mpcLibOptions: readonly ["GG20", "DKLS"];
|
|
5
|
+
export declare const defaultMpcLib: MpcLib;
|
|
6
|
+
//# sourceMappingURL=mpcLib.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mpcLib.d.ts","sourceRoot":"","sources":["../../../../packages/core/mpc/mpcLib.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;AAEpC,sFAAsF;AACtF,MAAM,MAAM,cAAc,GAAG,MAAM,GAAG,WAAW,CAAA;AAEjD,eAAO,MAAM,aAAa,2BAA4B,CAAA;AAEtD,eAAO,MAAM,aAAa,EAAE,MAAe,CAAA"}
|
package/dist/mpcLib.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mpcLib.js","sourceRoot":"","sources":["../../../../packages/core/mpc/mpcLib.ts"],"names":[],"mappings":"AAKA,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,MAAM,EAAE,MAAM,CAAU,CAAA;AAEtD,MAAM,CAAC,MAAM,aAAa,GAAW,MAAM,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
type CombineReshareCommitteeInput = {
|
|
2
|
+
keygenCommittee: string[];
|
|
3
|
+
oldKeygenCommittee: string[];
|
|
4
|
+
};
|
|
5
|
+
export declare const combineReshareCommittee: ({ keygenCommittee, oldKeygenCommittee, }: CombineReshareCommitteeInput) => {
|
|
6
|
+
allCommittee: string[];
|
|
7
|
+
newCommitteeIdx: number[];
|
|
8
|
+
oldCommitteeIdx: number[];
|
|
9
|
+
};
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=reshareCommittee.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reshareCommittee.d.ts","sourceRoot":"","sources":["../../../../packages/core/mpc/reshareCommittee.ts"],"names":[],"mappings":"AAAA,KAAK,4BAA4B,GAAG;IAClC,eAAe,EAAE,MAAM,EAAE,CAAA;IACzB,kBAAkB,EAAE,MAAM,EAAE,CAAA;CAC7B,CAAA;AACD,eAAO,MAAM,uBAAuB,GAAI,0CAGrC,4BAA4B;;;;CAqB9B,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export const combineReshareCommittee = ({ keygenCommittee, oldKeygenCommittee, }) => {
|
|
2
|
+
const allCommittee = Array.from(new Set([...keygenCommittee, ...oldKeygenCommittee]));
|
|
3
|
+
const newCommitteeIdx = [];
|
|
4
|
+
const oldCommitteeIdx = [];
|
|
5
|
+
for (const [idx, key] of allCommittee.entries()) {
|
|
6
|
+
if (oldKeygenCommittee.includes(key)) {
|
|
7
|
+
oldCommitteeIdx.push(idx);
|
|
8
|
+
}
|
|
9
|
+
if (keygenCommittee.includes(key)) {
|
|
10
|
+
newCommitteeIdx.push(idx);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
return {
|
|
14
|
+
allCommittee,
|
|
15
|
+
newCommitteeIdx,
|
|
16
|
+
oldCommitteeIdx,
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=reshareCommittee.js.map
|