@bitgo-beta/utxo-core 1.8.1-beta.61 → 1.8.1-beta.611
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/dist/cjs/src/Output.d.ts.map +1 -0
- package/dist/cjs/src/Output.js +60 -0
- package/dist/cjs/src/bip322/index.d.ts +5 -0
- package/dist/cjs/src/bip322/index.d.ts.map +1 -0
- package/dist/cjs/src/bip322/index.js +21 -0
- package/dist/cjs/src/bip322/toSign.d.ts +25 -0
- package/dist/cjs/src/bip322/toSign.d.ts.map +1 -0
- package/dist/cjs/src/bip322/toSign.js +126 -0
- package/dist/cjs/src/bip322/toSpend.d.ts +22 -0
- package/dist/cjs/src/bip322/toSpend.d.ts.map +1 -0
- package/dist/cjs/src/bip322/toSpend.js +72 -0
- package/dist/cjs/src/bip322/utils.d.ts +18 -0
- package/dist/cjs/src/bip322/utils.d.ts.map +1 -0
- package/dist/cjs/src/bip322/utils.js +115 -0
- package/dist/cjs/src/bip322/verify.d.ts +12 -0
- package/dist/cjs/src/bip322/verify.d.ts.map +1 -0
- package/dist/cjs/src/bip322/verify.js +115 -0
- package/dist/cjs/src/bip32utils.d.ts +16 -0
- package/dist/cjs/src/bip32utils.d.ts.map +1 -0
- package/dist/cjs/src/bip32utils.js +71 -0
- package/dist/cjs/src/bip65/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/bip65/index.js +1 -1
- package/dist/cjs/src/bip65/locktime.d.ts.map +1 -0
- package/dist/cjs/src/bip65/locktime.js +37 -0
- package/dist/{src → cjs/src}/descriptor/DescriptorMap.d.ts +1 -1
- package/dist/cjs/src/descriptor/DescriptorMap.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/DescriptorMap.js +9 -0
- package/dist/{src → cjs/src}/descriptor/Output.d.ts +1 -1
- package/dist/cjs/src/descriptor/Output.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/Output.js +41 -0
- package/dist/{src → cjs/src}/descriptor/VirtualSize.d.ts +1 -1
- package/dist/cjs/src/descriptor/VirtualSize.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/VirtualSize.js +100 -0
- package/dist/{src → cjs/src}/descriptor/address.d.ts +1 -1
- package/dist/cjs/src/descriptor/address.d.ts.map +1 -0
- package/dist/{src → cjs/src}/descriptor/address.js +1 -1
- package/dist/{src → cjs/src}/descriptor/derive.d.ts +1 -1
- package/dist/cjs/src/descriptor/derive.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/derive.js +45 -0
- package/dist/{src → cjs/src}/descriptor/fromFixedScriptWallet.d.ts +1 -1
- package/dist/cjs/src/descriptor/fromFixedScriptWallet.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/fromFixedScriptWallet.js +88 -0
- package/dist/{src → cjs/src}/descriptor/index.d.ts +1 -0
- package/dist/cjs/src/descriptor/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/descriptor/index.js +2 -1
- package/dist/cjs/src/descriptor/parse/PatternMatcher.d.ts +14 -0
- package/dist/cjs/src/descriptor/parse/PatternMatcher.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/parse/PatternMatcher.js +60 -0
- package/dist/{src → cjs/src}/descriptor/psbt/assertSatisfiable.d.ts +1 -1
- package/dist/cjs/src/descriptor/psbt/assertSatisfiable.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/psbt/assertSatisfiable.js +74 -0
- package/dist/{src → cjs/src}/descriptor/psbt/createPsbt.d.ts +4 -0
- package/dist/cjs/src/descriptor/psbt/createPsbt.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/psbt/createPsbt.js +107 -0
- package/dist/{src → cjs/src}/descriptor/psbt/findDescriptors.d.ts +1 -1
- package/dist/cjs/src/descriptor/psbt/findDescriptors.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/psbt/findDescriptors.js +98 -0
- package/dist/cjs/src/descriptor/psbt/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/descriptor/psbt/index.js +1 -1
- package/dist/{src → cjs/src}/descriptor/psbt/parse.d.ts +1 -1
- package/dist/cjs/src/descriptor/psbt/parse.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/psbt/parse.js +87 -0
- package/dist/{src → cjs/src}/descriptor/psbt/sign.d.ts +4 -4
- package/dist/cjs/src/descriptor/psbt/sign.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/psbt/sign.js +42 -0
- package/dist/{src → cjs/src}/descriptor/psbt/wrap.d.ts +1 -1
- package/dist/cjs/src/descriptor/psbt/wrap.d.ts.map +1 -0
- package/dist/cjs/src/descriptor/psbt/wrap.js +76 -0
- package/dist/cjs/src/dustThreshold.d.ts.map +1 -0
- package/dist/cjs/src/dustThreshold.js +134 -0
- package/dist/{src → cjs/src}/index.d.ts +1 -0
- package/dist/cjs/src/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/index.js +3 -2
- package/dist/cjs/src/paygo/attestation.d.ts +11 -0
- package/dist/cjs/src/paygo/attestation.d.ts.map +1 -0
- package/dist/cjs/src/paygo/attestation.js +58 -0
- package/dist/cjs/src/paygo/index.d.ts +3 -0
- package/dist/cjs/src/paygo/index.d.ts.map +1 -0
- package/dist/cjs/src/paygo/index.js +19 -0
- package/dist/{src/paygo/ExtractAddressPayGoAttestation.d.ts → cjs/src/paygo/parsePayGoAttestation.d.ts} +8 -3
- package/dist/cjs/src/paygo/parsePayGoAttestation.d.ts.map +1 -0
- package/dist/cjs/src/paygo/parsePayGoAttestation.js +50 -0
- package/dist/cjs/src/paygo/psbt/Errors.d.ts +22 -0
- package/dist/cjs/src/paygo/psbt/Errors.d.ts.map +1 -0
- package/dist/cjs/src/paygo/psbt/Errors.js +44 -0
- package/dist/cjs/src/paygo/psbt/index.d.ts +2 -0
- package/dist/cjs/src/paygo/psbt/index.d.ts.map +1 -0
- package/dist/{src/paygo → cjs/src/paygo/psbt}/index.js +2 -2
- package/dist/cjs/src/paygo/psbt/payGoAddressProof.d.ts +29 -0
- package/dist/cjs/src/paygo/psbt/payGoAddressProof.d.ts.map +1 -0
- package/dist/cjs/src/paygo/psbt/payGoAddressProof.js +124 -0
- package/dist/{src → cjs/src}/testutil/descriptor/descriptors.d.ts +4 -1
- package/dist/cjs/src/testutil/descriptor/descriptors.d.ts.map +1 -0
- package/dist/cjs/src/testutil/descriptor/descriptors.js +162 -0
- package/dist/cjs/src/testutil/descriptor/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/testutil/descriptor/index.js +1 -1
- package/dist/{src → cjs/src}/testutil/descriptor/mock.utils.d.ts +3 -1
- package/dist/cjs/src/testutil/descriptor/mock.utils.d.ts.map +1 -0
- package/dist/cjs/src/testutil/descriptor/mock.utils.js +92 -0
- package/dist/cjs/src/testutil/descriptor/psbt.utils.d.ts.map +1 -0
- package/dist/cjs/src/testutil/descriptor/psbt.utils.js +21 -0
- package/dist/cjs/src/testutil/fixtures.utils.d.ts.map +1 -0
- package/dist/cjs/src/testutil/fixtures.utils.js +127 -0
- package/dist/{src → cjs/src}/testutil/generatePayGoAttestationProof.utils.d.ts +1 -1
- package/dist/cjs/src/testutil/generatePayGoAttestationProof.utils.d.ts.map +1 -0
- package/dist/cjs/src/testutil/generatePayGoAttestationProof.utils.js +38 -0
- package/dist/{src → cjs/src}/testutil/index.d.ts +1 -0
- package/dist/cjs/src/testutil/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/testutil/index.js +2 -1
- package/dist/{src → cjs/src}/testutil/key.utils.d.ts +1 -1
- package/dist/cjs/src/testutil/key.utils.d.ts.map +1 -0
- package/dist/cjs/src/testutil/key.utils.js +60 -0
- package/dist/cjs/src/testutil/toPlainObject.utils.d.ts.map +1 -0
- package/dist/cjs/src/testutil/toPlainObject.utils.js +89 -0
- package/dist/cjs/src/testutil/trimMessagePrefix.d.ts +11 -0
- package/dist/cjs/src/testutil/trimMessagePrefix.d.ts.map +1 -0
- package/dist/cjs/src/testutil/trimMessagePrefix.js +60 -0
- package/dist/cjs/src/xOnlyPubkey.d.ts.map +1 -0
- package/dist/cjs/src/xOnlyPubkey.js +18 -0
- package/dist/cjs/test/Output.d.ts +2 -0
- package/dist/cjs/test/Output.d.ts.map +1 -0
- package/dist/cjs/test/Output.js +70 -0
- package/dist/cjs/test/bip322/bip322.utils.d.ts +7 -0
- package/dist/cjs/test/bip322/bip322.utils.d.ts.map +1 -0
- package/dist/cjs/test/bip322/bip322.utils.js +16 -0
- package/dist/cjs/test/bip322/toSign.d.ts +2 -0
- package/dist/cjs/test/bip322/toSign.d.ts.map +1 -0
- package/dist/cjs/test/bip322/toSign.js +133 -0
- package/dist/cjs/test/bip322/toSpend.d.ts +2 -0
- package/dist/cjs/test/bip322/toSpend.d.ts.map +1 -0
- package/dist/cjs/test/bip322/toSpend.js +70 -0
- package/dist/cjs/test/bip322/utils.d.ts +2 -0
- package/dist/cjs/test/bip322/utils.d.ts.map +1 -0
- package/dist/cjs/test/bip322/utils.js +79 -0
- package/dist/cjs/test/bip322/verify.d.ts +2 -0
- package/dist/cjs/test/bip322/verify.d.ts.map +1 -0
- package/dist/cjs/test/bip322/verify.js +293 -0
- package/dist/cjs/test/bip32utils.d.ts +2 -0
- package/dist/cjs/test/bip32utils.d.ts.map +1 -0
- package/dist/cjs/test/bip32utils.js +62 -0
- package/dist/cjs/test/bip65/locktime.d.ts +2 -0
- package/dist/cjs/test/bip65/locktime.d.ts.map +1 -0
- package/dist/cjs/test/bip65/locktime.js +22 -0
- package/dist/cjs/test/descriptor/Output.d.ts +2 -0
- package/dist/cjs/test/descriptor/Output.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/Output.js +44 -0
- package/dist/cjs/test/descriptor/derive.d.ts +2 -0
- package/dist/cjs/test/descriptor/derive.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/derive.js +27 -0
- package/dist/cjs/test/descriptor/fromFixedScriptWallet.d.ts +2 -0
- package/dist/cjs/test/descriptor/fromFixedScriptWallet.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/fromFixedScriptWallet.js +145 -0
- package/dist/cjs/test/descriptor/parse/PatternMatcher.d.ts +2 -0
- package/dist/cjs/test/descriptor/parse/PatternMatcher.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/parse/PatternMatcher.js +120 -0
- package/dist/cjs/test/descriptor/psbt/VirtualSize.d.ts +2 -0
- package/dist/cjs/test/descriptor/psbt/VirtualSize.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/psbt/VirtualSize.js +71 -0
- package/dist/cjs/test/descriptor/psbt/assertSatisfiable.d.ts +2 -0
- package/dist/cjs/test/descriptor/psbt/assertSatisfiable.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/psbt/assertSatisfiable.js +56 -0
- package/dist/cjs/test/descriptor/psbt/findDescriptors.d.ts +2 -0
- package/dist/cjs/test/descriptor/psbt/findDescriptors.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/psbt/findDescriptors.js +70 -0
- package/dist/cjs/test/descriptor/psbt/psbt.d.ts +2 -0
- package/dist/cjs/test/descriptor/psbt/psbt.d.ts.map +1 -0
- package/dist/cjs/test/descriptor/psbt/psbt.js +211 -0
- package/dist/cjs/test/dustThreshold.d.ts +2 -0
- package/dist/cjs/test/dustThreshold.d.ts.map +1 -0
- package/dist/cjs/test/dustThreshold.js +110 -0
- package/dist/cjs/test/paygo/attestation.d.ts +2 -0
- package/dist/cjs/test/paygo/attestation.d.ts.map +1 -0
- package/dist/cjs/test/paygo/attestation.js +23 -0
- package/dist/cjs/test/paygo/parsePayGoAttestation.d.ts +2 -0
- package/dist/cjs/test/paygo/parsePayGoAttestation.d.ts.map +1 -0
- package/dist/cjs/test/paygo/parsePayGoAttestation.js +75 -0
- package/dist/cjs/test/paygo/psbt/payGoAddressProof.d.ts +9 -0
- package/dist/cjs/test/paygo/psbt/payGoAddressProof.d.ts.map +1 -0
- package/dist/cjs/test/paygo/psbt/payGoAddressProof.js +163 -0
- package/dist/cjs/test/xOnlyPubkey.d.ts +2 -0
- package/dist/cjs/test/xOnlyPubkey.d.ts.map +1 -0
- package/dist/cjs/test/xOnlyPubkey.js +18 -0
- package/dist/cjs/tsconfig.tsbuildinfo +1 -0
- package/dist/esm/Output.d.ts +43 -0
- package/dist/esm/Output.js +53 -0
- package/dist/esm/bip322/index.d.ts +5 -0
- package/dist/esm/bip322/index.d.ts.map +1 -0
- package/dist/esm/bip322/index.js +5 -0
- package/dist/esm/bip322/toSign.d.ts +25 -0
- package/dist/esm/bip322/toSign.d.ts.map +1 -0
- package/dist/esm/bip322/toSign.js +120 -0
- package/dist/esm/bip322/toSpend.d.ts +22 -0
- package/dist/esm/bip322/toSpend.d.ts.map +1 -0
- package/dist/esm/bip322/toSpend.js +66 -0
- package/dist/esm/bip322/utils.d.ts +18 -0
- package/dist/esm/bip322/utils.d.ts.map +1 -0
- package/dist/esm/bip322/utils.js +77 -0
- package/dist/esm/bip322/verify.d.ts +12 -0
- package/dist/esm/bip322/verify.d.ts.map +1 -0
- package/dist/esm/bip322/verify.js +76 -0
- package/dist/esm/bip32utils.d.ts +16 -0
- package/dist/esm/bip32utils.d.ts.map +1 -0
- package/dist/esm/bip32utils.js +34 -0
- package/dist/esm/bip65/index.d.ts +2 -0
- package/dist/esm/bip65/index.js +2 -0
- package/dist/esm/bip65/locktime.d.ts +8 -0
- package/dist/esm/bip65/locktime.js +34 -0
- package/dist/esm/descriptor/DescriptorMap.d.ts +9 -0
- package/dist/{src → esm}/descriptor/DescriptorMap.d.ts.map +1 -1
- package/dist/esm/descriptor/DescriptorMap.js +6 -0
- package/dist/esm/descriptor/Output.d.ts +23 -0
- package/dist/{src → esm}/descriptor/Output.d.ts.map +1 -1
- package/dist/esm/descriptor/Output.js +32 -0
- package/dist/esm/descriptor/VirtualSize.d.ts +23 -0
- package/dist/{src → esm}/descriptor/VirtualSize.d.ts.map +1 -1
- package/dist/esm/descriptor/VirtualSize.js +94 -0
- package/dist/esm/descriptor/address.d.ts +5 -0
- package/dist/{src → esm}/descriptor/address.d.ts.map +1 -1
- package/dist/esm/descriptor/address.js +11 -0
- package/dist/esm/descriptor/derive.d.ts +13 -0
- package/dist/{src → esm}/descriptor/derive.d.ts.map +1 -1
- package/dist/esm/descriptor/derive.js +38 -0
- package/dist/esm/descriptor/fromFixedScriptWallet.d.ts +16 -0
- package/dist/{src → esm}/descriptor/fromFixedScriptWallet.d.ts.map +1 -1
- package/dist/esm/descriptor/fromFixedScriptWallet.js +51 -0
- package/dist/esm/descriptor/index.d.ts +11 -0
- package/dist/{src → esm}/descriptor/index.d.ts.map +1 -1
- package/dist/esm/descriptor/index.js +11 -0
- package/dist/esm/descriptor/parse/PatternMatcher.d.ts +14 -0
- package/dist/esm/descriptor/parse/PatternMatcher.d.ts.map +1 -0
- package/dist/esm/descriptor/parse/PatternMatcher.js +56 -0
- package/dist/esm/descriptor/psbt/assertSatisfiable.d.ts +20 -0
- package/dist/{src → esm}/descriptor/psbt/assertSatisfiable.d.ts.map +1 -1
- package/dist/esm/descriptor/psbt/assertSatisfiable.js +69 -0
- package/dist/esm/descriptor/psbt/createPsbt.d.ts +23 -0
- package/dist/esm/descriptor/psbt/createPsbt.d.ts.map +1 -0
- package/dist/esm/descriptor/psbt/createPsbt.js +69 -0
- package/dist/esm/descriptor/psbt/findDescriptors.d.ts +26 -0
- package/dist/{src → esm}/descriptor/psbt/findDescriptors.d.ts.map +1 -1
- package/dist/esm/descriptor/psbt/findDescriptors.js +94 -0
- package/dist/esm/descriptor/psbt/index.d.ts +7 -0
- package/dist/esm/descriptor/psbt/index.js +7 -0
- package/dist/esm/descriptor/psbt/parse.d.ts +27 -0
- package/dist/{src → esm}/descriptor/psbt/parse.d.ts.map +1 -1
- package/dist/esm/descriptor/psbt/parse.js +51 -0
- package/dist/esm/descriptor/psbt/sign.d.ts +26 -0
- package/dist/esm/descriptor/psbt/sign.d.ts.map +1 -0
- package/dist/esm/descriptor/psbt/sign.js +34 -0
- package/dist/esm/descriptor/psbt/wrap.d.ts +12 -0
- package/dist/{src → esm}/descriptor/psbt/wrap.d.ts.map +1 -1
- package/dist/esm/descriptor/psbt/wrap.js +38 -0
- package/dist/esm/dustThreshold.d.ts +4 -0
- package/dist/esm/dustThreshold.js +97 -0
- package/dist/esm/index.d.ts +10 -0
- package/dist/{src → esm}/index.d.ts.map +1 -1
- package/dist/esm/index.js +10 -0
- package/dist/esm/paygo/attestation.d.ts +11 -0
- package/dist/esm/paygo/attestation.d.ts.map +1 -0
- package/dist/esm/paygo/attestation.js +18 -0
- package/dist/esm/paygo/index.d.ts +3 -0
- package/dist/esm/paygo/index.d.ts.map +1 -0
- package/dist/esm/paygo/index.js +3 -0
- package/dist/esm/paygo/parsePayGoAttestation.d.ts +16 -0
- package/dist/esm/paygo/parsePayGoAttestation.d.ts.map +1 -0
- package/dist/esm/paygo/parsePayGoAttestation.js +43 -0
- package/dist/esm/paygo/psbt/Errors.d.ts +22 -0
- package/dist/esm/paygo/psbt/Errors.d.ts.map +1 -0
- package/dist/esm/paygo/psbt/Errors.js +35 -0
- package/dist/esm/paygo/psbt/index.d.ts +2 -0
- package/dist/esm/paygo/psbt/index.d.ts.map +1 -0
- package/dist/esm/paygo/psbt/index.js +2 -0
- package/dist/esm/paygo/psbt/payGoAddressProof.d.ts +29 -0
- package/dist/esm/paygo/psbt/payGoAddressProof.d.ts.map +1 -0
- package/dist/esm/paygo/psbt/payGoAddressProof.js +85 -0
- package/dist/esm/testutil/descriptor/descriptors.d.ts +13 -0
- package/dist/esm/testutil/descriptor/descriptors.d.ts.map +1 -0
- package/dist/esm/testutil/descriptor/descriptors.js +150 -0
- package/dist/esm/testutil/descriptor/index.d.ts +4 -0
- package/dist/esm/testutil/descriptor/index.js +4 -0
- package/dist/esm/testutil/descriptor/mock.utils.d.ts +36 -0
- package/dist/esm/testutil/descriptor/mock.utils.d.ts.map +1 -0
- package/dist/esm/testutil/descriptor/mock.utils.js +53 -0
- package/dist/esm/testutil/descriptor/psbt.utils.d.ts +4 -0
- package/dist/{src → esm}/testutil/descriptor/psbt.utils.d.ts.map +1 -1
- package/dist/esm/testutil/descriptor/psbt.utils.js +17 -0
- package/dist/esm/testutil/fixtures.utils.d.ts +15 -0
- package/dist/{src → esm}/testutil/fixtures.utils.js +5 -42
- package/dist/esm/testutil/generatePayGoAttestationProof.utils.d.ts +12 -0
- package/dist/esm/testutil/generatePayGoAttestationProof.utils.d.ts.map +1 -0
- package/dist/esm/testutil/generatePayGoAttestationProof.utils.js +32 -0
- package/dist/esm/testutil/index.d.ts +6 -0
- package/dist/{src → esm}/testutil/index.d.ts.map +1 -1
- package/dist/esm/testutil/index.js +6 -0
- package/dist/esm/testutil/key.utils.d.ts +16 -0
- package/dist/{src → esm}/testutil/key.utils.d.ts.map +1 -1
- package/dist/esm/testutil/key.utils.js +22 -0
- package/dist/esm/testutil/toPlainObject.utils.d.ts +11 -0
- package/dist/{src → esm}/testutil/toPlainObject.utils.d.ts.map +1 -1
- package/dist/esm/testutil/toPlainObject.utils.js +85 -0
- package/dist/esm/testutil/trimMessagePrefix.d.ts +11 -0
- package/dist/esm/testutil/trimMessagePrefix.d.ts.map +1 -0
- package/dist/esm/testutil/trimMessagePrefix.js +24 -0
- package/dist/esm/xOnlyPubkey.d.ts +2 -0
- package/dist/esm/xOnlyPubkey.js +15 -0
- package/package.json +50 -25
- package/dist/src/Output.js +0 -60
- package/dist/src/bip32utils.d.ts +0 -16
- package/dist/src/bip32utils.d.ts.map +0 -1
- package/dist/src/bip32utils.js +0 -72
- package/dist/src/bip65/locktime.js +0 -37
- package/dist/src/descriptor/DescriptorMap.js +0 -9
- package/dist/src/descriptor/Output.js +0 -41
- package/dist/src/descriptor/VirtualSize.js +0 -100
- package/dist/src/descriptor/derive.js +0 -45
- package/dist/src/descriptor/fromFixedScriptWallet.js +0 -88
- package/dist/src/descriptor/psbt/assertSatisfiable.js +0 -74
- package/dist/src/descriptor/psbt/createPsbt.d.ts.map +0 -1
- package/dist/src/descriptor/psbt/createPsbt.js +0 -82
- package/dist/src/descriptor/psbt/findDescriptors.js +0 -98
- package/dist/src/descriptor/psbt/parse.js +0 -87
- package/dist/src/descriptor/psbt/sign.d.ts.map +0 -1
- package/dist/src/descriptor/psbt/sign.js +0 -42
- package/dist/src/descriptor/psbt/wrap.js +0 -76
- package/dist/src/dustThreshold.js +0 -134
- package/dist/src/paygo/ExtractAddressPayGoAttestation.d.ts.map +0 -1
- package/dist/src/paygo/ExtractAddressPayGoAttestation.js +0 -44
- package/dist/src/paygo/index.d.ts +0 -2
- package/dist/src/paygo/index.d.ts.map +0 -1
- package/dist/src/testutil/descriptor/descriptors.d.ts.map +0 -1
- package/dist/src/testutil/descriptor/descriptors.js +0 -125
- package/dist/src/testutil/descriptor/mock.utils.d.ts.map +0 -1
- package/dist/src/testutil/descriptor/mock.utils.js +0 -91
- package/dist/src/testutil/descriptor/psbt.utils.js +0 -20
- package/dist/src/testutil/generatePayGoAttestationProof.utils.d.ts.map +0 -1
- package/dist/src/testutil/generatePayGoAttestationProof.utils.js +0 -43
- package/dist/src/testutil/key.utils.js +0 -59
- package/dist/src/testutil/toPlainObject.utils.js +0 -75
- package/dist/src/xOnlyPubkey.js +0 -18
- /package/dist/{src → cjs/src}/Output.d.ts +0 -0
- /package/dist/{src → cjs/src}/bip65/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/bip65/locktime.d.ts +0 -0
- /package/dist/{src → cjs/src}/descriptor/psbt/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/dustThreshold.d.ts +0 -0
- /package/dist/{src → cjs/src}/testutil/descriptor/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/testutil/descriptor/psbt.utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/testutil/fixtures.utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/testutil/toPlainObject.utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/xOnlyPubkey.d.ts +0 -0
- /package/dist/{src → esm}/Output.d.ts.map +0 -0
- /package/dist/{src → esm}/bip65/index.d.ts.map +0 -0
- /package/dist/{src → esm}/bip65/locktime.d.ts.map +0 -0
- /package/dist/{src → esm}/descriptor/psbt/index.d.ts.map +0 -0
- /package/dist/{src → esm}/dustThreshold.d.ts.map +0 -0
- /package/dist/{src → esm}/testutil/descriptor/index.d.ts.map +0 -0
- /package/dist/{src → esm}/testutil/fixtures.utils.d.ts.map +0 -0
- /package/dist/{src → esm}/xOnlyPubkey.d.ts.map +0 -0
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toXOnlyPublicKey = toXOnlyPublicKey;
|
|
4
|
+
function toXOnlyPublicKey(b) {
|
|
5
|
+
if (b.length === 33) {
|
|
6
|
+
if (b[0] === 0x02 || b[0] === 0x03) {
|
|
7
|
+
return b.subarray(1);
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
throw new Error(`invalid pubkey leading byte ${b.subarray(0, 1).toString('hex')}`);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
if (b.length === 32) {
|
|
14
|
+
return b;
|
|
15
|
+
}
|
|
16
|
+
throw new Error(`invalid pubkey buffer length ${b.length}`);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieE9ubHlQdWJrZXkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMveE9ubHlQdWJrZXkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw0Q0FjQztBQWRELFNBQWdCLGdCQUFnQixDQUFDLENBQVM7SUFDeEMsSUFBSSxDQUFDLENBQUMsTUFBTSxLQUFLLEVBQUUsRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7WUFDbkMsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZCLENBQUM7YUFBTSxDQUFDO1lBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQywrQkFBK0IsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNyRixDQUFDO0lBQ0gsQ0FBQztJQUVELElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUNwQixPQUFPLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxNQUFNLElBQUksS0FBSyxDQUFDLGdDQUFnQyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztBQUM5RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIHRvWE9ubHlQdWJsaWNLZXkoYjogQnVmZmVyKTogQnVmZmVyIHtcbiAgaWYgKGIubGVuZ3RoID09PSAzMykge1xuICAgIGlmIChiWzBdID09PSAweDAyIHx8IGJbMF0gPT09IDB4MDMpIHtcbiAgICAgIHJldHVybiBiLnN1YmFycmF5KDEpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYGludmFsaWQgcHVia2V5IGxlYWRpbmcgYnl0ZSAke2Iuc3ViYXJyYXkoMCwgMSkudG9TdHJpbmcoJ2hleCcpfWApO1xuICAgIH1cbiAgfVxuXG4gIGlmIChiLmxlbmd0aCA9PT0gMzIpIHtcbiAgICByZXR1cm4gYjtcbiAgfVxuXG4gIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCBwdWJrZXkgYnVmZmVyIGxlbmd0aCAke2IubGVuZ3RofWApO1xufVxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Output.d.ts","sourceRoot":"","sources":["../../../test/Output.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const assert = __importStar(require("assert"));
|
|
37
|
+
const src_1 = require("../src");
|
|
38
|
+
describe('Output', function () {
|
|
39
|
+
const oBigInt = { value: 1n };
|
|
40
|
+
const oBigInt2 = { value: 2n };
|
|
41
|
+
const oMax = { value: 'max' };
|
|
42
|
+
it('getMaxOutput returns expected values', function () {
|
|
43
|
+
assert.strictEqual((0, src_1.getMaxOutput)([oBigInt]), undefined);
|
|
44
|
+
assert.strictEqual((0, src_1.getMaxOutput)([oBigInt, oBigInt]), undefined);
|
|
45
|
+
assert.strictEqual((0, src_1.getMaxOutput)([oBigInt, oMax]), oMax);
|
|
46
|
+
assert.throws(() => (0, src_1.getMaxOutput)([oMax, oMax]), /Multiple max outputs/);
|
|
47
|
+
});
|
|
48
|
+
it('isMaxOutput correctly identifies max outputs', function () {
|
|
49
|
+
assert.strictEqual((0, src_1.isMaxOutput)(oBigInt), false);
|
|
50
|
+
assert.strictEqual((0, src_1.isMaxOutput)(oMax), true);
|
|
51
|
+
});
|
|
52
|
+
it('getOutputSum calculates sum correctly', function () {
|
|
53
|
+
assert.strictEqual((0, src_1.getOutputSum)([]), 0n);
|
|
54
|
+
assert.strictEqual((0, src_1.getOutputSum)([oBigInt]), 1n);
|
|
55
|
+
assert.strictEqual((0, src_1.getOutputSum)([oBigInt, oBigInt2]), 3n);
|
|
56
|
+
});
|
|
57
|
+
it('getFixedOutputSum handles mixed outputs', function () {
|
|
58
|
+
assert.strictEqual((0, src_1.getFixedOutputSum)([]), 0n);
|
|
59
|
+
assert.strictEqual((0, src_1.getFixedOutputSum)([oBigInt]), 1n);
|
|
60
|
+
assert.strictEqual((0, src_1.getFixedOutputSum)([oBigInt, oMax]), 1n);
|
|
61
|
+
assert.strictEqual((0, src_1.getFixedOutputSum)([oBigInt, oBigInt2, oMax]), 3n);
|
|
62
|
+
});
|
|
63
|
+
it('toFixedOutputs converts max outputs correctly', function () {
|
|
64
|
+
const maxAmount = 10n;
|
|
65
|
+
assert.deepStrictEqual((0, src_1.toFixedOutputs)([oBigInt], { maxAmount }), [oBigInt]);
|
|
66
|
+
assert.deepStrictEqual((0, src_1.toFixedOutputs)([oMax], { maxAmount }), [{ ...oMax, value: maxAmount }]);
|
|
67
|
+
assert.throws(() => (0, src_1.toFixedOutputs)([oMax, oMax], { maxAmount }), /Multiple max outputs/);
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3V0cHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vdGVzdC9PdXRwdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBaUM7QUFFakMsZ0NBQW9HO0FBRXBHLFFBQVEsQ0FBQyxRQUFRLEVBQUU7SUFDakIsTUFBTSxPQUFPLEdBQUcsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDOUIsTUFBTSxRQUFRLEdBQUcsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDL0IsTUFBTSxJQUFJLEdBQUcsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFXLENBQUM7SUFFdkMsRUFBRSxDQUFDLHNDQUFzQyxFQUFFO1FBQ3pDLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSxrQkFBWSxFQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN2RCxNQUFNLENBQUMsV0FBVyxDQUFDLElBQUEsa0JBQVksRUFBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ2hFLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSxrQkFBWSxFQUFDLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDeEQsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFBLGtCQUFZLEVBQUMsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUMsRUFBRSxzQkFBc0IsQ0FBQyxDQUFDO0lBQzFFLENBQUMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLDhDQUE4QyxFQUFFO1FBQ2pELE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSxpQkFBVyxFQUFDLE9BQU8sQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2hELE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSxpQkFBVyxFQUFDLElBQUksQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlDLENBQUMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLHVDQUF1QyxFQUFFO1FBQzFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSxrQkFBWSxFQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3pDLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSxrQkFBWSxFQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNoRCxNQUFNLENBQUMsV0FBVyxDQUFDLElBQUEsa0JBQVksRUFBQyxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzVELENBQUMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLHlDQUF5QyxFQUFFO1FBQzVDLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSx1QkFBaUIsRUFBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUM5QyxNQUFNLENBQUMsV0FBVyxDQUFDLElBQUEsdUJBQWlCLEVBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3JELE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSx1QkFBaUIsRUFBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzNELE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBQSx1QkFBaUIsRUFBQyxDQUFDLE9BQU8sRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN2RSxDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQywrQ0FBK0MsRUFBRTtRQUNsRCxNQUFNLFNBQVMsR0FBRyxHQUFHLENBQUM7UUFDdEIsTUFBTSxDQUFDLGVBQWUsQ0FBQyxJQUFBLG9CQUFjLEVBQUMsQ0FBQyxPQUFPLENBQUMsRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQzVFLE1BQU0sQ0FBQyxlQUFlLENBQUMsSUFBQSxvQkFBYyxFQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxTQUFTLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxHQUFHLElBQUksRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQy9GLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBQSxvQkFBYyxFQUFDLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUMsRUFBRSxzQkFBc0IsQ0FBQyxDQUFDO0lBQzNGLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcblxuaW1wb3J0IHsgZ2V0Rml4ZWRPdXRwdXRTdW0sIGdldE1heE91dHB1dCwgZ2V0T3V0cHV0U3VtLCBpc01heE91dHB1dCwgdG9GaXhlZE91dHB1dHMgfSBmcm9tICcuLi9zcmMnO1xuXG5kZXNjcmliZSgnT3V0cHV0JywgZnVuY3Rpb24gKCkge1xuICBjb25zdCBvQmlnSW50ID0geyB2YWx1ZTogMW4gfTtcbiAgY29uc3Qgb0JpZ0ludDIgPSB7IHZhbHVlOiAybiB9O1xuICBjb25zdCBvTWF4ID0geyB2YWx1ZTogJ21heCcgfSBhcyBjb25zdDtcblxuICBpdCgnZ2V0TWF4T3V0cHV0IHJldHVybnMgZXhwZWN0ZWQgdmFsdWVzJywgZnVuY3Rpb24gKCkge1xuICAgIGFzc2VydC5zdHJpY3RFcXVhbChnZXRNYXhPdXRwdXQoW29CaWdJbnRdKSwgdW5kZWZpbmVkKTtcbiAgICBhc3NlcnQuc3RyaWN0RXF1YWwoZ2V0TWF4T3V0cHV0KFtvQmlnSW50LCBvQmlnSW50XSksIHVuZGVmaW5lZCk7XG4gICAgYXNzZXJ0LnN0cmljdEVxdWFsKGdldE1heE91dHB1dChbb0JpZ0ludCwgb01heF0pLCBvTWF4KTtcbiAgICBhc3NlcnQudGhyb3dzKCgpID0+IGdldE1heE91dHB1dChbb01heCwgb01heF0pLCAvTXVsdGlwbGUgbWF4IG91dHB1dHMvKTtcbiAgfSk7XG5cbiAgaXQoJ2lzTWF4T3V0cHV0IGNvcnJlY3RseSBpZGVudGlmaWVzIG1heCBvdXRwdXRzJywgZnVuY3Rpb24gKCkge1xuICAgIGFzc2VydC5zdHJpY3RFcXVhbChpc01heE91dHB1dChvQmlnSW50KSwgZmFsc2UpO1xuICAgIGFzc2VydC5zdHJpY3RFcXVhbChpc01heE91dHB1dChvTWF4KSwgdHJ1ZSk7XG4gIH0pO1xuXG4gIGl0KCdnZXRPdXRwdXRTdW0gY2FsY3VsYXRlcyBzdW0gY29ycmVjdGx5JywgZnVuY3Rpb24gKCkge1xuICAgIGFzc2VydC5zdHJpY3RFcXVhbChnZXRPdXRwdXRTdW0oW10pLCAwbik7XG4gICAgYXNzZXJ0LnN0cmljdEVxdWFsKGdldE91dHB1dFN1bShbb0JpZ0ludF0pLCAxbik7XG4gICAgYXNzZXJ0LnN0cmljdEVxdWFsKGdldE91dHB1dFN1bShbb0JpZ0ludCwgb0JpZ0ludDJdKSwgM24pO1xuICB9KTtcblxuICBpdCgnZ2V0Rml4ZWRPdXRwdXRTdW0gaGFuZGxlcyBtaXhlZCBvdXRwdXRzJywgZnVuY3Rpb24gKCkge1xuICAgIGFzc2VydC5zdHJpY3RFcXVhbChnZXRGaXhlZE91dHB1dFN1bShbXSksIDBuKTtcbiAgICBhc3NlcnQuc3RyaWN0RXF1YWwoZ2V0Rml4ZWRPdXRwdXRTdW0oW29CaWdJbnRdKSwgMW4pO1xuICAgIGFzc2VydC5zdHJpY3RFcXVhbChnZXRGaXhlZE91dHB1dFN1bShbb0JpZ0ludCwgb01heF0pLCAxbik7XG4gICAgYXNzZXJ0LnN0cmljdEVxdWFsKGdldEZpeGVkT3V0cHV0U3VtKFtvQmlnSW50LCBvQmlnSW50Miwgb01heF0pLCAzbik7XG4gIH0pO1xuXG4gIGl0KCd0b0ZpeGVkT3V0cHV0cyBjb252ZXJ0cyBtYXggb3V0cHV0cyBjb3JyZWN0bHknLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3QgbWF4QW1vdW50ID0gMTBuO1xuICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwodG9GaXhlZE91dHB1dHMoW29CaWdJbnRdLCB7IG1heEFtb3VudCB9KSwgW29CaWdJbnRdKTtcbiAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKHRvRml4ZWRPdXRwdXRzKFtvTWF4XSwgeyBtYXhBbW91bnQgfSksIFt7IC4uLm9NYXgsIHZhbHVlOiBtYXhBbW91bnQgfV0pO1xuICAgIGFzc2VydC50aHJvd3MoKCkgPT4gdG9GaXhlZE91dHB1dHMoW29NYXgsIG9NYXhdLCB7IG1heEFtb3VudCB9KSwgL011bHRpcGxlIG1heCBvdXRwdXRzLyk7XG4gIH0pO1xufSk7XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { payments } from '@bitgo-beta/utxo-lib';
|
|
2
|
+
export declare const BIP322_WIF_FIXTURE = "L3VFeEujGtevx9w18HD1fhRbCH67Az2dpCymeRE1SoPK6XQtaN2k";
|
|
3
|
+
export declare const BIP322_PRV_FIXTURE: import("@bitgo-beta/utxo-lib").ECPairInterface;
|
|
4
|
+
export declare const BIP322_PAYMENT_P2WPKH_FIXTURE: payments.Payment;
|
|
5
|
+
export declare const BIP322_FIXTURE_HELLO_WORLD_TOSPEND_TX: import("@bitgo-beta/utxo-lib").Transaction<bigint>;
|
|
6
|
+
export declare const BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT: import("modules/utxo-lib/dist/src/bitgo").UtxoPsbt<import("modules/utxo-lib/dist/src/bitgo").UtxoTransaction<bigint>>;
|
|
7
|
+
//# sourceMappingURL=bip322.utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bip322.utils.d.ts","sourceRoot":"","sources":["../../../../test/bip322/bip322.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAU,MAAM,sBAAsB,CAAC;AAIxD,eAAO,MAAM,kBAAkB,yDAAyD,CAAC;AACzF,eAAO,MAAM,kBAAkB,gDAAqC,CAAC;AACrE,eAAO,MAAM,6BAA6B,kBAExC,CAAC;AAEH,eAAO,MAAM,qCAAqC,oDAGjD,CAAC;AAEF,eAAO,MAAM,sCAAsC,uHAAyB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT = exports.BIP322_FIXTURE_HELLO_WORLD_TOSPEND_TX = exports.BIP322_PAYMENT_P2WPKH_FIXTURE = exports.BIP322_PRV_FIXTURE = exports.BIP322_WIF_FIXTURE = void 0;
|
|
4
|
+
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
5
|
+
const bip322_1 = require("../../src/bip322");
|
|
6
|
+
exports.BIP322_WIF_FIXTURE = 'L3VFeEujGtevx9w18HD1fhRbCH67Az2dpCymeRE1SoPK6XQtaN2k';
|
|
7
|
+
exports.BIP322_PRV_FIXTURE = utxo_lib_1.ECPair.fromWIF(exports.BIP322_WIF_FIXTURE);
|
|
8
|
+
exports.BIP322_PAYMENT_P2WPKH_FIXTURE = utxo_lib_1.payments.p2wpkh({
|
|
9
|
+
address: 'bc1q9vza2e8x573nczrlzms0wvx3gsqjx7vavgkx0l',
|
|
10
|
+
});
|
|
11
|
+
exports.BIP322_FIXTURE_HELLO_WORLD_TOSPEND_TX = (0, bip322_1.buildToSpendTransaction)(exports.BIP322_PAYMENT_P2WPKH_FIXTURE.output, Buffer.from('Hello World'));
|
|
12
|
+
exports.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT = (0, bip322_1.createBaseToSignPsbt)();
|
|
13
|
+
(0, bip322_1.addBip322Input)(exports.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT, 'Hello World', {
|
|
14
|
+
scriptPubKey: exports.BIP322_PAYMENT_P2WPKH_FIXTURE.output,
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmlwMzIyLnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdGVzdC9iaXAzMjIvYmlwMzIyLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1EQUF3RDtBQUV4RCw2Q0FBaUc7QUFFcEYsUUFBQSxrQkFBa0IsR0FBRyxzREFBc0QsQ0FBQztBQUM1RSxRQUFBLGtCQUFrQixHQUFHLGlCQUFNLENBQUMsT0FBTyxDQUFDLDBCQUFrQixDQUFDLENBQUM7QUFDeEQsUUFBQSw2QkFBNkIsR0FBRyxtQkFBUSxDQUFDLE1BQU0sQ0FBQztJQUMzRCxPQUFPLEVBQUUsNENBQTRDO0NBQ3RELENBQUMsQ0FBQztBQUVVLFFBQUEscUNBQXFDLEdBQUcsSUFBQSxnQ0FBdUIsRUFDMUUscUNBQTZCLENBQUMsTUFBZ0IsRUFDOUMsTUFBTSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FDM0IsQ0FBQztBQUVXLFFBQUEsc0NBQXNDLEdBQUcsSUFBQSw2QkFBb0IsR0FBRSxDQUFDO0FBQzdFLElBQUEsdUJBQWMsRUFBQyw4Q0FBc0MsRUFBRSxhQUFhLEVBQUU7SUFDcEUsWUFBWSxFQUFFLHFDQUE2QixDQUFDLE1BQWdCO0NBQzdELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHBheW1lbnRzLCBFQ1BhaXIgfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5cbmltcG9ydCB7IGFkZEJpcDMyMklucHV0LCBjcmVhdGVCYXNlVG9TaWduUHNidCwgYnVpbGRUb1NwZW5kVHJhbnNhY3Rpb24gfSBmcm9tICcuLi8uLi9zcmMvYmlwMzIyJztcblxuZXhwb3J0IGNvbnN0IEJJUDMyMl9XSUZfRklYVFVSRSA9ICdMM1ZGZUV1akd0ZXZ4OXcxOEhEMWZoUmJDSDY3QXoyZHBDeW1lUkUxU29QSzZYUXRhTjJrJztcbmV4cG9ydCBjb25zdCBCSVAzMjJfUFJWX0ZJWFRVUkUgPSBFQ1BhaXIuZnJvbVdJRihCSVAzMjJfV0lGX0ZJWFRVUkUpO1xuZXhwb3J0IGNvbnN0IEJJUDMyMl9QQVlNRU5UX1AyV1BLSF9GSVhUVVJFID0gcGF5bWVudHMucDJ3cGtoKHtcbiAgYWRkcmVzczogJ2JjMXE5dnphMmU4eDU3M25jenJsem1zMHd2eDNnc3FqeDd2YXZna3gwbCcsXG59KTtcblxuZXhwb3J0IGNvbnN0IEJJUDMyMl9GSVhUVVJFX0hFTExPX1dPUkxEX1RPU1BFTkRfVFggPSBidWlsZFRvU3BlbmRUcmFuc2FjdGlvbihcbiAgQklQMzIyX1BBWU1FTlRfUDJXUEtIX0ZJWFRVUkUub3V0cHV0IGFzIEJ1ZmZlcixcbiAgQnVmZmVyLmZyb20oJ0hlbGxvIFdvcmxkJylcbik7XG5cbmV4cG9ydCBjb25zdCBCSVAzMjJfRklYVFVSRV9IRUxMT19XT1JMRF9UT1NJR05fUFNCVCA9IGNyZWF0ZUJhc2VUb1NpZ25Qc2J0KCk7XG5hZGRCaXAzMjJJbnB1dChCSVAzMjJfRklYVFVSRV9IRUxMT19XT1JMRF9UT1NJR05fUFNCVCwgJ0hlbGxvIFdvcmxkJywge1xuICBzY3JpcHRQdWJLZXk6IEJJUDMyMl9QQVlNRU5UX1AyV1BLSF9GSVhUVVJFLm91dHB1dCBhcyBCdWZmZXIsXG59KTtcbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toSign.d.ts","sourceRoot":"","sources":["../../../../test/bip322/toSign.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
const assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
41
|
+
const bip322 = __importStar(require("../../src/bip322"));
|
|
42
|
+
const bip322_utils_1 = require("./bip322.utils");
|
|
43
|
+
describe('BIP322 toSign', function () {
|
|
44
|
+
describe('buildToSignPsbt', function () {
|
|
45
|
+
const scriptPubKey = bip322_utils_1.BIP322_PAYMENT_P2WPKH_FIXTURE.output;
|
|
46
|
+
// Source: https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#transaction-hashes
|
|
47
|
+
const fixtures = [
|
|
48
|
+
{
|
|
49
|
+
message: '',
|
|
50
|
+
txid: '1e9654e951a5ba44c8604c4de6c67fd78a27e81dcadcfe1edf638ba3aaebaed6',
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
message: 'Hello World',
|
|
54
|
+
txid: '88737ae86f2077145f93cc4b153ae9a1cb8d56afa511988c149c5c8c9d93bddf',
|
|
55
|
+
},
|
|
56
|
+
];
|
|
57
|
+
fixtures.forEach(({ message, txid }) => {
|
|
58
|
+
it(`should build a to_sign PSBT for message "${message}"`, function () {
|
|
59
|
+
const result = bip322.createBaseToSignPsbt();
|
|
60
|
+
bip322.addBip322Input(result, message, {
|
|
61
|
+
scriptPubKey,
|
|
62
|
+
});
|
|
63
|
+
const computedTxid = result
|
|
64
|
+
.signAllInputs(bip322_utils_1.BIP322_PRV_FIXTURE, [utxolib.Transaction.SIGHASH_ALL])
|
|
65
|
+
.finalizeAllInputs()
|
|
66
|
+
.extractTransaction()
|
|
67
|
+
.getId();
|
|
68
|
+
assert_1.default.strictEqual(computedTxid, txid, `Transaction ID for message "${message}" does not match expected value`);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
describe('buildToSignPsbtForChainAndIndex', function () {
|
|
73
|
+
const rootWalletKeys = utxolib.testutil.getDefaultWalletKeys();
|
|
74
|
+
function run(chain, index) {
|
|
75
|
+
const scriptType = utxolib.bitgo.scriptTypeForChain(chain);
|
|
76
|
+
it(`should build and sign a to_sign PSBT for chain ${chain}, index ${index}`, function () {
|
|
77
|
+
const message = 'I can believe it is not butter';
|
|
78
|
+
const toSpendTx = bip322.buildToSpendTransactionFromChainAndIndex(rootWalletKeys, chain, index, message);
|
|
79
|
+
const toSignPsbt = bip322.createBaseToSignPsbt(rootWalletKeys);
|
|
80
|
+
bip322.addBip322InputWithChainAndIndex(toSignPsbt, message, rootWalletKeys, { chain, index });
|
|
81
|
+
// Can sign the PSBT with the keys
|
|
82
|
+
// Should be able to use HD because we have the (tap)bip32Derivation information
|
|
83
|
+
if (scriptType === 'p2trMusig2') {
|
|
84
|
+
toSignPsbt.setAllInputsMusig2NonceHD(rootWalletKeys.user);
|
|
85
|
+
toSignPsbt.setAllInputsMusig2NonceHD(rootWalletKeys.bitgo);
|
|
86
|
+
}
|
|
87
|
+
toSignPsbt.signAllInputsHD(rootWalletKeys.user);
|
|
88
|
+
toSignPsbt.signAllInputsHD(rootWalletKeys.bitgo);
|
|
89
|
+
// Wrap the PSBT as a UtxoPsbt so that we can use the validateSignaturesOfInputCommon method
|
|
90
|
+
const utxopsbt = utxolib.bitgo.createPsbtFromBuffer(toSignPsbt.toBuffer(), utxolib.networks.bitcoin);
|
|
91
|
+
utxopsbt.validateSignaturesOfAllInputs();
|
|
92
|
+
// finalize and extract
|
|
93
|
+
const tx = toSignPsbt.finalizeAllInputs().extractTransaction();
|
|
94
|
+
assert_1.default.ok(tx);
|
|
95
|
+
// Check that the transaction matches the full BIP322 format
|
|
96
|
+
// Source: https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#full
|
|
97
|
+
// For the to_spend transaction, verify that all of the properties are set correctly,
|
|
98
|
+
// then get the txid and make sure that it matches the value in the `to_sign` tx
|
|
99
|
+
assert_1.default.deepStrictEqual(toSpendTx.version, 0, 'version must be 0');
|
|
100
|
+
assert_1.default.deepStrictEqual(toSpendTx.locktime, 0, 'locktime must be 0');
|
|
101
|
+
assert_1.default.deepStrictEqual(toSpendTx.ins[0].hash.toString('hex'), '0000000000000000000000000000000000000000000000000000000000000000', 'input hash must be a 32 byte zero buffer');
|
|
102
|
+
assert_1.default.deepStrictEqual(toSpendTx.ins[0].index, 0xffffffff, 'input index must be 0xFFFFFFFF');
|
|
103
|
+
assert_1.default.deepStrictEqual(toSpendTx.ins[0].sequence, 0, 'input sequence must be 0');
|
|
104
|
+
assert_1.default.deepStrictEqual(toSpendTx.ins[0].script.toString('hex'), Buffer.concat([Buffer.from([0x00, 0x20]), bip322.hashMessageWithTag(message)]).toString('hex'), 'input script must be OP_0 PUSH32[ message_hash ]');
|
|
105
|
+
assert_1.default.ok(Array.isArray(toSpendTx.ins[0].witness), 'input witness must be an array');
|
|
106
|
+
assert_1.default.deepStrictEqual(toSpendTx.ins[0].witness.length, 0, 'input witness must be empty');
|
|
107
|
+
assert_1.default.deepStrictEqual(toSpendTx.ins.length, 1, 'to_spend transaction must have one input');
|
|
108
|
+
assert_1.default.deepStrictEqual(toSpendTx.outs.length, 1, 'to_spend transaction must have one output');
|
|
109
|
+
assert_1.default.deepStrictEqual(toSpendTx.outs[0].value, BigInt(0), 'output value must be 0');
|
|
110
|
+
const derivedKeys = rootWalletKeys.deriveForChainAndIndex(chain, index);
|
|
111
|
+
assert_1.default.deepStrictEqual(toSpendTx.outs[0].script.toString('hex'), utxolib.bitgo.outputScripts
|
|
112
|
+
.createOutputScript2of3(derivedKeys.publicKeys, utxolib.bitgo.scriptTypeForChain(chain), utxolib.networks.bitcoin)
|
|
113
|
+
.scriptPubKey.toString('hex'), 'the script pubkey of the to_spend output must be the scriptPubKey of the address we are proving ownership of');
|
|
114
|
+
assert_1.default.deepStrictEqual(tx.ins.length, 1, 'to_sign transaction must have one input');
|
|
115
|
+
assert_1.default.deepStrictEqual(tx.version, 0, 'to_sign transaction version must be 0');
|
|
116
|
+
assert_1.default.deepStrictEqual(tx.locktime, 0, 'to_sign transaction locktime must be 0');
|
|
117
|
+
assert_1.default.deepStrictEqual(utxolib.bitgo.getOutputIdForInput(tx.ins[0]).txid, toSpendTx.getId(), 'to_sign transaction input must reference the to_spend transaction');
|
|
118
|
+
assert_1.default.deepStrictEqual(tx.ins[0].index, 0, 'to_sign transaction input index must be 0');
|
|
119
|
+
assert_1.default.deepStrictEqual(tx.ins[0].sequence, 0, 'to_sign transaction input sequence must be 0');
|
|
120
|
+
// We are not going to explicitly check the script witness on this transaction because we already verified the
|
|
121
|
+
// signatures on the PSBT for the respective public keys. All that would be verified here is that we can assemble
|
|
122
|
+
// the script witness correctly, which must be true orelse we would have a much bigger problem.
|
|
123
|
+
assert_1.default.deepStrictEqual(tx.outs.length, 1, 'to_sign transaction must have one output');
|
|
124
|
+
assert_1.default.deepStrictEqual(tx.outs[0].value, BigInt(0), 'to_sign transaction output value must be 0');
|
|
125
|
+
assert_1.default.deepStrictEqual(tx.outs[0].script.toString('hex'), '6a', 'to_sign transaction output script must be OP_RETURN');
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
utxolib.bitgo.chainCodes.forEach((chain, i) => {
|
|
129
|
+
run(chain, i);
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9TaWduLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdGVzdC9iaXAzMjIvdG9TaWduLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsb0RBQTRCO0FBRTVCLDhEQUFnRDtBQUVoRCx5REFBMkM7QUFFM0MsaURBQTBGO0FBRTFGLFFBQVEsQ0FBQyxlQUFlLEVBQUU7SUFDeEIsUUFBUSxDQUFDLGlCQUFpQixFQUFFO1FBQzFCLE1BQU0sWUFBWSxHQUFHLDRDQUE2QixDQUFDLE1BQWdCLENBQUM7UUFDcEUsNEZBQTRGO1FBQzVGLE1BQU0sUUFBUSxHQUFHO1lBQ2Y7Z0JBQ0UsT0FBTyxFQUFFLEVBQUU7Z0JBQ1gsSUFBSSxFQUFFLGtFQUFrRTthQUN6RTtZQUNEO2dCQUNFLE9BQU8sRUFBRSxhQUFhO2dCQUN0QixJQUFJLEVBQUUsa0VBQWtFO2FBQ3pFO1NBQ0YsQ0FBQztRQUVGLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO1lBQ3JDLEVBQUUsQ0FBQyw0Q0FBNEMsT0FBTyxHQUFHLEVBQUU7Z0JBQ3pELE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO2dCQUM3QyxNQUFNLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUU7b0JBQ3JDLFlBQVk7aUJBQ2IsQ0FBQyxDQUFDO2dCQUNILE1BQU0sWUFBWSxHQUFHLE1BQU07cUJBQ3hCLGFBQWEsQ0FBQyxpQ0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQztxQkFDckQsaUJBQWlCLEVBQUU7cUJBQ25CLGtCQUFrQixFQUFFO3FCQUNwQixLQUFLLEVBQUUsQ0FBQztnQkFDWCxnQkFBTSxDQUFDLFdBQVcsQ0FBQyxZQUFZLEVBQUUsSUFBSSxFQUFFLCtCQUErQixPQUFP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QUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsNENBQTRDLENBQUMsQ0FBQztnQkFDbEcsZ0JBQU0sQ0FBQyxlQUFlLENBQ3BCLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFDakMsSUFBSSxFQUNKLHFEQUFxRCxDQUN0RCxDQUFDO1lBQ0osQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBRUQsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzVDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDaEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuXG5pbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuaW1wb3J0ICogYXMgYmlwMzIyIGZyb20gJy4uLy4uL3NyYy9iaXAzMjInO1xuXG5pbXBvcnQgeyBCSVAzMjJfUEFZTUVOVF9QMldQS0hfRklYVFVSRSwgQklQMzIyX1BSVl9GSVhUVVJFIGFzIHBydiB9IGZyb20gJy4vYmlwMzIyLnV0aWxzJztcblxuZGVzY3JpYmUoJ0JJUDMyMiB0b1NpZ24nLCBmdW5jdGlvbiAoKSB7XG4gIGRlc2NyaWJlKCdidWlsZFRvU2lnblBzYnQnLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3Qgc2NyaXB0UHViS2V5ID0gQklQMzIyX1BBWU1FTlRfUDJXUEtIX0ZJWFRVUkUub3V0cHV0IGFzIEJ1ZmZlcjtcbiAgICAvLyBTb3VyY2U6IGh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luL2JpcHMvYmxvYi9tYXN0ZXIvYmlwLTAzMjIubWVkaWF3aWtpI3RyYW5zYWN0aW9uLWhhc2hlc1xuICAgIGNvbnN0IGZpeHR1cmVzID0gW1xuICAgICAge1xuICAgICAgICBtZXNzYWdlOiAnJyxcbiAgICAgICAgdHhpZDogJzFlOTY1NGU5NTFhNWJhNDRjODYwNGM0ZGU2YzY3ZmQ3OGEyN2U4MWRjYWRjZmUxZWRmNjM4YmEzYWFlYmFlZDYnLFxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbWVzc2FnZTogJ0hlbGxvIFdvcmxkJyxcbiAgICAgICAgdHhpZDogJzg4NzM3YWU4NmYyMDc3MTQ1ZjkzY2M0YjE1M2FlOWExY2I4ZDU2YWZhNTExOTg4YzE0OWM1YzhjOWQ5M2JkZGYnLFxuICAgICAgfSxcbiAgICBdO1xuXG4gICAgZml4dHVyZXMuZm9yRWFjaCgoeyBtZXNzYWdlLCB0eGlkIH0pID0+IHtcbiAgICAgIGl0KGBzaG91bGQgYnVpbGQgYSB0b19zaWduIFBTQlQgZm9yIG1lc3NhZ2UgXCIke21lc3NhZ2V9XCJgLCBmdW5jdGlvbiAoKSB7XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGJpcDMyMi5jcmVhdGVCYXNlVG9TaWduUHNidCgpO1xuICAgICAgICBiaXAzMjIuYWRkQmlwMzIySW5wdXQocmVzdWx0LCBtZXNzYWdlLCB7XG4gICAgICAgICAgc2NyaXB0UHViS2V5LFxuICAgICAgICB9KTtcbiAgICAgICAgY29uc3QgY29tcHV0ZWRUeGlkID0gcmVzdWx0XG4gICAgICAgICAgLnNpZ25BbGxJbnB1dHMocHJ2LCBbdXR4b2xpYi5UcmFuc2FjdGlvbi5TSUdIQVNIX0FMTF0pXG4gICAgICAgICAgLmZpbmFsaXplQWxsSW5wdXRzKClcbiAgICAgICAgICAuZXh0cmFjdFRyYW5zYWN0aW9uKClcbiAgICAgICAgICAuZ2V0SWQoKTtcbiAgICAgICAgYXNzZXJ0LnN0cmljdEVxdWFsKGNvbXB1dGVkVHhpZCwgdHhpZCwgYFRyYW5zYWN0aW9uIElEIGZvciBtZXNzYWdlIFwiJHttZXNzYWdlfVwiIGRvZXMgbm90IG1hdGNoIGV4cGVjdGVkIHZhbHVlYCk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ2J1aWxkVG9TaWduUHNidEZvckNoYWluQW5kSW5kZXgnLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3Qgcm9vdFdhbGxldEtleXMgPSB1dHhvbGliLnRlc3R1dGlsLmdldERlZmF1bHRXYWxsZXRLZXlzKCk7XG5cbiAgICBmdW5jdGlvbiBydW4oY2hhaW46IHV0eG9saWIuYml0Z28uQ2hhaW5Db2RlLCBpbmRleDogbnVtYmVyKSB7XG4gICAgICBjb25zdCBzY3JpcHRUeXBlID0gdXR4b2xpYi5iaXRnby5zY3JpcHRUeXBlRm9yQ2hhaW4oY2hhaW4pO1xuICAgICAgaXQoYHNob3VsZCBidWlsZCBhbmQgc2lnbiBhIHRvX3NpZ24gUFNCVCBmb3IgY2hhaW4gJHtjaGFpbn0sIGluZGV4ICR7aW5kZXh9YCwgZnVuY3Rpb24gKCkge1xuICAgICAgICBjb25zdCBtZXNzYWdlID0gJ0kgY2FuIGJlbGlldmUgaXQgaXMgbm90IGJ1dHRlcic7XG5cbiAgICAgICAgY29uc3QgdG9TcGVuZFR4ID0gYmlwMzIyLmJ1aWxkVG9TcGVuZFRyYW5zYWN0aW9uRnJvbUNoYWluQW5kSW5kZXgocm9vdFdhbGxldEtleXMsIGNoYWluLCBpbmRleCwgbWVzc2FnZSk7XG4gICAgICAgIGNvbnN0IHRvU2lnblBzYnQgPSBiaXAzMjIuY3JlYXRlQmFzZVRvU2lnblBzYnQocm9vdFdhbGxldEtleXMpO1xuICAgICAgICBiaXAzMjIuYWRkQmlwMzIySW5wdXRXaXRoQ2hhaW5BbmRJbmRleCh0b1NpZ25Qc2J0LCBtZXNzYWdlLCByb290V2FsbGV0S2V5cywgeyBjaGFpbiwgaW5kZXggfSk7XG5cbiAgICAgICAgLy8gQ2FuIHNpZ24gdGhlIFBTQlQgd2l0aCB0aGUga2V5c1xuICAgICAgICAvLyBTaG91bGQgYmUgYWJsZSB0byB1c2UgSEQgYmVjYXVzZSB3ZSBoYXZlIHRoZSAodGFwKWJpcDMyRGVyaXZhdGlvbiBpbmZvcm1hdGlvblxuICAgICAgICBpZiAoc2NyaXB0VHlwZSA9PT0gJ3AydHJNdXNpZzInKSB7XG4gICAgICAgICAgdG9TaWduUHNidC5zZXRBbGxJbnB1dHNNdXNpZzJOb25jZUhEKHJvb3RXYWxsZXRLZXlzLnVzZXIpO1xuICAgICAgICAgIHRvU2lnblBzYnQuc2V0QWxsSW5wdXRzTXVzaWcyTm9uY2VIRChyb290V2FsbGV0S2V5cy5iaXRnbyk7XG4gICAgICAgIH1cbiAgICAgICAgdG9TaWduUHNidC5zaWduQWxsSW5wdXRzSEQocm9vdFdhbGxldEtleXMudXNlcik7XG4gICAgICAgIHRvU2lnblBzYnQuc2lnbkFsbElucHV0c0hEKHJvb3RXYWxsZXRLZXlzLmJpdGdvKTtcblxuICAgICAgICAvLyBXcmFwIHRoZSBQU0JUIGFzIGEgVXR4b1BzYnQgc28gdGhhdCB3ZSBjYW4gdXNlIHRoZSB2YWxpZGF0ZVNpZ25hdHVyZXNPZklucHV0Q29tbW9uIG1ldGhvZFxuICAgICAgICBjb25zdCB1dHhvcHNidCA9IHV0eG9saWIuYml0Z28uY3JlYXRlUHNidEZyb21CdWZmZXIodG9TaWduUHNidC50b0J1ZmZlcigpLCB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW4pO1xuICAgICAgICB1dHhvcHNidC52YWxpZGF0ZVNpZ25hdHVyZXNPZkFsbElucHV0cygpO1xuXG4gICAgICAgIC8vIGZpbmFsaXplIGFuZCBleHRyYWN0XG4gICAgICAgIGNvbnN0IHR4ID0gdG9TaWduUHNidC5maW5hbGl6ZUFsbElucHV0cygpLmV4dHJhY3RUcmFuc2FjdGlvbigpO1xuICAgICAgICBhc3NlcnQub2sodHgpO1xuXG4gICAgICAgIC8vIENoZWNrIHRoYXQgdGhlIHRyYW5zYWN0aW9uIG1hdGNoZXMgdGhlIGZ1bGwgQklQMzIyIGZvcm1hdFxuICAgICAgICAvLyBTb3VyY2U6IGh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luL2JpcHMvYmxvYi9tYXN0ZXIvYmlwLTAzMjIubWVkaWF3aWtpI2Z1bGxcbiAgICAgICAgLy8gRm9yIHRoZSB0b19zcGVuZCB0cmFuc2FjdGlvbiwgdmVyaWZ5IHRoYXQgYWxsIG9mIHRoZSBwcm9wZXJ0aWVzIGFyZSBzZXQgY29ycmVjdGx5LFxuICAgICAgICAvLyB0aGVuIGdldCB0aGUgdHhpZCBhbmQgbWFrZSBzdXJlIHRoYXQgaXQgbWF0Y2hlcyB0aGUgdmFsdWUgaW4gdGhlIGB0b19zaWduYCB0eFxuICAgICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKHRvU3BlbmRUeC52ZXJzaW9uLCAwLCAndmVyc2lvbiBtdXN0IGJlIDAnKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbCh0b1NwZW5kVHgubG9ja3RpbWUsIDAsICdsb2NrdGltZSBtdXN0IGJlIDAnKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChcbiAgICAgICAgICB0b1NwZW5kVHguaW5zWzBdLmhhc2gudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgICAgICcwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwJyxcbiAgICAgICAgICAnaW5wdXQgaGFzaCBtdXN0IGJlIGEgMzIgYnl0ZSB6ZXJvIGJ1ZmZlcidcbiAgICAgICAgKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbCh0b1NwZW5kVHguaW5zWzBdLmluZGV4LCAweGZmZmZmZmZmLCAnaW5wdXQgaW5kZXggbXVzdCBiZSAweEZGRkZGRkZGJyk7XG4gICAgICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwodG9TcGVuZFR4Lmluc1swXS5zZXF1ZW5jZSwgMCwgJ2lucHV0IHNlcXVlbmNlIG11c3QgYmUgMCcpO1xuICAgICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKFxuICAgICAgICAgIHRvU3BlbmRUeC5pbnNbMF0uc2NyaXB0LnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgICBCdWZmZXIuY29uY2F0KFtCdWZmZXIuZnJvbShbMHgwMCwgMHgyMF0pLCBiaXAzMjIuaGFzaE1lc3NhZ2VXaXRoVGFnKG1lc3NhZ2UpXSkudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgICAgICdpbnB1dCBzY3JpcHQgbXVzdCBiZSBPUF8wIFBVU0gzMlsgbWVzc2FnZV9oYXNoIF0nXG4gICAgICAgICk7XG4gICAgICAgIGFzc2VydC5vayhBcnJheS5pc0FycmF5KHRvU3BlbmRUeC5pbnNbMF0ud2l0bmVzcyksICdpbnB1dCB3aXRuZXNzIG11c3QgYmUgYW4gYXJyYXknKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbCh0b1NwZW5kVHguaW5zWzBdLndpdG5lc3MubGVuZ3RoLCAwLCAnaW5wdXQgd2l0bmVzcyBtdXN0IGJlIGVtcHR5Jyk7XG4gICAgICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwodG9TcGVuZFR4Lmlucy5sZW5ndGgsIDEsICd0b19zcGVuZCB0cmFuc2FjdGlvbiBtdXN0IGhhdmUgb25lIGlucHV0Jyk7XG4gICAgICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwodG9TcGVuZFR4Lm91dHMubGVuZ3RoLCAxLCAndG9fc3BlbmQgdHJhbnNhY3Rpb24gbXVzdCBoYXZlIG9uZSBvdXRwdXQnKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbCh0b1NwZW5kVHgub3V0c1swXS52YWx1ZSwgQmlnSW50KDApLCAnb3V0cHV0IHZhbHVlIG11c3QgYmUgMCcpO1xuICAgICAgICBjb25zdCBkZXJpdmVkS2V5cyA9IHJvb3RXYWxsZXRLZXlzLmRlcml2ZUZvckNoYWluQW5kSW5kZXgoY2hhaW4sIGluZGV4KTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChcbiAgICAgICAgICB0b1NwZW5kVHgub3V0c1swXS5zY3JpcHQudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgICAgIHV0eG9saWIuYml0Z28ub3V0cHV0U2NyaXB0c1xuICAgICAgICAgICAgLmNyZWF0ZU91dHB1dFNjcmlwdDJvZjMoXG4gICAgICAgICAgICAgIGRlcml2ZWRLZXlzLnB1YmxpY0tleXMsXG4gICAgICAgICAgICAgIHV0eG9saWIuYml0Z28uc2NyaXB0VHlwZUZvckNoYWluKGNoYWluKSxcbiAgICAgICAgICAgICAgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luXG4gICAgICAgICAgICApXG4gICAgICAgICAgICAuc2NyaXB0UHViS2V5LnRvU3RyaW5nKCdoZXgnKSxcbiAgICAgICAgICAndGhlIHNjcmlwdCBwdWJrZXkgb2YgdGhlIHRvX3NwZW5kIG91dHB1dCBtdXN0IGJlIHRoZSBzY3JpcHRQdWJLZXkgb2YgdGhlIGFkZHJlc3Mgd2UgYXJlIHByb3Zpbmcgb3duZXJzaGlwIG9mJ1xuICAgICAgICApO1xuICAgICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKHR4Lmlucy5sZW5ndGgsIDEsICd0b19zaWduIHRyYW5zYWN0aW9uIG11c3QgaGF2ZSBvbmUgaW5wdXQnKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbCh0eC52ZXJzaW9uLCAwLCAndG9fc2lnbiB0cmFuc2FjdGlvbiB2ZXJzaW9uIG11c3QgYmUgMCcpO1xuICAgICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKHR4LmxvY2t0aW1lLCAwLCAndG9fc2lnbiB0cmFuc2FjdGlvbiBsb2NrdGltZSBtdXN0IGJlIDAnKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChcbiAgICAgICAgICB1dHhvbGliLmJpdGdvLmdldE91dHB1dElkRm9ySW5wdXQodHguaW5zWzBdKS50eGlkLFxuICAgICAgICAgIHRvU3BlbmRUeC5nZXRJZCgpLFxuICAgICAgICAgICd0b19zaWduIHRyYW5zYWN0aW9uIGlucHV0IG11c3QgcmVmZXJlbmNlIHRoZSB0b19zcGVuZCB0cmFuc2FjdGlvbidcbiAgICAgICAgKTtcbiAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbCh0eC5pbnNbMF0uaW5kZXgsIDAsICd0b19zaWduIHRyYW5zYWN0aW9uIGlucHV0IGluZGV4IG11c3QgYmUgMCcpO1xuICAgICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKHR4Lmluc1swXS5zZXF1ZW5jZSwgMCwgJ3RvX3NpZ24gdHJhbnNhY3Rpb24gaW5wdXQgc2VxdWVuY2UgbXVzdCBiZSAwJyk7XG4gICAgICAgIC8vIFdlIGFyZSBub3QgZ29pbmcgdG8gZXhwbGljaXRseSBjaGVjayB0aGUgc2NyaXB0IHdpdG5lc3Mgb24gdGhpcyB0cmFuc2FjdGlvbiBiZWNhdXNlIHdlIGFscmVhZHkgdmVyaWZpZWQgdGhlXG4gICAgICAgIC8vIHNpZ25hdHVyZXMgb24gdGhlIFBTQlQgZm9yIHRoZSByZXNwZWN0aXZlIHB1YmxpYyBrZXlzLiBBbGwgdGhhdCB3b3VsZCBiZSB2ZXJpZmllZCBoZXJlIGlzIHRoYXQgd2UgY2FuIGFzc2VtYmxlXG4gICAgICAgIC8vIHRoZSBzY3JpcHQgd2l0bmVzcyBjb3JyZWN0bHksIHdoaWNoIG11c3QgYmUgdHJ1ZSBvcmVsc2Ugd2Ugd291bGQgaGF2ZSBhIG11Y2ggYmlnZ2VyIHByb2JsZW0uXG4gICAgICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwodHgub3V0cy5sZW5ndGgsIDEsICd0b19zaWduIHRyYW5zYWN0aW9uIG11c3QgaGF2ZSBvbmUgb3V0cHV0Jyk7XG4gICAgICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwodHgub3V0c1swXS52YWx1ZSwgQmlnSW50KDApLCAndG9fc2lnbiB0cmFuc2FjdGlvbiBvdXRwdXQgdmFsdWUgbXVzdCBiZSAwJyk7XG4gICAgICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwoXG4gICAgICAgICAgdHgub3V0c1swXS5zY3JpcHQudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgICAgICc2YScsXG4gICAgICAgICAgJ3RvX3NpZ24gdHJhbnNhY3Rpb24gb3V0cHV0IHNjcmlwdCBtdXN0IGJlIE9QX1JFVFVSTidcbiAgICAgICAgKTtcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIHV0eG9saWIuYml0Z28uY2hhaW5Db2Rlcy5mb3JFYWNoKChjaGFpbiwgaSkgPT4ge1xuICAgICAgcnVuKGNoYWluLCBpKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toSpend.d.ts","sourceRoot":"","sources":["../../../../test/bip322/toSpend.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const assert_1 = __importDefault(require("assert"));
|
|
7
|
+
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
8
|
+
const bip322_1 = require("../../src/bip322");
|
|
9
|
+
const bip322_utils_1 = require("./bip322.utils");
|
|
10
|
+
describe('to_spend', function () {
|
|
11
|
+
describe('Message hashing', function () {
|
|
12
|
+
// Test vectors from BIP322
|
|
13
|
+
// Source: https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#message-hashing
|
|
14
|
+
const fixtures = [
|
|
15
|
+
{
|
|
16
|
+
message: '',
|
|
17
|
+
hash: 'c90c269c4f8fcbe6880f72a721ddfbf1914268a794cbb21cfafee13770ae19f1',
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
message: 'Hello World',
|
|
21
|
+
hash: 'f0eb03b1a75ac6d9847f55c624a99169b5dccba2a31f5b23bea77ba270de0a7a',
|
|
22
|
+
},
|
|
23
|
+
];
|
|
24
|
+
fixtures.forEach(({ message, hash }) => {
|
|
25
|
+
it(`should hash the message "${message}"`, function () {
|
|
26
|
+
const result = (0, bip322_1.hashMessageWithTag)(Buffer.from(message));
|
|
27
|
+
assert_1.default.deepStrictEqual(result.toString('hex'), hash, `Hash for message "${message}" does not match expected value`);
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
describe('build to_spend transaction', function () {
|
|
32
|
+
const scriptPubKey = bip322_utils_1.BIP322_PAYMENT_P2WPKH_FIXTURE.output;
|
|
33
|
+
// Source: https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#transaction-hashes
|
|
34
|
+
const fixtures = [
|
|
35
|
+
{
|
|
36
|
+
message: '',
|
|
37
|
+
txid: 'c5680aa69bb8d860bf82d4e9cd3504b55dde018de765a91bb566283c545a99a7',
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
message: 'Hello World',
|
|
41
|
+
txid: 'b79d196740ad5217771c1098fc4a4b51e0535c32236c71f1ea4d61a2d603352b',
|
|
42
|
+
},
|
|
43
|
+
];
|
|
44
|
+
fixtures.forEach(({ message, txid }) => {
|
|
45
|
+
it(`should build a to_spend transaction for message "${message}"`, function () {
|
|
46
|
+
const result = (0, bip322_1.buildToSpendTransaction)(scriptPubKey, Buffer.from(message));
|
|
47
|
+
const computedTxid = result.getId();
|
|
48
|
+
assert_1.default.strictEqual(computedTxid, txid, `Transaction ID for message "${message}" does not match expected value`);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe('buildToSpendTransactionFromChainAndIndex', function () {
|
|
53
|
+
describe('should build a to_spend transaction for a non-Taproot chain', function () {
|
|
54
|
+
function run(chain) {
|
|
55
|
+
it(`scriptType: ${utxo_lib_1.bitgo.scriptTypeForChain(chain)}, chain ${chain}`, function () {
|
|
56
|
+
const tx = (0, bip322_1.buildToSpendTransactionFromChainAndIndex)(utxo_lib_1.testutil.getDefaultWalletKeys(), 20, 0, Buffer.from('Hello World'));
|
|
57
|
+
const expectedScriptPubKey = utxo_lib_1.bitgo.outputScripts
|
|
58
|
+
.createOutputScript2of3(utxo_lib_1.testutil.getDefaultWalletKeys().deriveForChainAndIndex(20, 0).publicKeys, 'p2wsh')
|
|
59
|
+
.scriptPubKey.toString();
|
|
60
|
+
const scriptPubKeyFromTx = tx.outs[0].script.toString();
|
|
61
|
+
assert_1.default.deepStrictEqual(scriptPubKeyFromTx, expectedScriptPubKey, 'ScriptPubKey does not match expected value');
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
[0, 1, 10, 11, 20, 21].forEach((chain) => {
|
|
65
|
+
run(chain);
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9TcGVuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Rlc3QvYmlwMzIyL3RvU3BlbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxvREFBNEI7QUFFNUIsbURBQXVEO0FBRXZELDZDQUkwQjtBQUUxQixpREFBK0Q7QUFFL0QsUUFBUSxDQUFDLFVBQVUsRUFBRTtJQUNuQixRQUFRLENBQUMsaUJBQWlCLEVBQUU7UUFDMUIsMkJBQTJCO1FBQzNCLHlGQUF5RjtRQUN6RixNQUFNLFFBQVEsR0FBRztZQUNmO2dCQUNFLE9BQU8sRUFBRSxFQUFFO2dCQUNYLElBQUksRUFBRSxrRUFBa0U7YUFDekU7WUFDRDtnQkFDRSxPQUFPLEVBQUUsYUFBYTtnQkFDdEIsSUFBSSxFQUFFLGtFQUFrRTthQUN6RTtTQUNGLENBQUM7UUFDRixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRTtZQUNyQyxFQUFFLENBQUMsNEJBQTRCLE9BQU8sR0FBRyxFQUFFO2dCQUN6QyxNQUFNLE1BQU0sR0FBRyxJQUFBLDJCQUFrQixFQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztnQkFDeEQsZ0JBQU0sQ0FBQyxlQUFlLENBQ3BCLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQ3RCLElBQUksRUFDSixxQkFBcUIsT0FBTyxpQ0FBaUMsQ0FDOUQsQ0FBQztZQUNKLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQyw0QkFBNEIsRUFBRTtRQUNyQyxNQUFNLFlBQVksR0FBRyw0Q0FBNkIsQ0FBQyxNQUFnQixDQUFDO1FBRXBFLDRGQUE0RjtRQUM1RixNQUFNLFFBQVEsR0FBRztZQUNmO2dCQUNFLE9BQU8sRUFBRSxFQUFFO2dCQUNYLElBQUksRUFBRSxrRUFBa0U7YUFDekU7WUFDRDtnQkFDRSxPQUFPLEVBQUUsYUFBYTtnQkFDdEIsSUFBSSxFQUFFLGtFQUFrRTthQUN6RTtTQUNGLENBQUM7UUFFRixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRTtZQUNyQyxFQUFFLENBQUMsb0RBQW9ELE9BQU8sR0FBRyxFQUFFO2dCQUNqRSxNQUFNLE1BQU0sR0FBRyxJQUFBLGdDQUF1QixFQUFDLFlBQVksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7Z0JBQzNFLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztnQkFDcEMsZ0JBQU0sQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLElBQUksRUFBRSwrQkFBK0IsT0FBTyxpQ0FBaUMsQ0FBQyxDQUFDO1lBQ2xILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQywwQ0FBMEMsRUFBRTtRQUNuRCxRQUFRLENBQUMsNkRBQTZELEVBQUU7WUFDdEUsU0FBUyxHQUFHLENBQUMsS0FBc0I7Z0JBQ2pDLEVBQUUsQ0FBQyxlQUFlLGdCQUFLLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLFdBQVcsS0FBSyxFQUFFLEVBQUU7b0JBQ25FLE1BQU0sRUFBRSxHQUFHLElBQUEsaURBQXdDLEVBQ2pELG1CQUFRLENBQUMsb0JBQW9CLEVBQUUsRUFDL0IsRUFBRSxFQUNGLENBQUMsRUFDRCxNQUFNLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUMzQixDQUFDO29CQUNGLE1BQU0sb0JBQW9CLEdBQUcsZ0JBQUssQ0FBQyxhQUFhO3lCQUM3QyxzQkFBc0IsQ0FBQyxtQkFBUSxDQUFDLG9CQUFvQixFQUFFLENBQUMsc0JBQXNCLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsRUFBRSxPQUFPLENBQUM7eUJBQ3pHLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztvQkFDM0IsTUFBTSxrQkFBa0IsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztvQkFDeEQsZ0JBQU0sQ0FBQyxlQUFlLENBQ3BCLGtCQUFrQixFQUNsQixvQkFBb0IsRUFDcEIsNENBQTRDLENBQzdDLENBQUM7Z0JBQ0osQ0FBQyxDQUFDLENBQUM7WUFDTCxDQUFDO1lBRUEsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBdUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDOUQsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2IsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCB7IHRlc3R1dGlsLCBiaXRnbyB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuaW1wb3J0IHtcbiAgYnVpbGRUb1NwZW5kVHJhbnNhY3Rpb24sXG4gIGhhc2hNZXNzYWdlV2l0aFRhZyxcbiAgYnVpbGRUb1NwZW5kVHJhbnNhY3Rpb25Gcm9tQ2hhaW5BbmRJbmRleCxcbn0gZnJvbSAnLi4vLi4vc3JjL2JpcDMyMic7XG5cbmltcG9ydCB7IEJJUDMyMl9QQVlNRU5UX1AyV1BLSF9GSVhUVVJFIH0gZnJvbSAnLi9iaXAzMjIudXRpbHMnO1xuXG5kZXNjcmliZSgndG9fc3BlbmQnLCBmdW5jdGlvbiAoKSB7XG4gIGRlc2NyaWJlKCdNZXNzYWdlIGhhc2hpbmcnLCBmdW5jdGlvbiAoKSB7XG4gICAgLy8gVGVzdCB2ZWN0b3JzIGZyb20gQklQMzIyXG4gICAgLy8gU291cmNlOiBodHRwczovL2dpdGh1Yi5jb20vYml0Y29pbi9iaXBzL2Jsb2IvbWFzdGVyL2JpcC0wMzIyLm1lZGlhd2lraSNtZXNzYWdlLWhhc2hpbmdcbiAgICBjb25zdCBmaXh0dXJlcyA9IFtcbiAgICAgIHtcbiAgICAgICAgbWVzc2FnZTogJycsXG4gICAgICAgIGhhc2g6ICdjOTBjMjY5YzRmOGZjYmU2ODgwZjcyYTcyMWRkZmJmMTkxNDI2OGE3OTRjYmIyMWNmYWZlZTEzNzcwYWUxOWYxJyxcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIG1lc3NhZ2U6ICdIZWxsbyBXb3JsZCcsXG4gICAgICAgIGhhc2g6ICdmMGViMDNiMWE3NWFjNmQ5ODQ3ZjU1YzYyNGE5OTE2OWI1ZGNjYmEyYTMxZjViMjNiZWE3N2JhMjcwZGUwYTdhJyxcbiAgICAgIH0sXG4gICAgXTtcbiAgICBmaXh0dXJlcy5mb3JFYWNoKCh7IG1lc3NhZ2UsIGhhc2ggfSkgPT4ge1xuICAgICAgaXQoYHNob3VsZCBoYXNoIHRoZSBtZXNzYWdlIFwiJHttZXNzYWdlfVwiYCwgZnVuY3Rpb24gKCkge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBoYXNoTWVzc2FnZVdpdGhUYWcoQnVmZmVyLmZyb20obWVzc2FnZSkpO1xuICAgICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKFxuICAgICAgICAgIHJlc3VsdC50b1N0cmluZygnaGV4JyksXG4gICAgICAgICAgaGFzaCxcbiAgICAgICAgICBgSGFzaCBmb3IgbWVzc2FnZSBcIiR7bWVzc2FnZX1cIiBkb2VzIG5vdCBtYXRjaCBleHBlY3RlZCB2YWx1ZWBcbiAgICAgICAgKTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZSgnYnVpbGQgdG9fc3BlbmQgdHJhbnNhY3Rpb24nLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3Qgc2NyaXB0UHViS2V5ID0gQklQMzIyX1BBWU1FTlRfUDJXUEtIX0ZJWFRVUkUub3V0cHV0IGFzIEJ1ZmZlcjtcblxuICAgIC8vIFNvdXJjZTogaHR0cHM6Ly9naXRodWIuY29tL2JpdGNvaW4vYmlwcy9ibG9iL21hc3Rlci9iaXAtMDMyMi5tZWRpYXdpa2kjdHJhbnNhY3Rpb24taGFzaGVzXG4gICAgY29uc3QgZml4dHVyZXMgPSBbXG4gICAgICB7XG4gICAgICAgIG1lc3NhZ2U6ICcnLFxuICAgICAgICB0eGlkOiAnYzU2ODBhYTY5YmI4ZDg2MGJmODJkNGU5Y2QzNTA0YjU1ZGRlMDE4ZGU3NjVhOTFiYjU2NjI4M2M1NDVhOTlhNycsXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBtZXNzYWdlOiAnSGVsbG8gV29ybGQnLFxuICAgICAgICB0eGlkOiAnYjc5ZDE5Njc0MGFkNTIxNzc3MWMxMDk4ZmM0YTRiNTFlMDUzNWMzMjIzNmM3MWYxZWE0ZDYxYTJkNjAzMzUyYicsXG4gICAgICB9LFxuICAgIF07XG5cbiAgICBmaXh0dXJlcy5mb3JFYWNoKCh7IG1lc3NhZ2UsIHR4aWQgfSkgPT4ge1xuICAgICAgaXQoYHNob3VsZCBidWlsZCBhIHRvX3NwZW5kIHRyYW5zYWN0aW9uIGZvciBtZXNzYWdlIFwiJHttZXNzYWdlfVwiYCwgZnVuY3Rpb24gKCkge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBidWlsZFRvU3BlbmRUcmFuc2FjdGlvbihzY3JpcHRQdWJLZXksIEJ1ZmZlci5mcm9tKG1lc3NhZ2UpKTtcbiAgICAgICAgY29uc3QgY29tcHV0ZWRUeGlkID0gcmVzdWx0LmdldElkKCk7XG4gICAgICAgIGFzc2VydC5zdHJpY3RFcXVhbChjb21wdXRlZFR4aWQsIHR4aWQsIGBUcmFuc2FjdGlvbiBJRCBmb3IgbWVzc2FnZSBcIiR7bWVzc2FnZX1cIiBkb2VzIG5vdCBtYXRjaCBleHBlY3RlZCB2YWx1ZWApO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdidWlsZFRvU3BlbmRUcmFuc2FjdGlvbkZyb21DaGFpbkFuZEluZGV4JywgZnVuY3Rpb24gKCkge1xuICAgIGRlc2NyaWJlKCdzaG91bGQgYnVpbGQgYSB0b19zcGVuZCB0cmFuc2FjdGlvbiBmb3IgYSBub24tVGFwcm9vdCBjaGFpbicsIGZ1bmN0aW9uICgpIHtcbiAgICAgIGZ1bmN0aW9uIHJ1bihjaGFpbjogYml0Z28uQ2hhaW5Db2RlKSB7XG4gICAgICAgIGl0KGBzY3JpcHRUeXBlOiAke2JpdGdvLnNjcmlwdFR5cGVGb3JDaGFpbihjaGFpbil9LCBjaGFpbiAke2NoYWlufWAsIGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICBjb25zdCB0eCA9IGJ1aWxkVG9TcGVuZFRyYW5zYWN0aW9uRnJvbUNoYWluQW5kSW5kZXgoXG4gICAgICAgICAgICB0ZXN0dXRpbC5nZXREZWZhdWx0V2FsbGV0S2V5cygpLFxuICAgICAgICAgICAgMjAsXG4gICAgICAgICAgICAwLFxuICAgICAgICAgICAgQnVmZmVyLmZyb20oJ0hlbGxvIFdvcmxkJylcbiAgICAgICAgICApO1xuICAgICAgICAgIGNvbnN0IGV4cGVjdGVkU2NyaXB0UHViS2V5ID0gYml0Z28ub3V0cHV0U2NyaXB0c1xuICAgICAgICAgICAgLmNyZWF0ZU91dHB1dFNjcmlwdDJvZjModGVzdHV0aWwuZ2V0RGVmYXVsdFdhbGxldEtleXMoKS5kZXJpdmVGb3JDaGFpbkFuZEluZGV4KDIwLCAwKS5wdWJsaWNLZXlzLCAncDJ3c2gnKVxuICAgICAgICAgICAgLnNjcmlwdFB1YktleS50b1N0cmluZygpO1xuICAgICAgICAgIGNvbnN0IHNjcmlwdFB1YktleUZyb21UeCA9IHR4Lm91dHNbMF0uc2NyaXB0LnRvU3RyaW5nKCk7XG4gICAgICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChcbiAgICAgICAgICAgIHNjcmlwdFB1YktleUZyb21UeCxcbiAgICAgICAgICAgIGV4cGVjdGVkU2NyaXB0UHViS2V5LFxuICAgICAgICAgICAgJ1NjcmlwdFB1YktleSBkb2VzIG5vdCBtYXRjaCBleHBlY3RlZCB2YWx1ZSdcbiAgICAgICAgICApO1xuICAgICAgICB9KTtcbiAgICAgIH1cblxuICAgICAgKFswLCAxLCAxMCwgMTEsIDIwLCAyMV0gYXMgYml0Z28uQ2hhaW5Db2RlW10pLmZvckVhY2goKGNoYWluKSA9PiB7XG4gICAgICAgIHJ1bihjaGFpbik7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../test/bip322/utils.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
const assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
41
|
+
const bip322_1 = require("../../src/bip322");
|
|
42
|
+
const bip322_utils_1 = require("./bip322.utils");
|
|
43
|
+
describe('BIP322 Proof utils', function () {
|
|
44
|
+
it('should add a BIP322 proof message to a PSBT input', function () {
|
|
45
|
+
const psbt = utxolib.bitgo.createPsbtFromBuffer(bip322_utils_1.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT.toBuffer(), utxolib.networks.bitcoin);
|
|
46
|
+
const proprietaryKeyVals = utxolib.bitgo.getPsbtInputProprietaryKeyVals(psbt.data.inputs[0], {
|
|
47
|
+
identifier: utxolib.bitgo.PSBT_PROPRIETARY_IDENTIFIER,
|
|
48
|
+
subtype: utxolib.bitgo.ProprietaryKeySubtype.BIP322_MESSAGE,
|
|
49
|
+
});
|
|
50
|
+
assert_1.default.ok(proprietaryKeyVals.length === 1);
|
|
51
|
+
assert_1.default.ok(proprietaryKeyVals[0].value.equals(Buffer.from('Hello World')));
|
|
52
|
+
assert_1.default.ok(proprietaryKeyVals[0].key.keydata.length === 0); // keydata should be empty
|
|
53
|
+
assert_1.default.ok(proprietaryKeyVals[0].key.identifier === utxolib.bitgo.PSBT_PROPRIETARY_IDENTIFIER);
|
|
54
|
+
assert_1.default.ok(proprietaryKeyVals[0].key.subtype === utxolib.bitgo.ProprietaryKeySubtype.BIP322_MESSAGE);
|
|
55
|
+
});
|
|
56
|
+
it('should return the input index of a BIP322 proof message', function () {
|
|
57
|
+
const psbt = utxolib.bitgo.createPsbtFromBuffer(bip322_utils_1.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT.toBuffer(), utxolib.networks.bitcoin);
|
|
58
|
+
const messageBuffer = (0, bip322_1.getBip322ProofMessageAtIndex)(psbt, 0);
|
|
59
|
+
assert_1.default.ok(messageBuffer, 'Message buffer should not be undefined');
|
|
60
|
+
assert_1.default.deepStrictEqual(messageBuffer.toString('utf-8'), 'Hello World', 'Message does not match expected value');
|
|
61
|
+
});
|
|
62
|
+
describe('isBip322ProofCheck', function () {
|
|
63
|
+
it('should work for PSBTs', function () {
|
|
64
|
+
const psbt = utxolib.bitgo.createPsbtFromBuffer(bip322_utils_1.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT.toBuffer(), utxolib.networks.bitcoin);
|
|
65
|
+
assert_1.default.ok((0, bip322_1.isBip322ProofCheck)(psbt), 'Expected PSBT to be a valid BIP322 proof');
|
|
66
|
+
assert_1.default.deepEqual((0, bip322_1.isBip322ProofCheck)(utxolib.testutil.constructPsbt([{ scriptType: 'taprootKeyPathSpend', value: BigInt(1000) }], [{ scriptType: 'p2sh', value: BigInt(900) }], utxolib.networks.bitcoin, utxolib.testutil.getDefaultWalletKeys(), 'unsigned')), false);
|
|
67
|
+
});
|
|
68
|
+
it('should work for Transactions', function () {
|
|
69
|
+
const psbt = utxolib.bitgo.createPsbtFromBuffer(bip322_utils_1.BIP322_FIXTURE_HELLO_WORLD_TOSIGN_PSBT.toBuffer(), utxolib.networks.bitcoin);
|
|
70
|
+
// Cannot extract the transaction because it has no signatures
|
|
71
|
+
const tx = psbt.getUnsignedTx();
|
|
72
|
+
assert_1.default.ok((0, bip322_1.isBip322ProofCheck)(tx), 'Expected Transaction to be a valid BIP322 proof');
|
|
73
|
+
assert_1.default.deepEqual((0, bip322_1.isBip322ProofCheck)(utxolib.testutil
|
|
74
|
+
.constructPsbt([{ scriptType: 'taprootKeyPathSpend', value: BigInt(1000) }], [{ scriptType: 'p2sh', value: BigInt(900) }], utxolib.networks.bitcoin, utxolib.testutil.getDefaultWalletKeys(), 'unsigned')
|
|
75
|
+
.getUnsignedTx()), false);
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0L2JpcDMyMi91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLG9EQUE0QjtBQUU1Qiw4REFBZ0Q7QUFFaEQsNkNBQW9GO0FBRXBGLGlEQUF3RTtBQUV4RSxRQUFRLENBQUMsb0JBQW9CLEVBQUU7SUFDN0IsRUFBRSxDQUFDLG1EQUFtRCxFQUFFO1FBQ3RELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQzdDLHFEQUFzQyxDQUFDLFFBQVEsRUFBRSxFQUNqRCxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FDekIsQ0FBQztRQUVGLE1BQU0sa0JBQWtCLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyw4QkFBOEIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUMzRixVQUFVLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkI7WUFDckQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQUMsY0FBYztTQUM1RCxDQUFDLENBQUM7UUFFSCxnQkFBTSxDQUFDLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDM0MsZ0JBQU0sQ0FBQyxFQUFFLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRSxnQkFBTSxDQUFDLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtRQUNyRixnQkFBTSxDQUFD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QUNBLGFBQWEsRUFBRSxDQUNuQixFQUNELEtBQUssQ0FDTixDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuXG5pbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuaW1wb3J0IHsgZ2V0QmlwMzIyUHJvb2ZNZXNzYWdlQXRJbmRleCwgaXNCaXAzMjJQcm9vZkNoZWNrIH0gZnJvbSAnLi4vLi4vc3JjL2JpcDMyMic7XG5cbmltcG9ydCB7IEJJUDMyMl9GSVhUVVJFX0hFTExPX1dPUkxEX1RPU0lHTl9QU0JUIH0gZnJvbSAnLi9iaXAzMjIudXRpbHMnO1xuXG5kZXNjcmliZSgnQklQMzIyIFByb29mIHV0aWxzJywgZnVuY3Rpb24gKCkge1xuICBpdCgnc2hvdWxkIGFkZCBhIEJJUDMyMiBwcm9vZiBtZXNzYWdlIHRvIGEgUFNCVCBpbnB1dCcsIGZ1bmN0aW9uICgpIHtcbiAgICBjb25zdCBwc2J0ID0gdXR4b2xpYi5iaXRnby5jcmVhdGVQc2J0RnJvbUJ1ZmZlcihcbiAgICAgIEJJUDMyMl9GSVhUVVJFX0hFTExPX1dPUkxEX1RPU0lHTl9QU0JULnRvQnVmZmVyKCksXG4gICAgICB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5cbiAgICApO1xuXG4gICAgY29uc3QgcHJvcHJpZXRhcnlLZXlWYWxzID0gdXR4b2xpYi5iaXRnby5nZXRQc2J0SW5wdXRQcm9wcmlldGFyeUtleVZhbHMocHNidC5kYXRhLmlucHV0c1swXSwge1xuICAgICAgaWRlbnRpZmllcjogdXR4b2xpYi5iaXRnby5QU0JUX1BST1BSSUVUQVJZX0lERU5USUZJRVIsXG4gICAgICBzdWJ0eXBlOiB1dHhvbGliLmJpdGdvLlByb3ByaWV0YXJ5S2V5U3VidHlwZS5CSVAzMjJfTUVTU0FHRSxcbiAgICB9KTtcblxuICAgIGFzc2VydC5vayhwcm9wcmlldGFyeUtleVZhbHMubGVuZ3RoID09PSAxKTtcbiAgICBhc3NlcnQub2socHJvcHJpZXRhcnlLZXlWYWxzWzBdLnZhbHVlLmVxdWFscyhCdWZmZXIuZnJvbSgnSGVsbG8gV29ybGQnKSkpO1xuICAgIGFzc2VydC5vayhwcm9wcmlldGFyeUtleVZhbHNbMF0ua2V5LmtleWRhdGEubGVuZ3RoID09PSAwKTsgLy8ga2V5ZGF0YSBzaG91bGQgYmUgZW1wdHlcbiAgICBhc3NlcnQub2socHJvcHJpZXRhcnlLZXlWYWxzWzBdLmtleS5pZGVudGlmaWVyID09PSB1dHhvbGliLmJpdGdvLlBTQlRfUFJPUFJJRVRBUllfSURFTlRJRklFUik7XG4gICAgYXNzZXJ0Lm9rKHByb3ByaWV0YXJ5S2V5VmFsc1swXS5rZXkuc3VidHlwZSA9PT0gdXR4b2xpYi5iaXRnby5Qcm9wcmlldGFyeUtleVN1YnR5cGUuQklQMzIyX01FU1NBR0UpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIHJldHVybiB0aGUgaW5wdXQgaW5kZXggb2YgYSBCSVAzMjIgcHJvb2YgbWVzc2FnZScsIGZ1bmN0aW9uICgpIHtcbiAgICBjb25zdCBwc2J0ID0gdXR4b2xpYi5iaXRnby5jcmVhdGVQc2J0RnJvbUJ1ZmZlcihcbiAgICAgIEJJUDMyMl9GSVhUVVJFX0hFTExPX1dPUkxEX1RPU0lHTl9QU0JULnRvQnVmZmVyKCksXG4gICAgICB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5cbiAgICApO1xuXG4gICAgY29uc3QgbWVzc2FnZUJ1ZmZlciA9IGdldEJpcDMyMlByb29mTWVzc2FnZUF0SW5kZXgocHNidCwgMCk7XG4gICAgYXNzZXJ0Lm9rKG1lc3NhZ2VCdWZmZXIsICdNZXNzYWdlIGJ1ZmZlciBzaG91bGQgbm90IGJlIHVuZGVmaW5lZCcpO1xuICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwobWVzc2FnZUJ1ZmZlci50b1N0cmluZygndXRmLTgnKSwgJ0hlbGxvIFdvcmxkJywgJ01lc3NhZ2UgZG9lcyBub3QgbWF0Y2ggZXhwZWN0ZWQgdmFsdWUnKTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ2lzQmlwMzIyUHJvb2ZDaGVjaycsIGZ1bmN0aW9uICgpIHtcbiAgICBpdCgnc2hvdWxkIHdvcmsgZm9yIFBTQlRzJywgZnVuY3Rpb24gKCkge1xuICAgICAgY29uc3QgcHNidCA9IHV0eG9saWIuYml0Z28uY3JlYXRlUHNidEZyb21CdWZmZXIoXG4gICAgICAgIEJJUDMyMl9GSVhUVVJFX0hFTExPX1dPUkxEX1RPU0lHTl9QU0JULnRvQnVmZmVyKCksXG4gICAgICAgIHV0eG9saWIubmV0d29ya3MuYml0Y29pblxuICAgICAgKTtcbiAgICAgIGFzc2VydC5vayhpc0JpcDMyMlByb29mQ2hlY2socHNidCksICdFeHBlY3RlZCBQU0JUIHRvIGJlIGEgdmFsaWQgQklQMzIyIHByb29mJyk7XG4gICAgICBhc3NlcnQuZGVlcEVxdWFsKFxuICAgICAgICBpc0JpcDMyMlByb29mQ2hlY2soXG4gICAgICAgICAgdXR4b2xpYi50ZXN0dXRpbC5jb25zdHJ1Y3RQc2J0KFxuICAgICAgICAgICAgW3sgc2NyaXB0VHlwZTogJ3RhcHJvb3RLZXlQYXRoU3BlbmQnLCB2YWx1ZTogQmlnSW50KDEwMDApIH1dLFxuICAgICAgICAgICAgW3sgc2NyaXB0VHlwZTogJ3Ayc2gnLCB2YWx1ZTogQmlnSW50KDkwMCkgfV0sXG4gICAgICAgICAgICB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW4sXG4gICAgICAgICAgICB1dHhvbGliLnRlc3R1dGlsLmdldERlZmF1bHRXYWxsZXRLZXlzKCksXG4gICAgICAgICAgICAndW5zaWduZWQnXG4gICAgICAgICAgKVxuICAgICAgICApLFxuICAgICAgICBmYWxzZVxuICAgICAgKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgd29yayBmb3IgVHJhbnNhY3Rpb25zJywgZnVuY3Rpb24gKCkge1xuICAgICAgY29uc3QgcHNidCA9IHV0eG9saWIuYml0Z28uY3JlYXRlUHNidEZyb21CdWZmZXIoXG4gICAgICAgIEJJUDMyMl9GSVhUVVJFX0hFTExPX1dPUkxEX1RPU0lHTl9QU0JULnRvQnVmZmVyKCksXG4gICAgICAgIHV0eG9saWIubmV0d29ya3MuYml0Y29pblxuICAgICAgKTtcbiAgICAgIC8vIENhbm5vdCBleHRyYWN0IHRoZSB0cmFuc2FjdGlvbiBiZWNhdXNlIGl0IGhhcyBubyBzaWduYXR1cmVzXG4gICAgICBjb25zdCB0eCA9IHBzYnQuZ2V0VW5zaWduZWRUeCgpO1xuICAgICAgYXNzZXJ0Lm9rKGlzQmlwMzIyUHJvb2ZDaGVjayh0eCksICdFeHBlY3RlZCBUcmFuc2FjdGlvbiB0byBiZSBhIHZhbGlkIEJJUDMyMiBwcm9vZicpO1xuICAgICAgYXNzZXJ0LmRlZXBFcXVhbChcbiAgICAgICAgaXNCaXAzMjJQcm9vZkNoZWNrKFxuICAgICAgICAgIHV0eG9saWIudGVzdHV0aWxcbiAgICAgICAgICAgIC5jb25zdHJ1Y3RQc2J0KFxuICAgICAgICAgICAgICBbeyBzY3JpcHRUeXBlOiAndGFwcm9vdEtleVBhdGhTcGVuZCcsIHZhbHVlOiBCaWdJbnQoMTAwMCkgfV0sXG4gICAgICAgICAgICAgIFt7IHNjcmlwdFR5cGU6ICdwMnNoJywgdmFsdWU6IEJpZ0ludCg5MDApIH1dLFxuICAgICAgICAgICAgICB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW4sXG4gICAgICAgICAgICAgIHV0eG9saWIudGVzdHV0aWwuZ2V0RGVmYXVsdFdhbGxldEtleXMoKSxcbiAgICAgICAgICAgICAgJ3Vuc2lnbmVkJ1xuICAgICAgICAgICAgKVxuICAgICAgICAgICAgLmdldFVuc2lnbmVkVHgoKVxuICAgICAgICApLFxuICAgICAgICBmYWxzZVxuICAgICAgKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verify.d.ts","sourceRoot":"","sources":["../../../../test/bip322/verify.ts"],"names":[],"mappings":""}
|