@bitgo-beta/utxo-core 0.0.0-semantic-release-managed
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/LICENSE +191 -0
- package/README.md +6 -0
- package/dist/src/Output.d.ts +43 -0
- package/dist/src/Output.d.ts.map +1 -0
- package/dist/src/Output.js +60 -0
- package/dist/src/bip322/index.d.ts +5 -0
- package/dist/src/bip322/index.d.ts.map +1 -0
- package/dist/src/bip322/index.js +21 -0
- package/dist/src/bip322/toSign.d.ts +25 -0
- package/dist/src/bip322/toSign.d.ts.map +1 -0
- package/dist/src/bip322/toSign.js +126 -0
- package/dist/src/bip322/toSpend.d.ts +22 -0
- package/dist/src/bip322/toSpend.d.ts.map +1 -0
- package/dist/src/bip322/toSpend.js +72 -0
- package/dist/src/bip322/utils.d.ts +18 -0
- package/dist/src/bip322/utils.d.ts.map +1 -0
- package/dist/src/bip322/utils.js +115 -0
- package/dist/src/bip322/verify.d.ts +12 -0
- package/dist/src/bip322/verify.d.ts.map +1 -0
- package/dist/src/bip322/verify.js +115 -0
- package/dist/src/bip32utils.d.ts +16 -0
- package/dist/src/bip32utils.d.ts.map +1 -0
- package/dist/src/bip32utils.js +71 -0
- package/dist/src/bip65/index.d.ts +2 -0
- package/dist/src/bip65/index.d.ts.map +1 -0
- package/dist/src/bip65/index.js +18 -0
- package/dist/src/bip65/locktime.d.ts +8 -0
- package/dist/src/bip65/locktime.d.ts.map +1 -0
- package/dist/src/bip65/locktime.js +37 -0
- package/dist/src/descriptor/DescriptorMap.d.ts +9 -0
- package/dist/src/descriptor/DescriptorMap.d.ts.map +1 -0
- package/dist/src/descriptor/DescriptorMap.js +9 -0
- package/dist/src/descriptor/Output.d.ts +23 -0
- package/dist/src/descriptor/Output.d.ts.map +1 -0
- package/dist/src/descriptor/Output.js +41 -0
- package/dist/src/descriptor/VirtualSize.d.ts +23 -0
- package/dist/src/descriptor/VirtualSize.d.ts.map +1 -0
- package/dist/src/descriptor/VirtualSize.js +100 -0
- package/dist/src/descriptor/address.d.ts +5 -0
- package/dist/src/descriptor/address.d.ts.map +1 -0
- package/dist/src/descriptor/address.js +48 -0
- package/dist/src/descriptor/derive.d.ts +13 -0
- package/dist/src/descriptor/derive.d.ts.map +1 -0
- package/dist/src/descriptor/derive.js +45 -0
- package/dist/src/descriptor/fromFixedScriptWallet.d.ts +16 -0
- package/dist/src/descriptor/fromFixedScriptWallet.d.ts.map +1 -0
- package/dist/src/descriptor/fromFixedScriptWallet.js +88 -0
- package/dist/src/descriptor/index.d.ts +11 -0
- package/dist/src/descriptor/index.d.ts.map +1 -0
- package/dist/src/descriptor/index.js +27 -0
- package/dist/src/descriptor/parse/PatternMatcher.d.ts +14 -0
- package/dist/src/descriptor/parse/PatternMatcher.d.ts.map +1 -0
- package/dist/src/descriptor/parse/PatternMatcher.js +60 -0
- package/dist/src/descriptor/psbt/assertSatisfiable.d.ts +20 -0
- package/dist/src/descriptor/psbt/assertSatisfiable.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/assertSatisfiable.js +74 -0
- package/dist/src/descriptor/psbt/createPsbt.d.ts +23 -0
- package/dist/src/descriptor/psbt/createPsbt.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/createPsbt.js +107 -0
- package/dist/src/descriptor/psbt/findDescriptors.d.ts +26 -0
- package/dist/src/descriptor/psbt/findDescriptors.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/findDescriptors.js +98 -0
- package/dist/src/descriptor/psbt/index.d.ts +7 -0
- package/dist/src/descriptor/psbt/index.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/index.js +23 -0
- package/dist/src/descriptor/psbt/parse.d.ts +27 -0
- package/dist/src/descriptor/psbt/parse.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/parse.js +87 -0
- package/dist/src/descriptor/psbt/sign.d.ts +26 -0
- package/dist/src/descriptor/psbt/sign.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/sign.js +42 -0
- package/dist/src/descriptor/psbt/wrap.d.ts +12 -0
- package/dist/src/descriptor/psbt/wrap.d.ts.map +1 -0
- package/dist/src/descriptor/psbt/wrap.js +76 -0
- package/dist/src/dustThreshold.d.ts +4 -0
- package/dist/src/dustThreshold.d.ts.map +1 -0
- package/dist/src/dustThreshold.js +134 -0
- package/dist/src/index.d.ts +10 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +49 -0
- package/dist/src/paygo/attestation.d.ts +11 -0
- package/dist/src/paygo/attestation.d.ts.map +1 -0
- package/dist/src/paygo/attestation.js +58 -0
- package/dist/src/paygo/index.d.ts +3 -0
- package/dist/src/paygo/index.d.ts.map +1 -0
- package/dist/src/paygo/index.js +19 -0
- package/dist/src/paygo/parsePayGoAttestation.d.ts +16 -0
- package/dist/src/paygo/parsePayGoAttestation.d.ts.map +1 -0
- package/dist/src/paygo/parsePayGoAttestation.js +50 -0
- package/dist/src/paygo/psbt/Errors.d.ts +22 -0
- package/dist/src/paygo/psbt/Errors.d.ts.map +1 -0
- package/dist/src/paygo/psbt/Errors.js +44 -0
- package/dist/src/paygo/psbt/index.d.ts +2 -0
- package/dist/src/paygo/psbt/index.d.ts.map +1 -0
- package/dist/src/paygo/psbt/index.js +18 -0
- package/dist/src/paygo/psbt/payGoAddressProof.d.ts +29 -0
- package/dist/src/paygo/psbt/payGoAddressProof.d.ts.map +1 -0
- package/dist/src/paygo/psbt/payGoAddressProof.js +124 -0
- package/dist/src/testutil/descriptor/descriptors.d.ts +13 -0
- package/dist/src/testutil/descriptor/descriptors.d.ts.map +1 -0
- package/dist/src/testutil/descriptor/descriptors.js +162 -0
- package/dist/src/testutil/descriptor/index.d.ts +4 -0
- package/dist/src/testutil/descriptor/index.d.ts.map +1 -0
- package/dist/src/testutil/descriptor/index.js +20 -0
- package/dist/src/testutil/descriptor/mock.utils.d.ts +36 -0
- package/dist/src/testutil/descriptor/mock.utils.d.ts.map +1 -0
- package/dist/src/testutil/descriptor/mock.utils.js +92 -0
- package/dist/src/testutil/descriptor/psbt.utils.d.ts +4 -0
- package/dist/src/testutil/descriptor/psbt.utils.d.ts.map +1 -0
- package/dist/src/testutil/descriptor/psbt.utils.js +21 -0
- package/dist/src/testutil/fixtures.utils.d.ts +15 -0
- package/dist/src/testutil/fixtures.utils.d.ts.map +1 -0
- package/dist/src/testutil/fixtures.utils.js +127 -0
- package/dist/src/testutil/generatePayGoAttestationProof.utils.d.ts +12 -0
- package/dist/src/testutil/generatePayGoAttestationProof.utils.d.ts.map +1 -0
- package/dist/src/testutil/generatePayGoAttestationProof.utils.js +38 -0
- package/dist/src/testutil/index.d.ts +6 -0
- package/dist/src/testutil/index.d.ts.map +1 -0
- package/dist/src/testutil/index.js +22 -0
- package/dist/src/testutil/key.utils.d.ts +16 -0
- package/dist/src/testutil/key.utils.d.ts.map +1 -0
- package/dist/src/testutil/key.utils.js +59 -0
- package/dist/src/testutil/toPlainObject.utils.d.ts +11 -0
- package/dist/src/testutil/toPlainObject.utils.d.ts.map +1 -0
- package/dist/src/testutil/toPlainObject.utils.js +89 -0
- package/dist/src/testutil/trimMessagePrefix.d.ts +11 -0
- package/dist/src/testutil/trimMessagePrefix.d.ts.map +1 -0
- package/dist/src/testutil/trimMessagePrefix.js +60 -0
- package/dist/src/xOnlyPubkey.d.ts +2 -0
- package/dist/src/xOnlyPubkey.d.ts.map +1 -0
- package/dist/src/xOnlyPubkey.js +18 -0
- package/package.json +63 -0
|
@@ -0,0 +1,42 @@
|
|
|
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
|
+
exports.getNewSignatureCountForInput = getNewSignatureCountForInput;
|
|
7
|
+
exports.getNewSignatureCount = getNewSignatureCount;
|
|
8
|
+
exports.signWithKey = signWithKey;
|
|
9
|
+
const assert_1 = __importDefault(require("assert"));
|
|
10
|
+
/**
|
|
11
|
+
* @param signResult
|
|
12
|
+
* @return the number of new signatures created by the signResult for a single input
|
|
13
|
+
*/
|
|
14
|
+
function getNewSignatureCountForInput(signResult) {
|
|
15
|
+
if ('Schnorr' in signResult) {
|
|
16
|
+
return signResult.Schnorr.length;
|
|
17
|
+
}
|
|
18
|
+
if ('Ecdsa' in signResult) {
|
|
19
|
+
return signResult.Ecdsa.length;
|
|
20
|
+
}
|
|
21
|
+
throw new Error(`Unknown signature type ${Object.keys(signResult).join(', ')}`);
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* @param signResult
|
|
25
|
+
* @return the number of new signatures created by the signResult
|
|
26
|
+
*/
|
|
27
|
+
function getNewSignatureCount(signResult) {
|
|
28
|
+
return Object.values(signResult).reduce((sum, signatures) => sum + getNewSignatureCountForInput(signatures), 0);
|
|
29
|
+
}
|
|
30
|
+
/** Convenience function to sign a PSBT with a key */
|
|
31
|
+
function signWithKey(psbt, key) {
|
|
32
|
+
// we need to do casting here because the type definitions in wasm-miniscript are a little bit buggy
|
|
33
|
+
if (Buffer.isBuffer(key)) {
|
|
34
|
+
return psbt.signWithPrv(key);
|
|
35
|
+
}
|
|
36
|
+
if ('toBase58' in key) {
|
|
37
|
+
return psbt.signWithXprv(key.toBase58());
|
|
38
|
+
}
|
|
39
|
+
(0, assert_1.default)(key.privateKey);
|
|
40
|
+
return psbt.signWithPrv(key.privateKey);
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kZXNjcmlwdG9yL3BzYnQvc2lnbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQWVBLG9FQVFDO0FBTUQsb0RBRUM7QUFLRCxrQ0FVQztBQTlDRCxvREFBNEI7QUFXNUI7OztHQUdHO0FBQ0gsU0FBZ0IsNEJBQTRCLENBQUMsVUFBK0I7SUFDMUUsSUFBSSxTQUFTLElBQUksVUFBVSxFQUFFLENBQUM7UUFDNUIsT0FBTyxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUNuQyxDQUFDO0lBQ0QsSUFBSSxPQUFPLElBQUksVUFBVSxFQUFFLENBQUM7UUFDMUIsT0FBTyxVQUFVLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQztJQUNqQyxDQUFDO0lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQywwQkFBMEIsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQ2xGLENBQUM7QUFFRDs7O0dBR0c7QUFDSCxTQUFnQixvQkFBb0IsQ0FBQyxVQUEwQjtJQUM3RCxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLFVBQVUsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLDRCQUE0QixDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ2xILENBQUM7QUFJRCxxREFBcUQ7QUFDckQsU0FBZ0IsV0FBVyxDQUFDLElBQWMsRUFBRSxHQUFRO0lBQ2xELG9HQUFvRztJQUNwRyxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUN6QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUE4QixDQUFDO0lBQzVELENBQUM7SUFDRCxJQUFJLFVBQVUsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUN0QixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxDQUE4QixDQUFDO0lBQ3hFLENBQUM7SUFDRCxJQUFBLGdCQUFNLEVBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3ZCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUE4QixDQUFDO0FBQ3ZFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgUHNidCBhcyBXYXNtUHNidCB9IGZyb20gJ0BiaXRnby93YXNtLW1pbmlzY3JpcHQnO1xuXG4vKiogVGhlc2UgY2FuIGJlIHJlcGxhY2VkIHdoZW4gQGJpdGdvL3dhc20tbWluaXNjcmlwdCBpcyB1cGRhdGVkICovXG5leHBvcnQgdHlwZSBTaWduUHNidElucHV0UmVzdWx0ID0geyBTY2hub3JyOiBzdHJpbmdbXSB9IHwgeyBFY2RzYTogc3RyaW5nW10gfTtcbmV4cG9ydCB0eXBlIFNpZ25Qc2J0UmVzdWx0ID0ge1xuICBbaW5wdXRJbmRleDogbnVtYmVyXTogU2lnblBzYnRJbnB1dFJlc3VsdDtcbn07XG5cbi8qKlxuICogQHBhcmFtIHNpZ25SZXN1bHRcbiAqIEByZXR1cm4gdGhlIG51bWJlciBvZiBuZXcgc2lnbmF0dXJlcyBjcmVhdGVkIGJ5IHRoZSBzaWduUmVzdWx0IGZvciBhIHNpbmdsZSBpbnB1dFxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0TmV3U2lnbmF0dXJlQ291bnRGb3JJbnB1dChzaWduUmVzdWx0OiBTaWduUHNidElucHV0UmVzdWx0KTogbnVtYmVyIHtcbiAgaWYgKCdTY2hub3JyJyBpbiBzaWduUmVzdWx0KSB7XG4gICAgcmV0dXJuIHNpZ25SZXN1bHQuU2Nobm9yci5sZW5ndGg7XG4gIH1cbiAgaWYgKCdFY2RzYScgaW4gc2lnblJlc3VsdCkge1xuICAgIHJldHVybiBzaWduUmVzdWx0LkVjZHNhLmxlbmd0aDtcbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoYFVua25vd24gc2lnbmF0dXJlIHR5cGUgJHtPYmplY3Qua2V5cyhzaWduUmVzdWx0KS5qb2luKCcsICcpfWApO1xufVxuXG4vKipcbiAqIEBwYXJhbSBzaWduUmVzdWx0XG4gKiBAcmV0dXJuIHRoZSBudW1iZXIgb2YgbmV3IHNpZ25hdHVyZXMgY3JlYXRlZCBieSB0aGUgc2lnblJlc3VsdFxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0TmV3U2lnbmF0dXJlQ291bnQoc2lnblJlc3VsdDogU2lnblBzYnRSZXN1bHQpOiBudW1iZXIge1xuICByZXR1cm4gT2JqZWN0LnZhbHVlcyhzaWduUmVzdWx0KS5yZWR1Y2UoKHN1bSwgc2lnbmF0dXJlcykgPT4gc3VtICsgZ2V0TmV3U2lnbmF0dXJlQ291bnRGb3JJbnB1dChzaWduYXR1cmVzKSwgMCk7XG59XG5cbnR5cGUgS2V5ID0gQnVmZmVyIHwgdXR4b2xpYi5CSVAzMkludGVyZmFjZSB8IHV0eG9saWIuRUNQYWlySW50ZXJmYWNlO1xuXG4vKiogQ29udmVuaWVuY2UgZnVuY3Rpb24gdG8gc2lnbiBhIFBTQlQgd2l0aCBhIGtleSAqL1xuZXhwb3J0IGZ1bmN0aW9uIHNpZ25XaXRoS2V5KHBzYnQ6IFdhc21Qc2J0LCBrZXk6IEtleSk6IFNpZ25Qc2J0UmVzdWx0IHtcbiAgLy8gd2UgbmVlZCB0byBkbyBjYXN0aW5nIGhlcmUgYmVjYXVzZSB0aGUgdHlwZSBkZWZpbml0aW9ucyBpbiB3YXNtLW1pbmlzY3JpcHQgYXJlIGEgbGl0dGxlIGJpdCBidWdneVxuICBpZiAoQnVmZmVyLmlzQnVmZmVyKGtleSkpIHtcbiAgICByZXR1cm4gcHNidC5zaWduV2l0aFBydihrZXkpIGFzIHVua25vd24gYXMgU2lnblBzYnRSZXN1bHQ7XG4gIH1cbiAgaWYgKCd0b0Jhc2U1OCcgaW4ga2V5KSB7XG4gICAgcmV0dXJuIHBzYnQuc2lnbldpdGhYcHJ2KGtleS50b0Jhc2U1OCgpKSBhcyB1bmtub3duIGFzIFNpZ25Qc2J0UmVzdWx0O1xuICB9XG4gIGFzc2VydChrZXkucHJpdmF0ZUtleSk7XG4gIHJldHVybiBwc2J0LnNpZ25XaXRoUHJ2KGtleS5wcml2YXRlS2V5KSBhcyB1bmtub3duIGFzIFNpZ25Qc2J0UmVzdWx0O1xufVxuIl19
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Psbt as WasmPsbt } from '@bitgo/wasm-miniscript';
|
|
2
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
3
|
+
export declare function toWrappedPsbt(psbt: utxolib.bitgo.UtxoPsbt | utxolib.Psbt | Buffer | Uint8Array): WasmPsbt;
|
|
4
|
+
export declare function toUtxoPsbt(psbt: WasmPsbt | Buffer | Uint8Array, network: utxolib.Network): utxolib.bitgo.UtxoPsbt;
|
|
5
|
+
/**
|
|
6
|
+
* Use `wasm-miniscript` to finalize a PSBT.
|
|
7
|
+
* Miniscript based finalization is more powerful than bitcoinjs-lib's / utxo-lib's finalization
|
|
8
|
+
* and can finalize more complex scripts (e.g. miniscript descriptors).
|
|
9
|
+
* @param psbt
|
|
10
|
+
*/
|
|
11
|
+
export declare function finalizePsbt(psbt: utxolib.bitgo.UtxoPsbt): void;
|
|
12
|
+
//# sourceMappingURL=wrap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wrap.d.ts","sourceRoot":"","sources":["../../../../src/descriptor/psbt/wrap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,IAAI,GAAG,MAAM,GAAG,UAAU,GAAG,QAAQ,CAQzG;AAED,wBAAgB,UAAU,CAAC,IAAI,EAAE,QAAQ,GAAG,MAAM,GAAG,UAAU,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAQjH;AAED;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAU/D"}
|
|
@@ -0,0 +1,76 @@
|
|
|
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
|
+
exports.toWrappedPsbt = toWrappedPsbt;
|
|
37
|
+
exports.toUtxoPsbt = toUtxoPsbt;
|
|
38
|
+
exports.finalizePsbt = finalizePsbt;
|
|
39
|
+
const wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
|
|
40
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
41
|
+
function toWrappedPsbt(psbt) {
|
|
42
|
+
if (psbt instanceof utxolib.bitgo.UtxoPsbt || psbt instanceof utxolib.Psbt) {
|
|
43
|
+
psbt = psbt.toBuffer();
|
|
44
|
+
}
|
|
45
|
+
if (psbt instanceof Buffer || psbt instanceof Uint8Array) {
|
|
46
|
+
return wasm_miniscript_1.Psbt.deserialize(psbt);
|
|
47
|
+
}
|
|
48
|
+
throw new Error('Invalid input');
|
|
49
|
+
}
|
|
50
|
+
function toUtxoPsbt(psbt, network) {
|
|
51
|
+
if (psbt instanceof wasm_miniscript_1.Psbt) {
|
|
52
|
+
psbt = psbt.serialize();
|
|
53
|
+
}
|
|
54
|
+
if (psbt instanceof Buffer || psbt instanceof Uint8Array) {
|
|
55
|
+
return utxolib.bitgo.UtxoPsbt.fromBuffer(Buffer.from(psbt), { network });
|
|
56
|
+
}
|
|
57
|
+
throw new Error('Invalid input');
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Use `wasm-miniscript` to finalize a PSBT.
|
|
61
|
+
* Miniscript based finalization is more powerful than bitcoinjs-lib's / utxo-lib's finalization
|
|
62
|
+
* and can finalize more complex scripts (e.g. miniscript descriptors).
|
|
63
|
+
* @param psbt
|
|
64
|
+
*/
|
|
65
|
+
function finalizePsbt(psbt) {
|
|
66
|
+
if (utxolib.getMainnet(psbt.network) !== utxolib.networks.bitcoin) {
|
|
67
|
+
throw new Error('only bitcoin and testnet are supported');
|
|
68
|
+
}
|
|
69
|
+
const wrappedPsbt = toWrappedPsbt(psbt);
|
|
70
|
+
wrappedPsbt.finalize();
|
|
71
|
+
const unwrappedPsbt = toUtxoPsbt(wrappedPsbt, psbt.network);
|
|
72
|
+
for (let i = 0; i < psbt.data.inputs.length; i++) {
|
|
73
|
+
psbt.data.inputs[i] = unwrappedPsbt.data.inputs[i];
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid3JhcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kZXNjcmlwdG9yL3BzYnQvd3JhcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUdBLHNDQVFDO0FBRUQsZ0NBUUM7QUFRRCxvQ0FVQztBQXZDRCw0REFBMEQ7QUFDMUQsOERBQWdEO0FBRWhELFNBQWdCLGFBQWEsQ0FBQyxJQUFpRTtJQUM3RixJQUFJLElBQUksWUFBWSxPQUFPLENBQUMsS0FBSyxDQUFDLFFBQVEsSUFBSSxJQUFJLFlBQVksT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzNFLElBQUksR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUNELElBQUksSUFBSSxZQUFZLE1BQU0sSUFBSSxJQUFJLFlBQVksVUFBVSxFQUFFLENBQUM7UUFDekQsT0FBTyxzQkFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztBQUNuQyxDQUFDO0FBRUQsU0FBZ0IsVUFBVSxDQUFDLElBQW9DLEVBQUUsT0FBd0I7SUFDdkYsSUFBSSxJQUFJLFlBQVksc0JBQVEsRUFBRSxDQUFDO1FBQzdCLElBQUksR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDMUIsQ0FBQztJQUNELElBQUksSUFBSSxZQUFZLE1BQU0sSUFBSSxJQUFJLFlBQVksVUFBVSxFQUFFLENBQUM7UUFDekQsT0FBTyxPQUFPLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQztJQUNELE1BQU0sSUFBSSxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUM7QUFDbkMsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBZ0IsWUFBWSxDQUFDLElBQTRCO0lBQ3ZELElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNsRSxNQUFNLElBQUksS0FBSyxDQUFDLHdDQUF3QyxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUNELE1BQU0sV0FBVyxHQUFHLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDdkIsTUFBTSxhQUFhLEdBQUcsVUFBVSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDNUQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQ2pELElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLGFBQWEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3JELENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHNidCBhcyBXYXNtUHNidCB9IGZyb20gJ0BiaXRnby93YXNtLW1pbmlzY3JpcHQnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5cbmV4cG9ydCBmdW5jdGlvbiB0b1dyYXBwZWRQc2J0KHBzYnQ6IHV0eG9saWIuYml0Z28uVXR4b1BzYnQgfCB1dHhvbGliLlBzYnQgfCBCdWZmZXIgfCBVaW50OEFycmF5KTogV2FzbVBzYnQge1xuICBpZiAocHNidCBpbnN0YW5jZW9mIHV0eG9saWIuYml0Z28uVXR4b1BzYnQgfHwgcHNidCBpbnN0YW5jZW9mIHV0eG9saWIuUHNidCkge1xuICAgIHBzYnQgPSBwc2J0LnRvQnVmZmVyKCk7XG4gIH1cbiAgaWYgKHBzYnQgaW5zdGFuY2VvZiBCdWZmZXIgfHwgcHNidCBpbnN0YW5jZW9mIFVpbnQ4QXJyYXkpIHtcbiAgICByZXR1cm4gV2FzbVBzYnQuZGVzZXJpYWxpemUocHNidCk7XG4gIH1cbiAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGlucHV0Jyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b1V0eG9Qc2J0KHBzYnQ6IFdhc21Qc2J0IHwgQnVmZmVyIHwgVWludDhBcnJheSwgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrKTogdXR4b2xpYi5iaXRnby5VdHhvUHNidCB7XG4gIGlmIChwc2J0IGluc3RhbmNlb2YgV2FzbVBzYnQpIHtcbiAgICBwc2J0ID0gcHNidC5zZXJpYWxpemUoKTtcbiAgfVxuICBpZiAocHNidCBpbnN0YW5jZW9mIEJ1ZmZlciB8fCBwc2J0IGluc3RhbmNlb2YgVWludDhBcnJheSkge1xuICAgIHJldHVybiB1dHhvbGliLmJpdGdvLlV0eG9Qc2J0LmZyb21CdWZmZXIoQnVmZmVyLmZyb20ocHNidCksIHsgbmV0d29yayB9KTtcbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgaW5wdXQnKTtcbn1cblxuLyoqXG4gKiBVc2UgYHdhc20tbWluaXNjcmlwdGAgdG8gZmluYWxpemUgYSBQU0JULlxuICogTWluaXNjcmlwdCBiYXNlZCBmaW5hbGl6YXRpb24gaXMgbW9yZSBwb3dlcmZ1bCB0aGFuIGJpdGNvaW5qcy1saWIncyAvIHV0eG8tbGliJ3MgZmluYWxpemF0aW9uXG4gKiBhbmQgY2FuIGZpbmFsaXplIG1vcmUgY29tcGxleCBzY3JpcHRzIChlLmcuIG1pbmlzY3JpcHQgZGVzY3JpcHRvcnMpLlxuICogQHBhcmFtIHBzYnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGZpbmFsaXplUHNidChwc2J0OiB1dHhvbGliLmJpdGdvLlV0eG9Qc2J0KTogdm9pZCB7XG4gIGlmICh1dHhvbGliLmdldE1haW5uZXQocHNidC5uZXR3b3JrKSAhPT0gdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdvbmx5IGJpdGNvaW4gYW5kIHRlc3RuZXQgYXJlIHN1cHBvcnRlZCcpO1xuICB9XG4gIGNvbnN0IHdyYXBwZWRQc2J0ID0gdG9XcmFwcGVkUHNidChwc2J0KTtcbiAgd3JhcHBlZFBzYnQuZmluYWxpemUoKTtcbiAgY29uc3QgdW53cmFwcGVkUHNidCA9IHRvVXR4b1BzYnQod3JhcHBlZFBzYnQsIHBzYnQubmV0d29yayk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgcHNidC5kYXRhLmlucHV0cy5sZW5ndGg7IGkrKykge1xuICAgIHBzYnQuZGF0YS5pbnB1dHNbaV0gPSB1bndyYXBwZWRQc2J0LmRhdGEuaW5wdXRzW2ldO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
2
|
+
export declare function getDustThresholdSat(network: utxolib.Network, outputSize: number, isWitness: boolean): number;
|
|
3
|
+
export declare function getDustThresholdSatForOutputScript(network: utxolib.Network, script: Buffer): number;
|
|
4
|
+
//# sourceMappingURL=dustThreshold.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dustThreshold.d.ts","sourceRoot":"","sources":["../../src/dustThreshold.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AA8IhD,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,GAAG,MAAM,CAU5G;AAED,wBAAgB,kCAAkC,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAEnG"}
|
|
@@ -0,0 +1,134 @@
|
|
|
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
|
+
exports.getDustThresholdSat = getDustThresholdSat;
|
|
37
|
+
exports.getDustThresholdSatForOutputScript = getDustThresholdSatForOutputScript;
|
|
38
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
39
|
+
/**
|
|
40
|
+
* Checks if the output script is a witness script or not
|
|
41
|
+
* @param script
|
|
42
|
+
* @returns true if the script is a witness script
|
|
43
|
+
*/
|
|
44
|
+
function isWitnessOutputScript(script) {
|
|
45
|
+
/**
|
|
46
|
+
* Source: https://github.com/bitcoin/bitcoin/blob/v28.1/src/script/script.cpp#L241-L257
|
|
47
|
+
* A witness program is any valid CScript that consists of a 1-byte push opcode
|
|
48
|
+
* followed by a data push between 2 and 40 bytes.
|
|
49
|
+
*/
|
|
50
|
+
if (script.length < 4 || script.length > 42) {
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
if (script[0] !== utxolib.opcodes.OP_0 && (script[0] < utxolib.opcodes.OP_1 || script[0] > utxolib.opcodes.OP_16)) {
|
|
54
|
+
return false;
|
|
55
|
+
}
|
|
56
|
+
return script[1] + 2 === script.length;
|
|
57
|
+
}
|
|
58
|
+
function getDustRelayLimit(network) {
|
|
59
|
+
network = utxolib.getMainnet(network);
|
|
60
|
+
switch (network) {
|
|
61
|
+
case utxolib.networks.bitcoin:
|
|
62
|
+
case utxolib.networks.bitcoingold:
|
|
63
|
+
case utxolib.networks.dash:
|
|
64
|
+
// btc: https://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.h#L50-L55
|
|
65
|
+
// btg: https://github.com/BTCGPU/BTCGPU/blob/v0.17.3/src/policy/policy.h#L48
|
|
66
|
+
// dash: https://github.com/dashpay/dash/blob/v22.0.0-beta.1/src/policy/policy.h#L41-L46
|
|
67
|
+
return { feeRateSatKB: 3000 };
|
|
68
|
+
case utxolib.networks.bitcoincash:
|
|
69
|
+
// https://github.com/bitcoin-cash-node/bitcoin-cash-node/blob/v27.1.0/src/policy/policy.h#L76-L83
|
|
70
|
+
// I actually haven't looked at BSV and am depressed that I still need to handle the case here
|
|
71
|
+
return { feeRateSatKB: 1000 };
|
|
72
|
+
case utxolib.networks.dogecoin:
|
|
73
|
+
// https://github.com/dogecoin/dogecoin/blob/v1.14.8/src/policy/policy.h#L65-L81
|
|
74
|
+
// (COIN / 100) / 10;
|
|
75
|
+
return { satAmount: 1000000 };
|
|
76
|
+
case utxolib.networks.litecoin:
|
|
77
|
+
// https://github.com/litecoin-project/litecoin/blob/master/src/policy/policy.h#L47-L52
|
|
78
|
+
return { feeRateSatKB: 30000 };
|
|
79
|
+
case utxolib.networks.zcash:
|
|
80
|
+
// https://github.com/zcash/zcash/blob/master/src/primitives/transaction.h#L396-L399
|
|
81
|
+
// https://github.com/zcash/zcash/blob/v6.0.0/src/policy/policy.h#L43-L89 (I don't quite get it)
|
|
82
|
+
return { satAmount: 300 };
|
|
83
|
+
case utxolib.networks.bitcoinsv:
|
|
84
|
+
throw new Error('deprecated coin');
|
|
85
|
+
default:
|
|
86
|
+
throw new Error('unsupported network');
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
function getSpendSize(network, outputSize, isWitness) {
|
|
90
|
+
network = utxolib.getMainnet(network);
|
|
91
|
+
switch (network) {
|
|
92
|
+
case utxolib.networks.bitcoin:
|
|
93
|
+
case utxolib.networks.bitcoincash:
|
|
94
|
+
case utxolib.networks.bitcoingold:
|
|
95
|
+
case utxolib.networks.litecoin:
|
|
96
|
+
/*
|
|
97
|
+
btc: https://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.cpp#L26-L68
|
|
98
|
+
bch: https://github.com/bitcoin-cash-node/bitcoin-cash-node/blob/v27.1.0/src/policy/policy.cpp#L18-L36 (btc-ish)
|
|
99
|
+
btg: https://github.com/BTCGPU/BTCGPU/blob/v0.17.3/src/policy/policy.cpp#L18-L50 (btc-ish)
|
|
100
|
+
ltc: https://github.com/litecoin-project/litecoin/blob/v0.21.4/src/policy/policy.cpp#L15-L47 (btc-ish)
|
|
101
|
+
|
|
102
|
+
The fixed component here is 69.75 for isWitness=true and 150 for isWitness=false.
|
|
103
|
+
*/
|
|
104
|
+
return outputSize + 32 + 4 + 1 + 107 / (isWitness ? 4 : 1) + 4;
|
|
105
|
+
case utxolib.networks.dash:
|
|
106
|
+
// dash: https://github.com/dashpay/dash/blob/v21.1.1/src/policy/policy.cpp#L14-L30 (btc-ish)
|
|
107
|
+
// how did they end up with 148? I don't know
|
|
108
|
+
return outputSize + 148;
|
|
109
|
+
case utxolib.networks.dogecoin:
|
|
110
|
+
case utxolib.networks.zcash:
|
|
111
|
+
// doge: https://github.com/dogecoin/dogecoin/blob/v1.14.8/src/policy/policy.h#L65-L81 (hardcoded)
|
|
112
|
+
// zec: https://github.com/zcash/zcash/blob/v6.0.0/src/policy/policy.h#L43-L89 (some weird other thing, doge-ish)
|
|
113
|
+
throw new Error('dust limit is size-independent');
|
|
114
|
+
case utxolib.networks.bitcoinsv:
|
|
115
|
+
throw new Error('deprecated coin');
|
|
116
|
+
default:
|
|
117
|
+
throw new Error('unsupported network');
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
function getDustThresholdSat(network, outputSize, isWitness) {
|
|
121
|
+
const dustLimit = getDustRelayLimit(network);
|
|
122
|
+
if ('satAmount' in dustLimit) {
|
|
123
|
+
return dustLimit.satAmount;
|
|
124
|
+
}
|
|
125
|
+
if ('feeRateSatKB' in dustLimit) {
|
|
126
|
+
const spendSize = getSpendSize(network, outputSize, isWitness);
|
|
127
|
+
return Math.ceil((dustLimit.feeRateSatKB * spendSize) / 1000);
|
|
128
|
+
}
|
|
129
|
+
throw new Error('unexpected dustLimit');
|
|
130
|
+
}
|
|
131
|
+
function getDustThresholdSatForOutputScript(network, script) {
|
|
132
|
+
return getDustThresholdSat(network, script.length, isWitnessOutputScript(script));
|
|
133
|
+
}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dustThreshold.js","sourceRoot":"","sources":["../../src/dustThreshold.ts"],"names":[],"mappings":"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","sourcesContent":["import * as utxolib from '@bitgo-beta/utxo-lib';\n\n/**\n * Checks if the output script is a witness script or not\n * @param script\n * @returns true if the script is a witness script\n */\nfunction isWitnessOutputScript(script: Buffer): boolean {\n  /**\n   * Source: https://github.com/bitcoin/bitcoin/blob/v28.1/src/script/script.cpp#L241-L257\n   * A witness program is any valid CScript that consists of a 1-byte push opcode\n   * followed by a data push between 2 and 40 bytes.\n   */\n  if (script.length < 4 || script.length > 42) {\n    return false;\n  }\n  if (script[0] !== utxolib.opcodes.OP_0 && (script[0] < utxolib.opcodes.OP_1 || script[0] > utxolib.opcodes.OP_16)) {\n    return false;\n  }\n  return script[1] + 2 === script.length;\n}\n\n/*\n\nThe dust threshold for most UTXO coins is dependent on multiple factors:\n\n(1) spendability of the output (OP_RETURNs are allowed to be 0 sized)\n(2) whether it is a witness or non-witness output\n(3) a particular fee rate (GetDiscardRate())\n\nI will do the analysis mostly for bitcoin here and then generalize.\n\nOn the indexer we use `sendrawtransaction`, which calls `IsStandardTx` like this\n\nhttps://github.com/bitcoin/bitcoin/blob/v28.0/src/kernel/mempool_options.h#L47\n\n```\nif (\n  m_pool.m_opts.require_standard &&\n   !IsStandardTx(tx,\n   m_pool.m_opts.max_datacarrier_bytes,\n   m_pool.m_opts.permit_bare_multisig,\n   m_pool.m_opts.dust_relay_feerate, reason))\n```\n\nThe `dust_relay_feerate` in this context is a hardcoded constant:\nhttps://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.h#L50-L55\n\n(that can actually be overridden with a hidden command\nline parameter: https://bitcoin.stackexchange.com/a/41082/137601)\n\nThere we call `IsDust`\n\nhttps://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.cpp#L144-L146\n\n```\nif (IsDust(txout, dust_relay_fee)) {\n    reason = \"dust\";\n    return false;\n}\n```\n\nWhich calls `GetDustThreshold`,\n\nhttps://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.cpp#L67\n\nThe implementation of `GetDustThreshold` computes the minimal transaction size that can spend the output, and computes\na minimum fee for that transaction size based on the `dust_relay_fee` (FeeRate) parameter.\n\nThe different utxo implementations differ in these ways:\n\n- some have a fixed, satoshi amount dust limit (doge, zec)\n- some have a different dust_relay_fee\n\n*/\n\ntype DustLimit = { feeRateSatKB: number } | { satAmount: number };\n\nfunction getDustRelayLimit(network: utxolib.Network): DustLimit {\n  network = utxolib.getMainnet(network);\n  switch (network) {\n    case utxolib.networks.bitcoin:\n    case utxolib.networks.bitcoingold:\n    case utxolib.networks.dash:\n      // btc:  https://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.h#L50-L55\n      // btg:  https://github.com/BTCGPU/BTCGPU/blob/v0.17.3/src/policy/policy.h#L48\n      // dash: https://github.com/dashpay/dash/blob/v22.0.0-beta.1/src/policy/policy.h#L41-L46\n      return { feeRateSatKB: 3000 };\n    case utxolib.networks.bitcoincash:\n      // https://github.com/bitcoin-cash-node/bitcoin-cash-node/blob/v27.1.0/src/policy/policy.h#L76-L83\n      // I actually haven't looked at BSV and am depressed that I still need to handle the case here\n      return { feeRateSatKB: 1000 };\n    case utxolib.networks.dogecoin:\n      // https://github.com/dogecoin/dogecoin/blob/v1.14.8/src/policy/policy.h#L65-L81\n      // (COIN / 100) / 10;\n      return { satAmount: 1_000_000 };\n    case utxolib.networks.litecoin:\n      //  https://github.com/litecoin-project/litecoin/blob/master/src/policy/policy.h#L47-L52\n      return { feeRateSatKB: 30_000 };\n    case utxolib.networks.zcash:\n      // https://github.com/zcash/zcash/blob/master/src/primitives/transaction.h#L396-L399\n      // https://github.com/zcash/zcash/blob/v6.0.0/src/policy/policy.h#L43-L89 (I don't quite get it)\n      return { satAmount: 300 };\n    case utxolib.networks.bitcoinsv:\n      throw new Error('deprecated coin');\n    default:\n      throw new Error('unsupported network');\n  }\n}\n\nfunction getSpendSize(network: utxolib.Network, outputSize: number, isWitness: boolean): number {\n  network = utxolib.getMainnet(network);\n  switch (network) {\n    case utxolib.networks.bitcoin:\n    case utxolib.networks.bitcoincash:\n    case utxolib.networks.bitcoingold:\n    case utxolib.networks.litecoin:\n      /*\n        btc:  https://github.com/bitcoin/bitcoin/blob/v28.0/src/policy/policy.cpp#L26-L68\n        bch:  https://github.com/bitcoin-cash-node/bitcoin-cash-node/blob/v27.1.0/src/policy/policy.cpp#L18-L36 (btc-ish)\n        btg:  https://github.com/BTCGPU/BTCGPU/blob/v0.17.3/src/policy/policy.cpp#L18-L50 (btc-ish)\n        ltc:  https://github.com/litecoin-project/litecoin/blob/v0.21.4/src/policy/policy.cpp#L15-L47 (btc-ish)\n\n        The fixed component here is 69.75 for isWitness=true and 150 for isWitness=false.\n       */\n      return outputSize + 32 + 4 + 1 + 107 / (isWitness ? 4 : 1) + 4;\n    case utxolib.networks.dash:\n      // dash: https://github.com/dashpay/dash/blob/v21.1.1/src/policy/policy.cpp#L14-L30 (btc-ish)\n      // how did they end up with 148? I don't know\n      return outputSize + 148;\n    case utxolib.networks.dogecoin:\n    case utxolib.networks.zcash:\n      // doge: https://github.com/dogecoin/dogecoin/blob/v1.14.8/src/policy/policy.h#L65-L81 (hardcoded)\n      // zec:  https://github.com/zcash/zcash/blob/v6.0.0/src/policy/policy.h#L43-L89 (some weird other thing, doge-ish)\n      throw new Error('dust limit is size-independent');\n    case utxolib.networks.bitcoinsv:\n      throw new Error('deprecated coin');\n    default:\n      throw new Error('unsupported network');\n  }\n}\n\nexport function getDustThresholdSat(network: utxolib.Network, outputSize: number, isWitness: boolean): number {\n  const dustLimit = getDustRelayLimit(network);\n  if ('satAmount' in dustLimit) {\n    return dustLimit.satAmount;\n  }\n  if ('feeRateSatKB' in dustLimit) {\n    const spendSize = getSpendSize(network, outputSize, isWitness);\n    return Math.ceil((dustLimit.feeRateSatKB * spendSize) / 1000);\n  }\n  throw new Error('unexpected dustLimit');\n}\n\nexport function getDustThresholdSatForOutputScript(network: utxolib.Network, script: Buffer): number {\n  return getDustThresholdSat(network, script.length, isWitnessOutputScript(script));\n}\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * as bip65 from './bip65';
|
|
2
|
+
export * as descriptor from './descriptor';
|
|
3
|
+
export * as testutil from './testutil';
|
|
4
|
+
export * as paygo from './paygo';
|
|
5
|
+
export * as bip32utils from './bip32utils';
|
|
6
|
+
export * as bip322 from './bip322';
|
|
7
|
+
export * from './dustThreshold';
|
|
8
|
+
export * from './Output';
|
|
9
|
+
export * from './xOnlyPubkey';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAC;AACvC,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,eAAe,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
36
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.bip322 = exports.bip32utils = exports.paygo = exports.testutil = exports.descriptor = exports.bip65 = void 0;
|
|
40
|
+
exports.bip65 = __importStar(require("./bip65"));
|
|
41
|
+
exports.descriptor = __importStar(require("./descriptor"));
|
|
42
|
+
exports.testutil = __importStar(require("./testutil"));
|
|
43
|
+
exports.paygo = __importStar(require("./paygo"));
|
|
44
|
+
exports.bip32utils = __importStar(require("./bip32utils"));
|
|
45
|
+
exports.bip322 = __importStar(require("./bip322"));
|
|
46
|
+
__exportStar(require("./dustThreshold"), exports);
|
|
47
|
+
__exportStar(require("./Output"), exports);
|
|
48
|
+
__exportStar(require("./xOnlyPubkey"), exports);
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsaURBQWlDO0FBQ2pDLDJEQUEyQztBQUMzQyx1REFBdUM7QUFDdkMsaURBQWlDO0FBQ2pDLDJEQUEyQztBQUMzQyxtREFBbUM7QUFDbkMsa0RBQWdDO0FBQ2hDLDJDQUF5QjtBQUN6QixnREFBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBhcyBiaXA2NSBmcm9tICcuL2JpcDY1JztcbmV4cG9ydCAqIGFzIGRlc2NyaXB0b3IgZnJvbSAnLi9kZXNjcmlwdG9yJztcbmV4cG9ydCAqIGFzIHRlc3R1dGlsIGZyb20gJy4vdGVzdHV0aWwnO1xuZXhwb3J0ICogYXMgcGF5Z28gZnJvbSAnLi9wYXlnbyc7XG5leHBvcnQgKiBhcyBiaXAzMnV0aWxzIGZyb20gJy4vYmlwMzJ1dGlscyc7XG5leHBvcnQgKiBhcyBiaXAzMjIgZnJvbSAnLi9iaXAzMjInO1xuZXhwb3J0ICogZnJvbSAnLi9kdXN0VGhyZXNob2xkJztcbmV4cG9ydCAqIGZyb20gJy4vT3V0cHV0JztcbmV4cG9ydCAqIGZyb20gJy4veE9ubHlQdWJrZXknO1xuIl19
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
2
|
+
export declare const NIL_UUID = "00000000-0000-0000-0000-000000000000";
|
|
3
|
+
/** This function reconstructs the proof <ENTROPY><ADDRESS><UUID>
|
|
4
|
+
* given the address and entropy.
|
|
5
|
+
*
|
|
6
|
+
* @param address
|
|
7
|
+
* @param entropy
|
|
8
|
+
* @returns
|
|
9
|
+
*/
|
|
10
|
+
export declare function createPayGoAttestationBuffer(address: string, entropy: Buffer, network: utxolib.Network): Buffer;
|
|
11
|
+
//# sourceMappingURL=attestation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attestation.d.ts","sourceRoot":"","sources":["../../../src/paygo/attestation.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,eAAO,MAAM,QAAQ,yCAAyC,CAAC;AAE/D;;;;;;GAMG;AACH,wBAAgB,4BAA4B,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAM/G"}
|
|
@@ -0,0 +1,58 @@
|
|
|
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
|
+
exports.NIL_UUID = void 0;
|
|
40
|
+
exports.createPayGoAttestationBuffer = createPayGoAttestationBuffer;
|
|
41
|
+
const assert_1 = __importDefault(require("assert"));
|
|
42
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
43
|
+
exports.NIL_UUID = '00000000-0000-0000-0000-000000000000';
|
|
44
|
+
/** This function reconstructs the proof <ENTROPY><ADDRESS><UUID>
|
|
45
|
+
* given the address and entropy.
|
|
46
|
+
*
|
|
47
|
+
* @param address
|
|
48
|
+
* @param entropy
|
|
49
|
+
* @returns
|
|
50
|
+
*/
|
|
51
|
+
function createPayGoAttestationBuffer(address, entropy, network) {
|
|
52
|
+
(0, assert_1.default)(address.length > 0);
|
|
53
|
+
const isValidAddress = utxolib.address.toOutputScript(address, network);
|
|
54
|
+
(0, assert_1.default)(isValidAddress, `Address ${address} is not a valid address.`);
|
|
55
|
+
const addressBuffer = Buffer.from(address);
|
|
56
|
+
return Buffer.concat([entropy, addressBuffer, Buffer.from(exports.NIL_UUID)]);
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0ZXN0YXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGF5Z28vYXR0ZXN0YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWUEsb0VBTUM7QUFsQkQsb0RBQTRCO0FBRTVCLDhEQUFnRDtBQUNuQyxRQUFBLFFBQVEsR0FBRyxzQ0FBc0MsQ0FBQztBQUUvRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQiw0QkFBNEIsQ0FBQyxPQUFlLEVBQUUsT0FBZSxFQUFFLE9BQXdCO0lBQ3JHLElBQUEsZ0JBQU0sRUFBQyxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzNCLE1BQU0sY0FBYyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQztJQUN4RSxJQUFBLGdCQUFNLEVBQUMsY0FBYyxFQUFFLFdBQVcsT0FBTywwQkFBMEIsQ0FBQyxDQUFDO0lBQ3JFLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0MsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLGdCQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDeEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcblxuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5leHBvcnQgY29uc3QgTklMX1VVSUQgPSAnMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwJztcblxuLyoqIFRoaXMgZnVuY3Rpb24gcmVjb25zdHJ1Y3RzIHRoZSBwcm9vZiA8RU5UUk9QWT48QUREUkVTUz48VVVJRD5cbiAqIGdpdmVuIHRoZSBhZGRyZXNzIGFuZCBlbnRyb3B5LlxuICpcbiAqIEBwYXJhbSBhZGRyZXNzXG4gKiBAcGFyYW0gZW50cm9weVxuICogQHJldHVybnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVBheUdvQXR0ZXN0YXRpb25CdWZmZXIoYWRkcmVzczogc3RyaW5nLCBlbnRyb3B5OiBCdWZmZXIsIG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IEJ1ZmZlciB7XG4gIGFzc2VydChhZGRyZXNzLmxlbmd0aCA+IDApO1xuICBjb25zdCBpc1ZhbGlkQWRkcmVzcyA9IHV0eG9saWIuYWRkcmVzcy50b091dHB1dFNjcmlwdChhZGRyZXNzLCBuZXR3b3JrKTtcbiAgYXNzZXJ0KGlzVmFsaWRBZGRyZXNzLCBgQWRkcmVzcyAke2FkZHJlc3N9IGlzIG5vdCBhIHZhbGlkIGFkZHJlc3MuYCk7XG4gIGNvbnN0IGFkZHJlc3NCdWZmZXIgPSBCdWZmZXIuZnJvbShhZGRyZXNzKTtcbiAgcmV0dXJuIEJ1ZmZlci5jb25jYXQoW2VudHJvcHksIGFkZHJlc3NCdWZmZXIsIEJ1ZmZlci5mcm9tKE5JTF9VVUlEKV0pO1xufVxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/paygo/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC;AACxC,cAAc,QAAQ,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./parsePayGoAttestation"), exports);
|
|
18
|
+
__exportStar(require("./psbt"), exports);
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGF5Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDBEQUF3QztBQUN4Qyx5Q0FBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BhcnNlUGF5R29BdHRlc3RhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3BzYnQnO1xuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export declare const Prefix: Buffer<ArrayBuffer>;
|
|
2
|
+
/**
|
|
3
|
+
* This function takes in the attestation proof of a PayGo address of the from
|
|
4
|
+
* <varint_length><ENTROPY><ADDRESS><UUID> and returns
|
|
5
|
+
* the address given its length. It is assumed that the ENTROPY is 64 bytes in the Buffer
|
|
6
|
+
* so if not given an address proof length we can still extract the address from the proof.
|
|
7
|
+
*
|
|
8
|
+
* @param message
|
|
9
|
+
* @param adressProofLength
|
|
10
|
+
*/
|
|
11
|
+
export declare function parsePayGoAttestation(message: Buffer): {
|
|
12
|
+
entropy: Buffer;
|
|
13
|
+
address: Buffer;
|
|
14
|
+
uuid: Buffer;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=parsePayGoAttestation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parsePayGoAttestation.d.ts","sourceRoot":"","sources":["../../../src/paygo/parsePayGoAttestation.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,MAAM,qBAA0D,CAAC;AAQ9E;;;;;;;;GAQG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM,GAAG;IACtD,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CACd,CA0BA"}
|
|
@@ -0,0 +1,50 @@
|
|
|
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
|
+
exports.Prefix = void 0;
|
|
7
|
+
exports.parsePayGoAttestation = parsePayGoAttestation;
|
|
8
|
+
const assert_1 = __importDefault(require("assert"));
|
|
9
|
+
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
10
|
+
// The signed address will always have the following structure:
|
|
11
|
+
// 0x18Bitcoin Signed Message:\n<varint_length><ENTROPY><ADDRESS><UUID>
|
|
12
|
+
exports.Prefix = Buffer.from('\u0018Bitcoin Signed Message:\n', 'utf-8');
|
|
13
|
+
// UUID has the structure 00000000-0000-0000-0000-000000000000, and after
|
|
14
|
+
// we Buffer.from and get it's length its 36.
|
|
15
|
+
const UuidBufferLength = 36;
|
|
16
|
+
// The entropy will always be 64 bytes
|
|
17
|
+
const EntropyLen = 64;
|
|
18
|
+
/**
|
|
19
|
+
* This function takes in the attestation proof of a PayGo address of the from
|
|
20
|
+
* <varint_length><ENTROPY><ADDRESS><UUID> and returns
|
|
21
|
+
* the address given its length. It is assumed that the ENTROPY is 64 bytes in the Buffer
|
|
22
|
+
* so if not given an address proof length we can still extract the address from the proof.
|
|
23
|
+
*
|
|
24
|
+
* @param message
|
|
25
|
+
* @param adressProofLength
|
|
26
|
+
*/
|
|
27
|
+
function parsePayGoAttestation(message) {
|
|
28
|
+
if (message.length <= EntropyLen + UuidBufferLength) {
|
|
29
|
+
throw new Error('PayGo attestation proof is too short to contain a valid address');
|
|
30
|
+
}
|
|
31
|
+
// This generates the first part before the varint length so that we can
|
|
32
|
+
// determine how many bytes this is and iterate through the Buffer.
|
|
33
|
+
let offset = 0;
|
|
34
|
+
if (message.toString('hex').startsWith(exports.Prefix.toString('hex'))) {
|
|
35
|
+
offset = exports.Prefix.length;
|
|
36
|
+
}
|
|
37
|
+
// we decode the varint of the message which is uint32
|
|
38
|
+
// https://en.bitcoin.it/wiki/Protocol_documentation
|
|
39
|
+
const varInt = utxo_lib_1.bufferutils.varuint.decode(message, offset);
|
|
40
|
+
(0, assert_1.default)(varInt);
|
|
41
|
+
offset += utxo_lib_1.bufferutils.varuint.decode.bytes;
|
|
42
|
+
const entropy = message.subarray(offset, offset + EntropyLen);
|
|
43
|
+
offset += EntropyLen;
|
|
44
|
+
const address = message.subarray(offset, message.length - UuidBufferLength);
|
|
45
|
+
offset += address.length;
|
|
46
|
+
const uuid = message.subarray(message.length - UuidBufferLength);
|
|
47
|
+
// we break up the original message and retuen the entropy, address and uuid in their buffers
|
|
48
|
+
return { entropy, address, uuid };
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VQYXlHb0F0dGVzdGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BheWdvL3BhcnNlUGF5R29BdHRlc3RhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUF1QkEsc0RBOEJDO0FBckRELG9EQUE0QjtBQUU1QixtREFBbUQ7QUFFbkQsK0RBQStEO0FBQy9ELHVFQUF1RTtBQUMxRCxRQUFBLE1BQU0sR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLGlDQUFpQyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBRTlFLHlFQUF5RTtBQUN6RSw2Q0FBNkM7QUFDN0MsTUFBTSxnQkFBZ0IsR0FBRyxFQUFFLENBQUM7QUFDNUIsc0NBQXNDO0FBQ3RDLE1BQU0sVUFBVSxHQUFHLEVBQUUsQ0FBQztBQUV0Qjs7Ozs7Ozs7R0FRRztBQUNILFNBQWdCLHFCQUFxQixDQUFDLE9BQWU7SUFLbkQsSUFBSSxPQUFPLENBQUMsTUFBTSxJQUFJLFVBQVUsR0FBRyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3BELE1BQU0sSUFBSSxLQUFLLENBQUMsaUVBQWlFLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBRUQsd0VBQXdFO0lBQ3hFLG1FQUFtRTtJQUNuRSxJQUFJLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFDZixJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsVUFBVSxDQUFDLGNBQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQy9ELE1BQU0sR0FBRyxjQUFNLENBQUMsTUFBTSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxzREFBc0Q7SUFDdEQsb0RBQW9EO0lBQ3BELE1BQU0sTUFBTSxHQUFHLHNCQUFXLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDM0QsSUFBQSxnQkFBTSxFQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2YsTUFBTSxJQUFJLHNCQUFXLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFFM0MsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLFVBQVUsQ0FBQyxDQUFDO0lBQzlELE1BQU0sSUFBSSxVQUFVLENBQUM7SUFDckIsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQzVFLE1BQU0sSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDO0lBQ3pCLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxDQUFDO0lBRWpFLDZGQUE2RjtJQUM3RixPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQztBQUNwQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuXG5pbXBvcnQgeyBidWZmZXJ1dGlscyB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuLy8gVGhlIHNpZ25lZCBhZGRyZXNzIHdpbGwgYWx3YXlzIGhhdmUgdGhlIGZvbGxvd2luZyBzdHJ1Y3R1cmU6XG4vLyAweDE4Qml0Y29pbiBTaWduZWQgTWVzc2FnZTpcXG48dmFyaW50X2xlbmd0aD48RU5UUk9QWT48QUREUkVTUz48VVVJRD5cbmV4cG9ydCBjb25zdCBQcmVmaXggPSBCdWZmZXIuZnJvbSgnXFx1MDAxOEJpdGNvaW4gU2lnbmVkIE1lc3NhZ2U6XFxuJywgJ3V0Zi04Jyk7XG5cbi8vIFVVSUQgaGFzIHRoZSBzdHJ1Y3R1cmUgMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwLCBhbmQgYWZ0ZXJcbi8vIHdlIEJ1ZmZlci5mcm9tIGFuZCBnZXQgaXQncyBsZW5ndGggaXRzIDM2LlxuY29uc3QgVXVpZEJ1ZmZlckxlbmd0aCA9IDM2O1xuLy8gVGhlIGVudHJvcHkgd2lsbCBhbHdheXMgYmUgNjQgYnl0ZXNcbmNvbnN0IEVudHJvcHlMZW4gPSA2NDtcblxuLyoqXG4gKiBUaGlzIGZ1bmN0aW9uIHRha2VzIGluIHRoZSBhdHRlc3RhdGlvbiBwcm9vZiBvZiBhIFBheUdvIGFkZHJlc3Mgb2YgdGhlIGZyb21cbiAqIDx2YXJpbnRfbGVuZ3RoPjxFTlRST1BZPjxBRERSRVNTPjxVVUlEPiBhbmQgcmV0dXJuc1xuICogdGhlIGFkZHJlc3MgZ2l2ZW4gaXRzIGxlbmd0aC4gSXQgaXMgYXNzdW1lZCB0aGF0IHRoZSBFTlRST1BZIGlzIDY0IGJ5dGVzIGluIHRoZSBCdWZmZXJcbiAqIHNvIGlmIG5vdCBnaXZlbiBhbiBhZGRyZXNzIHByb29mIGxlbmd0aCB3ZSBjYW4gc3RpbGwgZXh0cmFjdCB0aGUgYWRkcmVzcyBmcm9tIHRoZSBwcm9vZi5cbiAqXG4gKiBAcGFyYW0gbWVzc2FnZVxuICogQHBhcmFtIGFkcmVzc1Byb29mTGVuZ3RoXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZVBheUdvQXR0ZXN0YXRpb24obWVzc2FnZTogQnVmZmVyKToge1xuICBlbnRyb3B5OiBCdWZmZXI7XG4gIGFkZHJlc3M6IEJ1ZmZlcjtcbiAgdXVpZDogQnVmZmVyO1xufSB7XG4gIGlmIChtZXNzYWdlLmxlbmd0aCA8PSBFbnRyb3B5TGVuICsgVXVpZEJ1ZmZlckxlbmd0aCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUGF5R28gYXR0ZXN0YXRpb24gcHJvb2YgaXMgdG9vIHNob3J0IHRvIGNvbnRhaW4gYSB2YWxpZCBhZGRyZXNzJyk7XG4gIH1cblxuICAvLyBUaGlzIGdlbmVyYXRlcyB0aGUgZmlyc3QgcGFydCBiZWZvcmUgdGhlIHZhcmludCBsZW5ndGggc28gdGhhdCB3ZSBjYW5cbiAgLy8gZGV0ZXJtaW5lIGhvdyBtYW55IGJ5dGVzIHRoaXMgaXMgYW5kIGl0ZXJhdGUgdGhyb3VnaCB0aGUgQnVmZmVyLlxuICBsZXQgb2Zmc2V0ID0gMDtcbiAgaWYgKG1lc3NhZ2UudG9TdHJpbmcoJ2hleCcpLnN0YXJ0c1dpdGgoUHJlZml4LnRvU3RyaW5nKCdoZXgnKSkpIHtcbiAgICBvZmZzZXQgPSBQcmVmaXgubGVuZ3RoO1xuICB9XG5cbiAgLy8gd2UgZGVjb2RlIHRoZSB2YXJpbnQgb2YgdGhlIG1lc3NhZ2Ugd2hpY2ggaXMgdWludDMyXG4gIC8vIGh0dHBzOi8vZW4uYml0Y29pbi5pdC93aWtpL1Byb3RvY29sX2RvY3VtZW50YXRpb25cbiAgY29uc3QgdmFySW50ID0gYnVmZmVydXRpbHMudmFydWludC5kZWNvZGUobWVzc2FnZSwgb2Zmc2V0KTtcbiAgYXNzZXJ0KHZhckludCk7XG4gIG9mZnNldCArPSBidWZmZXJ1dGlscy52YXJ1aW50LmRlY29kZS5ieXRlcztcblxuICBjb25zdCBlbnRyb3B5ID0gbWVzc2FnZS5zdWJhcnJheShvZmZzZXQsIG9mZnNldCArIEVudHJvcHlMZW4pO1xuICBvZmZzZXQgKz0gRW50cm9weUxlbjtcbiAgY29uc3QgYWRkcmVzcyA9IG1lc3NhZ2Uuc3ViYXJyYXkob2Zmc2V0LCBtZXNzYWdlLmxlbmd0aCAtIFV1aWRCdWZmZXJMZW5ndGgpO1xuICBvZmZzZXQgKz0gYWRkcmVzcy5sZW5ndGg7XG4gIGNvbnN0IHV1aWQgPSBtZXNzYWdlLnN1YmFycmF5KG1lc3NhZ2UubGVuZ3RoIC0gVXVpZEJ1ZmZlckxlbmd0aCk7XG5cbiAgLy8gd2UgYnJlYWsgdXAgdGhlIG9yaWdpbmFsIG1lc3NhZ2UgYW5kIHJldHVlbiB0aGUgZW50cm9weSwgYWRkcmVzcyBhbmQgdXVpZCBpbiB0aGVpciBidWZmZXJzXG4gIHJldHVybiB7IGVudHJvcHksIGFkZHJlc3MsIHV1aWQgfTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export declare class PayGoError extends Error {
|
|
2
|
+
constructor(message: string);
|
|
3
|
+
}
|
|
4
|
+
export declare class ErrorNoPayGoProof extends PayGoError {
|
|
5
|
+
outputIndex: number;
|
|
6
|
+
constructor(outputIndex: number);
|
|
7
|
+
}
|
|
8
|
+
export declare class ErrorMultiplePayGoProof extends PayGoError {
|
|
9
|
+
constructor();
|
|
10
|
+
}
|
|
11
|
+
export declare class ErrorPayGoAddressProofFailedVerification extends PayGoError {
|
|
12
|
+
constructor();
|
|
13
|
+
}
|
|
14
|
+
export declare class ErrorOutputIndexOutOfBounds extends PayGoError {
|
|
15
|
+
outputIndex: number;
|
|
16
|
+
constructor(outputIndex: number);
|
|
17
|
+
}
|
|
18
|
+
export declare class ErrorMultiplePayGoProofAtPsbtIndex extends PayGoError {
|
|
19
|
+
outputIndex: number;
|
|
20
|
+
constructor(outputIndex: number);
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=Errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Errors.d.ts","sourceRoot":"","sources":["../../../../src/paygo/psbt/Errors.ts"],"names":[],"mappings":"AAAA,qBAAa,UAAW,SAAQ,KAAK;gBACvB,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,iBAAkB,SAAQ,UAAU;IAC5B,WAAW,EAAE,MAAM;gBAAnB,WAAW,EAAE,MAAM;CAGvC;AAED,qBAAa,uBAAwB,SAAQ,UAAU;;CAItD;AAED,qBAAa,wCAAyC,SAAQ,UAAU;;CAIvE;AAED,qBAAa,2BAA4B,SAAQ,UAAU;IACtC,WAAW,EAAE,MAAM;gBAAnB,WAAW,EAAE,MAAM;CAGvC;AAED,qBAAa,kCAAmC,SAAQ,UAAU;IAC7C,WAAW,EAAE,MAAM;gBAAnB,WAAW,EAAE,MAAM;CAGvC"}
|