@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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHVzdFRocmVzaG9sZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kdXN0VGhyZXNob2xkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBOElBLGtEQVVDO0FBRUQsZ0ZBRUM7QUE1SkQsOERBQWdEO0FBRWhEOzs7O0dBSUc7QUFDSCxTQUFTLHFCQUFxQixDQUFDLE1BQWM7SUFDM0M7Ozs7T0FJRztJQUNILElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxFQUFFLEVBQUUsQ0FBQztRQUM1QyxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFDRCxJQUFJLE1BQU0sQ0FBQyxDQUFDLENBQUMsS0FBSyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksSUFBSSxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ2xILE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxNQUFNLENBQUMsTUFBTSxDQUFDO0FBQ3pDLENBQUM7QUEwREQsU0FBUyxpQkFBaUIsQ0FBQyxPQUF3QjtJQUNqRCxPQUFPLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN0QyxRQUFRLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDOUIsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUNsQyxLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSTtZQUN4QixrRkFBa0Y7WUFDbEYsOEVBQThFO1lBQzlFLHdGQUF3RjtZQUN4RixPQUFPLEVBQUUsWUFBWSxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ2hDLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxXQUFXO1lBQy9CLGtHQUFrRztZQUNsRyw4RkFBOEY7WUFDOUYsT0FBTyxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsQ0FBQztRQUNoQyxLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUTtZQUM1QixnRkFBZ0Y7WUFDaEYscUJBQXFCO1lBQ3JCLE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBUyxFQUFFLENBQUM7UUFDbEMsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLFFBQVE7WUFDNUIsd0ZBQXdGO1lBQ3hGLE9BQU8sRUFBRSxZQUFZLEVBQUUsS0FBTSxFQUFFLENBQUM7UUFDbEMsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUs7WUFDekIsb0ZBQW9GO1lBQ3BGLGdHQUFnRztZQUNoRyxPQUFPLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxDQUFDO1FBQzVCLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxTQUFTO1lBQzdCLE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUNyQztZQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUMzQyxDQUFDO0FBQ0gsQ0FBQztBQUVELFNBQVMsWUFBWSxDQUFDLE9BQXdCLEVBQUUsVUFBa0IsRUFBRSxTQUFrQjtJQUNwRixPQUFPLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN0QyxRQUFRLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDOUIsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUNsQyxLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQ2xDLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRO1lBQzVCOzs7Ozs7O2VBT0c7WUFDSCxPQUFPLFVBQVUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2pFLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJO1lBQ3hCLDZGQUE2RjtZQUM3Riw2Q0FBNkM7WUFDN0MsT0FBTyxVQUFVLEdBQUcsR0FBRyxDQUFDO1FBQzFCLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFDL0IsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUs7WUFDekIsa0dBQWtHO1lBQ2xHLGtIQUFrSDtZQUNsSCxNQUFNLElBQUksS0FBSyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7UUFDcEQsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLFNBQVM7WUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3JDO1lBQ0UsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBQzNDLENBQUM7QUFDSCxDQUFDO0FBRUQsU0FBZ0IsbUJBQW1CLENBQUMsT0FBd0IsRUFBRSxVQUFrQixFQUFFLFNBQWtCO0lBQ2xHLE1BQU0sU0FBUyxHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzdDLElBQUksV0FBVyxJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQzdCLE9BQU8sU0FBUyxDQUFDLFNBQVMsQ0FBQztJQUM3QixDQUFDO0lBQ0QsSUFBSSxjQUFjLElBQUksU0FBUyxFQUFFLENBQUM7UUFDaEMsTUFBTSxTQUFTLEdBQUcsWUFBWSxDQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDL0QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsU0FBUyxDQUFDLFlBQVksR0FBRyxTQUFTLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBQzFDLENBQUM7QUFFRCxTQUFnQixrQ0FBa0MsQ0FBQyxPQUF3QixFQUFFLE1BQWM7SUFDekYsT0FBTyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLE1BQU0sRUFBRSxxQkFBcUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0FBQ3BGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuLyoqXG4gKiBDaGVja3MgaWYgdGhlIG91dHB1dCBzY3JpcHQgaXMgYSB3aXRuZXNzIHNjcmlwdCBvciBub3RcbiAqIEBwYXJhbSBzY3JpcHRcbiAqIEByZXR1cm5zIHRydWUgaWYgdGhlIHNjcmlwdCBpcyBhIHdpdG5lc3Mgc2NyaXB0XG4gKi9cbmZ1bmN0aW9uIGlzV2l0bmVzc091dHB1dFNjcmlwdChzY3JpcHQ6IEJ1ZmZlcik6IGJvb2xlYW4ge1xuICAvKipcbiAgICogU291cmNlOiBodHRwczovL2dpdGh1Yi5jb20vYml0Y29pbi9iaXRjb2luL2Jsb2IvdjI4LjEvc3JjL3NjcmlwdC9zY3JpcHQuY3BwI0wyNDEtTDI1N1xuICAgKiBBIHdpdG5lc3MgcHJvZ3JhbSBpcyBhbnkgdmFsaWQgQ1NjcmlwdCB0aGF0IGNvbnNpc3RzIG9mIGEgMS1ieXRlIHB1c2ggb3Bjb2RlXG4gICAqIGZvbGxvd2VkIGJ5IGEgZGF0YSBwdXNoIGJldHdlZW4gMiBhbmQgNDAgYnl0ZXMuXG4gICAqL1xuICBpZiAoc2NyaXB0Lmxlbmd0aCA8IDQgfHwgc2NyaXB0Lmxlbmd0aCA+IDQyKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIGlmIChzY3JpcHRbMF0gIT09IHV0eG9saWIub3Bjb2Rlcy5PUF8wICYmIChzY3JpcHRbMF0gPCB1dHhvbGliLm9wY29kZXMuT1BfMSB8fCBzY3JpcHRbMF0gPiB1dHhvbGliLm9wY29kZXMuT1BfMTYpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIHJldHVybiBzY3JpcHRbMV0gKyAyID09PSBzY3JpcHQubGVuZ3RoO1xufVxuXG4vKlxuXG5UaGUgZHVzdCB0aHJlc2hvbGQgZm9yIG1vc3QgVVRYTyBjb2lucyBpcyBkZXBlbmRlbnQgb24gbXVsdGlwbGUgZmFjdG9yczpcblxuKDEpIHNwZW5kYWJpbGl0eSBvZiB0aGUgb3V0cHV0IChPUF9SRVRVUk5zIGFyZSBhbGxvd2VkIHRvIGJlIDAgc2l6ZWQpXG4oMikgd2hldGhlciBpdCBpcyBhIHdpdG5lc3Mgb3Igbm9uLXdpdG5lc3Mgb3V0cHV0XG4oMykgYSBwYXJ0aWN1bGFyIGZlZSByYXRlIChHZXREaXNjYXJkUmF0ZSgpKVxuXG5JIHdpbGwgZG8gdGhlIGFuYWx5c2lzIG1vc3RseSBmb3IgYml0Y29pbiBoZXJlIGFuZCB0aGVuIGdlbmVyYWxpemUuXG5cbk9uIHRoZSBpbmRleGVyIHdlIHVzZSBgc2VuZHJhd3RyYW5zYWN0aW9uYCwgd2hpY2ggY2FsbHMgYElzU3RhbmRhcmRUeGAgbGlrZSB0aGlzXG5cbmh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luL2JpdGNvaW4vYmxvYi92MjguMC9zcmMva2VybmVsL21lbXBvb2xfb3B0aW9ucy5oI0w0N1xuXG5gYGBcbmlmIChcbiAgbV9wb29sLm1fb3B0cy5yZXF1aXJlX3N0YW5kYXJkICYmXG4gICAhSXNTdGFuZGFyZFR4KHR4LFxuICAgbV9wb29sLm1fb3B0cy5tYXhfZGF0YWNhcnJpZXJfYnl0ZXMsXG4gICBtX3Bvb2wubV9vcHRzLnBlcm1pdF9iYXJlX211bHRpc2lnLFxuICAgbV9wb29sLm1fb3B0cy5kdXN0X3JlbGF5X2ZlZXJhdGUsIHJlYXNvbikpXG5gYGBcblxuVGhlIGBkdXN0X3JlbGF5X2ZlZXJhdGVgIGluIHRoaXMgY29udGV4dCBpcyBhIGhhcmRjb2RlZCBjb25zdGFudDpcbmh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luL2JpdGNvaW4vYmxvYi92MjguMC9zcmMvcG9saWN5L3BvbGljeS5oI0w1MC1MNTVcblxuKHRoYXQgY2FuIGFjdHVhbGx5IGJlIG92ZXJyaWRkZW4gd2l0aCBhIGhpZGRlbiBjb21tYW5kXG5saW5lIHBhcmFtZXRlcjogaHR0cHM6Ly9iaXRjb2luLnN0YWNrZXhjaGFuZ2UuY29tL2EvNDEwODIvMTM3NjAxKVxuXG5UaGVyZSB3ZSBjYWxsIGBJc0R1c3RgXG5cbmh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luL2JpdGNvaW4vYmxvYi92MjguMC9zcmMvcG9saWN5L3BvbGljeS5jcHAjTDE0NC1MMTQ2XG5cbmBgYFxuaWYgKElzRHVzdCh0eG91dCwgZHVzdF9yZWxheV9mZWUpKSB7XG4gICAgcmVhc29uID0gXCJkdXN0XCI7XG4gICAgcmV0dXJuIGZhbHNlO1xufVxuYGBgXG5cbldoaWNoIGNhbGxzIGBHZXREdXN0VGhyZXNob2xkYCxcblxuaHR0cHM6Ly9naXRodWIuY29tL2JpdGNvaW4vYml0Y29pbi9ibG9iL3YyOC4wL3NyYy9wb2xpY3kvcG9saWN5LmNwcCNMNjdcblxuVGhlIGltcGxlbWVudGF0aW9uIG9mIGBHZXREdXN0VGhyZXNob2xkYCBjb21wdXRlcyB0aGUgbWluaW1hbCB0cmFuc2FjdGlvbiBzaXplIHRoYXQgY2FuIHNwZW5kIHRoZSBvdXRwdXQsIGFuZCBjb21wdXRlc1xuYSBtaW5pbXVtIGZlZSBmb3IgdGhhdCB0cmFuc2FjdGlvbiBzaXplIGJhc2VkIG9uIHRoZSBgZHVzdF9yZWxheV9mZWVgIChGZWVSYXRlKSBwYXJhbWV0ZXIuXG5cblRoZSBkaWZmZXJlbnQgdXR4byBpbXBsZW1lbnRhdGlvbnMgZGlmZmVyIGluIHRoZXNlIHdheXM6XG5cbi0gc29tZSBoYXZlIGEgZml4ZWQsIHNhdG9zaGkgYW1vdW50IGR1c3QgbGltaXQgKGRvZ2UsIHplYylcbi0gc29tZSBoYXZlIGEgZGlmZmVyZW50IGR1c3RfcmVsYXlfZmVlXG5cbiovXG5cbnR5cGUgRHVzdExpbWl0ID0geyBmZWVSYXRlU2F0S0I6IG51bWJlciB9IHwgeyBzYXRBbW91bnQ6IG51bWJlciB9O1xuXG5mdW5jdGlvbiBnZXREdXN0UmVsYXlMaW1pdChuZXR3b3JrOiB1dHhvbGliLk5ldHdvcmspOiBEdXN0TGltaXQge1xuICBuZXR3b3JrID0gdXR4b2xpYi5nZXRNYWlubmV0KG5ldHdvcmspO1xuICBzd2l0Y2ggKG5ldHdvcmspIHtcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pbjpcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmRhc2g6XG4gICAgICAvLyBidGM6ICBodHRwczovL2dpdGh1Yi5jb20vYml0Y29pbi9iaXRjb2luL2Jsb2IvdjI4LjAvc3JjL3BvbGljeS9wb2xpY3kuaCNMNTAtTDU1XG4gICAgICAvLyBidGc6ICBodHRwczovL2dpdGh1Yi5jb20vQlRDR1BVL0JUQ0dQVS9ibG9iL3YwLjE3LjMvc3JjL3BvbGljeS9wb2xpY3kuaCNMNDhcbiAgICAgIC8vIGRhc2g6IGh0dHBzOi8vZ2l0aHViLmNvbS9kYXNocGF5L2Rhc2gvYmxvYi92MjIuMC4wLWJldGEuMS9zcmMvcG9saWN5L3BvbGljeS5oI0w0MS1MNDZcbiAgICAgIHJldHVybiB7IGZlZVJhdGVTYXRLQjogMzAwMCB9O1xuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luY2FzaDpcbiAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luLWNhc2gtbm9kZS9iaXRjb2luLWNhc2gtbm9kZS9ibG9iL3YyNy4xLjAvc3JjL3BvbGljeS9wb2xpY3kuaCNMNzYtTDgzXG4gICAgICAvLyBJIGFjdHVhbGx5IGhhdmVuJ3QgbG9va2VkIGF0IEJTViBhbmQgYW0gZGVwcmVzc2VkIHRoYXQgSSBzdGlsbCBuZWVkIHRvIGhhbmRsZSB0aGUgY2FzZSBoZXJlXG4gICAgICByZXR1cm4geyBmZWVSYXRlU2F0S0I6IDEwMDAgfTtcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuZG9nZWNvaW46XG4gICAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vZG9nZWNvaW4vZG9nZWNvaW4vYmxvYi92MS4xNC44L3NyYy9wb2xpY3kvcG9saWN5LmgjTDY1LUw4MVxuICAgICAgLy8gKENPSU4gLyAxMDApIC8gMTA7XG4gICAgICByZXR1cm4geyBzYXRBbW91bnQ6IDFfMDAwXzAwMCB9O1xuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5saXRlY29pbjpcbiAgICAgIC8vICBodHRwczovL2dpdGh1Yi5jb20vbGl0ZWNvaW4tcHJvamVjdC9saXRlY29pbi9ibG9iL21hc3Rlci9zcmMvcG9saWN5L3BvbGljeS5oI0w0Ny1MNTJcbiAgICAgIHJldHVybiB7IGZlZVJhdGVTYXRLQjogMzBfMDAwIH07XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLnpjYXNoOlxuICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL3pjYXNoL3pjYXNoL2Jsb2IvbWFzdGVyL3NyYy9wcmltaXRpdmVzL3RyYW5zYWN0aW9uLmgjTDM5Ni1MMzk5XG4gICAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vemNhc2gvemNhc2gvYmxvYi92Ni4wLjAvc3JjL3BvbGljeS9wb2xpY3kuaCNMNDMtTDg5IChJIGRvbid0IHF1aXRlIGdldCBpdClcbiAgICAgIHJldHVybiB7IHNhdEFtb3VudDogMzAwIH07XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICAgIHRocm93IG5ldyBFcnJvcignZGVwcmVjYXRlZCBjb2luJyk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcigndW5zdXBwb3J0ZWQgbmV0d29yaycpO1xuICB9XG59XG5cbmZ1bmN0aW9uIGdldFNwZW5kU2l6ZShuZXR3b3JrOiB1dHhvbGliLk5ldHdvcmssIG91dHB1dFNpemU6IG51bWJlciwgaXNXaXRuZXNzOiBib29sZWFuKTogbnVtYmVyIHtcbiAgbmV0d29yayA9IHV0eG9saWIuZ2V0TWFpbm5ldChuZXR3b3JrKTtcbiAgc3dpdGNoIChuZXR3b3JrKSB7XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW46XG4gICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luZ29sZDpcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MubGl0ZWNvaW46XG4gICAgICAvKlxuICAgICAgICBidGM6ICBodHRwczovL2dpdGh1Yi5jb20vYml0Y29pbi9iaXRjb2luL2Jsb2IvdjI4LjAvc3JjL3BvbGljeS9wb2xpY3kuY3BwI0wyNi1MNjhcbiAgICAgICAgYmNoOiAgaHR0cHM6Ly9naXRodWIuY29tL2JpdGNvaW4tY2FzaC1ub2RlL2JpdGNvaW4tY2FzaC1ub2RlL2Jsb2IvdjI3LjEuMC9zcmMvcG9saWN5L3BvbGljeS5jcHAjTDE4LUwzNiAoYnRjLWlzaClcbiAgICAgICAgYnRnOiAgaHR0cHM6Ly9naXRodWIuY29tL0JUQ0dQVS9CVENHUFUvYmxvYi92MC4xNy4zL3NyYy9wb2xpY3kvcG9saWN5LmNwcCNMMTgtTDUwIChidGMtaXNoKVxuICAgICAgICBsdGM6ICBodHRwczovL2dpdGh1Yi5jb20vbGl0ZWNvaW4tcHJvamVjdC9saXRlY29pbi9ibG9iL3YwLjIxLjQvc3JjL3BvbGljeS9wb2xpY3kuY3BwI0wxNS1MNDcgKGJ0Yy1pc2gpXG5cbiAgICAgICAgVGhlIGZpeGVkIGNvbXBvbmVudCBoZXJlIGlzIDY5Ljc1IGZvciBpc1dpdG5lc3M9dHJ1ZSBhbmQgMTUwIGZvciBpc1dpdG5lc3M9ZmFsc2UuXG4gICAgICAgKi9cbiAgICAgIHJldHVybiBvdXRwdXRTaXplICsgMzIgKyA0ICsgMSArIDEwNyAvIChpc1dpdG5lc3MgPyA0IDogMSkgKyA0O1xuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5kYXNoOlxuICAgICAgLy8gZGFzaDogaHR0cHM6Ly9naXRodWIuY29tL2Rhc2hwYXkvZGFzaC9ibG9iL3YyMS4xLjEvc3JjL3BvbGljeS9wb2xpY3kuY3BwI0wxNC1MMzAgKGJ0Yy1pc2gpXG4gICAgICAvLyBob3cgZGlkIHRoZXkgZW5kIHVwIHdpdGggMTQ4PyBJIGRvbid0IGtub3dcbiAgICAgIHJldHVybiBvdXRwdXRTaXplICsgMTQ4O1xuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5kb2dlY29pbjpcbiAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuemNhc2g6XG4gICAgICAvLyBkb2dlOiBodHRwczovL2dpdGh1Yi5jb20vZG9nZWNvaW4vZG9nZWNvaW4vYmxvYi92MS4xNC44L3NyYy9wb2xpY3kvcG9saWN5LmgjTDY1LUw4MSAoaGFyZGNvZGVkKVxuICAgICAgLy8gemVjOiAgaHR0cHM6Ly9naXRodWIuY29tL3pjYXNoL3pjYXNoL2Jsb2IvdjYuMC4wL3NyYy9wb2xpY3kvcG9saWN5LmgjTDQzLUw4OSAoc29tZSB3ZWlyZCBvdGhlciB0aGluZywgZG9nZS1pc2gpXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2R1c3QgbGltaXQgaXMgc2l6ZS1pbmRlcGVuZGVudCcpO1xuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luc3Y6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2RlcHJlY2F0ZWQgY29pbicpO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3Vuc3VwcG9ydGVkIG5ldHdvcmsnKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RHVzdFRocmVzaG9sZFNhdChuZXR3b3JrOiB1dHhvbGliLk5ldHdvcmssIG91dHB1dFNpemU6IG51bWJlciwgaXNXaXRuZXNzOiBib29sZWFuKTogbnVtYmVyIHtcbiAgY29uc3QgZHVzdExpbWl0ID0gZ2V0RHVzdFJlbGF5TGltaXQobmV0d29yayk7XG4gIGlmICgnc2F0QW1vdW50JyBpbiBkdXN0TGltaXQpIHtcbiAgICByZXR1cm4gZHVzdExpbWl0LnNhdEFtb3VudDtcbiAgfVxuICBpZiAoJ2ZlZVJhdGVTYXRLQicgaW4gZHVzdExpbWl0KSB7XG4gICAgY29uc3Qgc3BlbmRTaXplID0gZ2V0U3BlbmRTaXplKG5ldHdvcmssIG91dHB1dFNpemUsIGlzV2l0bmVzcyk7XG4gICAgcmV0dXJuIE1hdGguY2VpbCgoZHVzdExpbWl0LmZlZVJhdGVTYXRLQiAqIHNwZW5kU2l6ZSkgLyAxMDAwKTtcbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoJ3VuZXhwZWN0ZWQgZHVzdExpbWl0Jyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREdXN0VGhyZXNob2xkU2F0Rm9yT3V0cHV0U2NyaXB0KG5ldHdvcms6IHV0eG9saWIuTmV0d29yaywgc2NyaXB0OiBCdWZmZXIpOiBudW1iZXIge1xuICByZXR1cm4gZ2V0RHVzdFRocmVzaG9sZFNhdChuZXR3b3JrLCBzY3JpcHQubGVuZ3RoLCBpc1dpdG5lc3NPdXRwdXRTY3JpcHQoc2NyaXB0KSk7XG59XG4iXX0=
|
|
@@ -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"}
|