@bitgo-beta/abstract-utxo 1.6.1-alpha.256 → 1.6.1-alpha.258
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +3 -2
- package/dist/src/offlineVault/OfflineVaultHalfSigned.js +3 -3
- package/dist/src/offlineVault/{OfflineVaultUnsigned.d.ts → OfflineVaultSignable.d.ts} +3 -3
- package/dist/src/offlineVault/{OfflineVaultUnsigned.d.ts.map → OfflineVaultSignable.d.ts.map} +1 -1
- package/dist/src/offlineVault/{OfflineVaultUnsigned.js → OfflineVaultSignable.js} +3 -3
- package/dist/src/offlineVault/TransactionExplanation.d.ts +15 -0
- package/dist/src/offlineVault/TransactionExplanation.d.ts.map +1 -0
- package/dist/src/offlineVault/TransactionExplanation.js +16 -0
- package/dist/src/offlineVault/descriptor/transaction.d.ts +2 -0
- package/dist/src/offlineVault/descriptor/transaction.d.ts.map +1 -1
- package/dist/src/offlineVault/descriptor/transaction.js +21 -4
- package/dist/src/offlineVault/index.d.ts +3 -0
- package/dist/src/offlineVault/index.d.ts.map +1 -1
- package/dist/src/offlineVault/index.js +4 -2
- package/dist/test/offlineVault/halfSigned.js +5 -2
- package/dist/test/transaction/descriptor/explainPsbt.js +3 -2
- package/dist/test/transaction/descriptor/fixtures.utils.d.ts +5 -1
- package/dist/test/transaction/descriptor/fixtures.utils.d.ts.map +1 -1
- package/dist/test/transaction/descriptor/fixtures.utils.js +9 -4
- package/dist/test/transaction/descriptor/parse.js +5 -4
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -7
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,YAAY,MAAM,gBAAgB,CAAC"}
|
package/dist/src/index.js
CHANGED
|
@@ -36,11 +36,12 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
36
36
|
};
|
|
37
37
|
})();
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.descriptor = void 0;
|
|
39
|
+
exports.offlineVault = exports.descriptor = void 0;
|
|
40
40
|
__exportStar(require("./abstractUtxoCoin"), exports);
|
|
41
41
|
__exportStar(require("./config"), exports);
|
|
42
42
|
__exportStar(require("./recovery"), exports);
|
|
43
43
|
__exportStar(require("./replayProtection"), exports);
|
|
44
44
|
__exportStar(require("./sign"), exports);
|
|
45
45
|
exports.descriptor = __importStar(require("./descriptor"));
|
|
46
|
-
|
|
46
|
+
exports.offlineVault = __importStar(require("./offlineVault"));
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQW1DO0FBQ25DLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IscURBQW1DO0FBQ25DLHlDQUF1QjtBQUd2QiwyREFBMkM7QUFDM0MsK0RBQStDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hYnN0cmFjdFV0eG9Db2luJztcbmV4cG9ydCAqIGZyb20gJy4vY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vcmVjb3ZlcnknO1xuZXhwb3J0ICogZnJvbSAnLi9yZXBsYXlQcm90ZWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vc2lnbic7XG5cbmV4cG9ydCB7IFV0eG9XYWxsZXQgfSBmcm9tICcuL3dhbGxldCc7XG5leHBvcnQgKiBhcyBkZXNjcmlwdG9yIGZyb20gJy4vZGVzY3JpcHRvcic7XG5leHBvcnQgKiBhcyBvZmZsaW5lVmF1bHQgZnJvbSAnLi9vZmZsaW5lVmF1bHQnO1xuIl19
|
|
@@ -37,7 +37,7 @@ exports.createHalfSigned = createHalfSigned;
|
|
|
37
37
|
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
38
38
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
39
39
|
const names_1 = require("../names");
|
|
40
|
-
const
|
|
40
|
+
const OfflineVaultSignable_1 = require("./OfflineVaultSignable");
|
|
41
41
|
const descriptor_1 = require("./descriptor");
|
|
42
42
|
function createHalfSignedFromPsbt(psbt) {
|
|
43
43
|
return { halfSigned: { txHex: psbt.toHex() } };
|
|
@@ -48,7 +48,7 @@ function createHalfSigned(coin, prv, derivationId, tx) {
|
|
|
48
48
|
prv = utxolib.bip32.fromBase58(prv);
|
|
49
49
|
}
|
|
50
50
|
prv = sdk_core_1.BaseCoin.deriveKeyWithSeedBip32(prv, derivationId).key;
|
|
51
|
-
if (!
|
|
51
|
+
if (!OfflineVaultSignable_1.OfflineVaultSignable.is(tx)) {
|
|
52
52
|
throw new Error('unsupported transaction type');
|
|
53
53
|
}
|
|
54
54
|
if (descriptor_1.DescriptorTransaction.is(tx)) {
|
|
@@ -56,4 +56,4 @@ function createHalfSigned(coin, prv, derivationId, tx) {
|
|
|
56
56
|
}
|
|
57
57
|
throw new Error('unsupported transaction type');
|
|
58
58
|
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2ZmbGluZVZhdWx0SGFsZlNpZ25lZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9vZmZsaW5lVmF1bHQvT2ZmbGluZVZhdWx0SGFsZlNpZ25lZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWlCQSw0Q0FrQkM7QUFuQ0QsOERBQWdEO0FBRWhELG1EQUFnRDtBQUVoRCxvQ0FBK0M7QUFFL0MsaUVBQThEO0FBQzlELDZDQUF3RTtBQU14RSxTQUFTLHdCQUF3QixDQUFDLElBQWtCO0lBQ2xELE9BQU8sRUFBRSxVQUFVLEVBQUUsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQztBQUNqRCxDQUFDO0FBRUQsU0FBZ0IsZ0JBQWdCLENBQzlCLElBQVksRUFDWixHQUE0QixFQUM1QixZQUFvQixFQUNwQixFQUFXO0lBRVgsTUFBTSxPQUFPLEdBQUcsSUFBQSwyQkFBbUIsRUFBQyxJQUFJLENBQUMsQ0FBQztJQUMxQyxJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQzVCLEdBQUcsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBQ0QsR0FBRyxHQUFHLG1CQUFRLENBQUMsc0JBQXNCLENBQUMsR0FBRyxFQUFFLFlBQVksQ0FBQyxDQUFDLEdBQUcsQ0FBQztJQUM3RCxJQUFJLENBQUMsMkNBQW9CLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDakMsTUFBTSxJQUFJLEtBQUssQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFDRCxJQUFJLGtDQUFxQixDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQ2pDLE9BQU8sd0JBQXdCLENBQUMsSUFBQSw4QkFBaUIsRUFBQyxFQUFFLEVBQUUsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUNELE1BQU0sSUFBSSxLQUFLLENBQUMsOEJBQThCLENBQUMsQ0FBQztBQUNsRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBCSVAzMkludGVyZmFjZSB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCB7IEJhc2VDb2luIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuXG5pbXBvcnQgeyBnZXROZXR3b3JrRnJvbUNoYWluIH0gZnJvbSAnLi4vbmFtZXMnO1xuXG5pbXBvcnQgeyBPZmZsaW5lVmF1bHRTaWduYWJsZSB9IGZyb20gJy4vT2ZmbGluZVZhdWx0U2lnbmFibGUnO1xuaW1wb3J0IHsgRGVzY3JpcHRvclRyYW5zYWN0aW9uLCBnZXRIYWxmU2lnbmVkUHNidCB9IGZyb20gJy4vZGVzY3JpcHRvcic7XG5cbmV4cG9ydCB0eXBlIE9mZmxpbmVWYXVsdEhhbGZTaWduZWQgPSB7XG4gIGhhbGZTaWduZWQ6IHsgdHhIZXg6IHN0cmluZyB9O1xufTtcblxuZnVuY3Rpb24gY3JlYXRlSGFsZlNpZ25lZEZyb21Qc2J0KHBzYnQ6IHV0eG9saWIuUHNidCk6IE9mZmxpbmVWYXVsdEhhbGZTaWduZWQge1xuICByZXR1cm4geyBoYWxmU2lnbmVkOiB7IHR4SGV4OiBwc2J0LnRvSGV4KCkgfSB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlSGFsZlNpZ25lZChcbiAgY29pbjogc3RyaW5nLFxuICBwcnY6IHN0cmluZyB8IEJJUDMySW50ZXJmYWNlLFxuICBkZXJpdmF0aW9uSWQ6IHN0cmluZyxcbiAgdHg6IHVua25vd25cbik6IE9mZmxpbmVWYXVsdEhhbGZTaWduZWQge1xuICBjb25zdCBuZXR3b3JrID0gZ2V0TmV0d29ya0Zyb21DaGFpbihjb2luKTtcbiAgaWYgKHR5cGVvZiBwcnYgPT09ICdzdHJpbmcnKSB7XG4gICAgcHJ2ID0gdXR4b2xpYi5iaXAzMi5mcm9tQmFzZTU4KHBydik7XG4gIH1cbiAgcHJ2ID0gQmFzZUNvaW4uZGVyaXZlS2V5V2l0aFNlZWRCaXAzMihwcnYsIGRlcml2YXRpb25JZCkua2V5O1xuICBpZiAoIU9mZmxpbmVWYXVsdFNpZ25hYmxlLmlzKHR4KSkge1xuICAgIHRocm93IG5ldyBFcnJvcigndW5zdXBwb3J0ZWQgdHJhbnNhY3Rpb24gdHlwZScpO1xuICB9XG4gIGlmIChEZXNjcmlwdG9yVHJhbnNhY3Rpb24uaXModHgpKSB7XG4gICAgcmV0dXJuIGNyZWF0ZUhhbGZTaWduZWRGcm9tUHNidChnZXRIYWxmU2lnbmVkUHNidCh0eCwgcHJ2LCBuZXR3b3JrKSk7XG4gIH1cbiAgdGhyb3cgbmV3IEVycm9yKCd1bnN1cHBvcnRlZCB0cmFuc2FjdGlvbiB0eXBlJyk7XG59XG4iXX0=
|
|
@@ -10,7 +10,7 @@ export type XPubWithDerivationPath = t.TypeOf<typeof XPubWithDerivationPath>;
|
|
|
10
10
|
/**
|
|
11
11
|
* This is the transaction payload that is sent to the offline vault to sign.
|
|
12
12
|
*/
|
|
13
|
-
export declare const
|
|
13
|
+
export declare const OfflineVaultSignable: t.TypeC<{
|
|
14
14
|
xpubsWithDerivationPath: t.TypeC<{
|
|
15
15
|
user: t.IntersectionC<[t.TypeC<{
|
|
16
16
|
xpub: t.StringC;
|
|
@@ -32,7 +32,7 @@ export declare const OfflineVaultUnsigned: t.TypeC<{
|
|
|
32
32
|
txHex: t.StringC;
|
|
33
33
|
}>;
|
|
34
34
|
}>;
|
|
35
|
-
export type OfflineVaultUnsigned = t.TypeOf<typeof
|
|
35
|
+
export type OfflineVaultUnsigned = t.TypeOf<typeof OfflineVaultSignable>;
|
|
36
36
|
type WithXpub = {
|
|
37
37
|
xpub: string;
|
|
38
38
|
};
|
|
@@ -43,4 +43,4 @@ type NamedKeys = {
|
|
|
43
43
|
};
|
|
44
44
|
export declare function toKeyTriple(xpubs: NamedKeys): Triple<utxolib.BIP32Interface>;
|
|
45
45
|
export {};
|
|
46
|
-
//# sourceMappingURL=
|
|
46
|
+
//# sourceMappingURL=OfflineVaultSignable.d.ts.map
|
package/dist/src/offlineVault/{OfflineVaultUnsigned.d.ts.map → OfflineVaultSignable.d.ts.map}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"
|
|
1
|
+
{"version":3,"file":"OfflineVaultSignable.d.ts","sourceRoot":"","sources":["../../../src/offlineVault/OfflineVaultSignable.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAE3B,eAAO,MAAM,sBAAsB;;;;IAGlC,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,sBAAsB,CAAC,CAAC;AAE7E;;GAEG;AACH,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;EAUhC,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,oBAAoB,CAAC,CAAC;AAEzE,KAAK,QAAQ,GAAG;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC;AACjC,KAAK,SAAS,GAAG;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,QAAQ,CAAC;IAAC,KAAK,EAAE,QAAQ,CAAA;CAAE,CAAC;AACvE,wBAAgB,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAI5E"}
|
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.
|
|
36
|
+
exports.OfflineVaultSignable = exports.XPubWithDerivationPath = void 0;
|
|
37
37
|
exports.toKeyTriple = toKeyTriple;
|
|
38
38
|
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
39
39
|
const t = __importStar(require("io-ts"));
|
|
@@ -41,7 +41,7 @@ exports.XPubWithDerivationPath = t.intersection([t.type({ xpub: t.string }), t.p
|
|
|
41
41
|
/**
|
|
42
42
|
* This is the transaction payload that is sent to the offline vault to sign.
|
|
43
43
|
*/
|
|
44
|
-
exports.
|
|
44
|
+
exports.OfflineVaultSignable = t.type({
|
|
45
45
|
xpubsWithDerivationPath: t.type({
|
|
46
46
|
user: exports.XPubWithDerivationPath,
|
|
47
47
|
backup: exports.XPubWithDerivationPath,
|
|
@@ -52,4 +52,4 @@ exports.OfflineVaultUnsigned = t.type({
|
|
|
52
52
|
function toKeyTriple(xpubs) {
|
|
53
53
|
return [xpubs.user.xpub, xpubs.backup.xpub, xpubs.bitgo.xpub].map((xpub) => utxolib.bip32.fromBase58(xpub));
|
|
54
54
|
}
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2ZmbGluZVZhdWx0U2lnbmFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvb2ZmbGluZVZhdWx0L09mZmxpbmVWYXVsdFNpZ25hYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQThCQSxrQ0FJQztBQWxDRCw4REFBZ0Q7QUFFaEQseUNBQTJCO0FBRWQsUUFBQSxzQkFBc0IsR0FBRyxDQUFDLENBQUMsWUFBWSxDQUNsRCxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxFQUFFLHlCQUF5QixFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQ2hGLHdCQUF3QixDQUN6QixDQUFDO0FBSUY7O0dBRUc7QUFDVSxRQUFBLG9CQUFvQixHQUFHLENBQUMsQ0FBQyxJQUFJLENBQ3hDO0lBQ0UsdUJBQXVCLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUM5QixJQUFJLEVBQUUsOEJBQXNCO1FBQzVCLE1BQU0sRUFBRSw4QkFBc0I7UUFDOUIsS0FBSyxFQUFFLDhCQUFzQjtLQUM5QixDQUFDO0lBQ0YsWUFBWSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO0NBQzFDLEVBQ0QsaUJBQWlCLENBQ2xCLENBQUM7QUFNRixTQUFnQixXQUFXLENBQUMsS0FBZ0I7SUFDMUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDekUsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQ0csQ0FBQztBQUN0QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBUcmlwbGUgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgKiBhcyB0IGZyb20gJ2lvLXRzJztcblxuZXhwb3J0IGNvbnN0IFhQdWJXaXRoRGVyaXZhdGlvblBhdGggPSB0LmludGVyc2VjdGlvbihcbiAgW3QudHlwZSh7IHhwdWI6IHQuc3RyaW5nIH0pLCB0LnBhcnRpYWwoeyBkZXJpdmVkRnJvbVBhcmVudFdpdGhTZWVkOiB0LnN0cmluZyB9KV0sXG4gICdYUHViV2l0aERlcml2YXRpb25QYXRoJ1xuKTtcblxuZXhwb3J0IHR5cGUgWFB1YldpdGhEZXJpdmF0aW9uUGF0aCA9IHQuVHlwZU9mPHR5cGVvZiBYUHViV2l0aERlcml2YXRpb25QYXRoPjtcblxuLyoqXG4gKiBUaGlzIGlzIHRoZSB0cmFuc2FjdGlvbiBwYXlsb2FkIHRoYXQgaXMgc2VudCB0byB0aGUgb2ZmbGluZSB2YXVsdCB0byBzaWduLlxuICovXG5leHBvcnQgY29uc3QgT2ZmbGluZVZhdWx0U2lnbmFibGUgPSB0LnR5cGUoXG4gIHtcbiAgICB4cHVic1dpdGhEZXJpdmF0aW9uUGF0aDogdC50eXBlKHtcbiAgICAgIHVzZXI6IFhQdWJXaXRoRGVyaXZhdGlvblBhdGgsXG4gICAgICBiYWNrdXA6IFhQdWJXaXRoRGVyaXZhdGlvblBhdGgsXG4gICAgICBiaXRnbzogWFB1YldpdGhEZXJpdmF0aW9uUGF0aCxcbiAgICB9KSxcbiAgICBjb2luU3BlY2lmaWM6IHQudHlwZSh7IHR4SGV4OiB0LnN0cmluZyB9KSxcbiAgfSxcbiAgJ0Jhc2VUcmFuc2FjdGlvbidcbik7XG5cbmV4cG9ydCB0eXBlIE9mZmxpbmVWYXVsdFVuc2lnbmVkID0gdC5UeXBlT2Y8dHlwZW9mIE9mZmxpbmVWYXVsdFNpZ25hYmxlPjtcblxudHlwZSBXaXRoWHB1YiA9IHsgeHB1Yjogc3RyaW5nIH07XG50eXBlIE5hbWVkS2V5cyA9IHsgdXNlcjogV2l0aFhwdWI7IGJhY2t1cDogV2l0aFhwdWI7IGJpdGdvOiBXaXRoWHB1YiB9O1xuZXhwb3J0IGZ1bmN0aW9uIHRvS2V5VHJpcGxlKHhwdWJzOiBOYW1lZEtleXMpOiBUcmlwbGU8dXR4b2xpYi5CSVAzMkludGVyZmFjZT4ge1xuICByZXR1cm4gW3hwdWJzLnVzZXIueHB1YiwgeHB1YnMuYmFja3VwLnhwdWIsIHhwdWJzLmJpdGdvLnhwdWJdLm1hcCgoeHB1YikgPT5cbiAgICB1dHhvbGliLmJpcDMyLmZyb21CYXNlNTgoeHB1YilcbiAgKSBhcyBUcmlwbGU8dXR4b2xpYi5CSVAzMkludGVyZmFjZT47XG59XG4iXX0=
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface ExplanationOutput {
|
|
2
|
+
address: string;
|
|
3
|
+
amount: string | number;
|
|
4
|
+
}
|
|
5
|
+
export interface TransactionExplanation {
|
|
6
|
+
outputs: ExplanationOutput[];
|
|
7
|
+
changeOutputs: ExplanationOutput[];
|
|
8
|
+
fee: {
|
|
9
|
+
fee: string | number;
|
|
10
|
+
payGoFeeString: string | number | undefined;
|
|
11
|
+
payGoFeeAddress: string | undefined;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export declare function getTransactionExplanation(coin: string, tx: unknown): TransactionExplanation;
|
|
15
|
+
//# sourceMappingURL=TransactionExplanation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TransactionExplanation.d.ts","sourceRoot":"","sources":["../../../src/offlineVault/TransactionExplanation.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,iBAAiB,EAAE,CAAC;IAC7B,aAAa,EAAE,iBAAiB,EAAE,CAAC;IACnC,GAAG,EAAE;QAEH,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC;QACrB,cAAc,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;QAC5C,eAAe,EAAE,MAAM,GAAG,SAAS,CAAC;KACrC,CAAC;CACH;AAED,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,GAAG,sBAAsB,CAS3F"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getTransactionExplanation = getTransactionExplanation;
|
|
4
|
+
const names_1 = require("../names");
|
|
5
|
+
const OfflineVaultSignable_1 = require("./OfflineVaultSignable");
|
|
6
|
+
const descriptor_1 = require("./descriptor");
|
|
7
|
+
function getTransactionExplanation(coin, tx) {
|
|
8
|
+
if (!OfflineVaultSignable_1.OfflineVaultSignable.is(tx)) {
|
|
9
|
+
throw new Error('not a signable transaction');
|
|
10
|
+
}
|
|
11
|
+
if (descriptor_1.DescriptorTransaction.is(tx)) {
|
|
12
|
+
return (0, descriptor_1.getTransactionExplanationFromPsbt)(tx, (0, names_1.getNetworkFromChain)(coin));
|
|
13
|
+
}
|
|
14
|
+
throw new Error('unsupported transaction type');
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVHJhbnNhY3Rpb25FeHBsYW5hdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9vZmZsaW5lVmF1bHQvVHJhbnNhY3Rpb25FeHBsYW5hdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQXFCQSw4REFTQztBQTlCRCxvQ0FBK0M7QUFFL0MsaUVBQThEO0FBQzlELDZDQUF3RjtBQWtCeEYsU0FBZ0IseUJBQXlCLENBQUMsSUFBWSxFQUFFLEVBQVc7SUFDakUsSUFBSSxDQUFDLDJDQUFvQixDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQ2pDLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBQ0QsSUFBSSxrQ0FBcUIsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUNqQyxPQUFPLElBQUEsOENBQWlDLEVBQUMsRUFBRSxFQUFFLElBQUEsMkJBQW1CLEVBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUMxRSxDQUFDO0lBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDO0FBQ2xELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXROZXR3b3JrRnJvbUNoYWluIH0gZnJvbSAnLi4vbmFtZXMnO1xuXG5pbXBvcnQgeyBPZmZsaW5lVmF1bHRTaWduYWJsZSB9IGZyb20gJy4vT2ZmbGluZVZhdWx0U2lnbmFibGUnO1xuaW1wb3J0IHsgRGVzY3JpcHRvclRyYW5zYWN0aW9uLCBnZXRUcmFuc2FjdGlvbkV4cGxhbmF0aW9uRnJvbVBzYnQgfSBmcm9tICcuL2Rlc2NyaXB0b3InO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV4cGxhbmF0aW9uT3V0cHV0IHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBhbW91bnQ6IHN0cmluZyB8IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbkV4cGxhbmF0aW9uIHtcbiAgb3V0cHV0czogRXhwbGFuYXRpb25PdXRwdXRbXTtcbiAgY2hhbmdlT3V0cHV0czogRXhwbGFuYXRpb25PdXRwdXRbXTtcbiAgZmVlOiB7XG4gICAgLyogbmV0d29yayBmZWUgKi9cbiAgICBmZWU6IHN0cmluZyB8IG51bWJlcjtcbiAgICBwYXlHb0ZlZVN0cmluZzogc3RyaW5nIHwgbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIHBheUdvRmVlQWRkcmVzczogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0VHJhbnNhY3Rpb25FeHBsYW5hdGlvbihjb2luOiBzdHJpbmcsIHR4OiB1bmtub3duKTogVHJhbnNhY3Rpb25FeHBsYW5hdGlvbiB7XG4gIGlmICghT2ZmbGluZVZhdWx0U2lnbmFibGUuaXModHgpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdub3QgYSBzaWduYWJsZSB0cmFuc2FjdGlvbicpO1xuICB9XG4gIGlmIChEZXNjcmlwdG9yVHJhbnNhY3Rpb24uaXModHgpKSB7XG4gICAgcmV0dXJuIGdldFRyYW5zYWN0aW9uRXhwbGFuYXRpb25Gcm9tUHNidCh0eCwgZ2V0TmV0d29ya0Zyb21DaGFpbihjb2luKSk7XG4gIH1cblxuICB0aHJvdyBuZXcgRXJyb3IoJ3Vuc3VwcG9ydGVkIHRyYW5zYWN0aW9uIHR5cGUnKTtcbn1cbiJdfQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
2
2
|
import * as t from 'io-ts';
|
|
3
3
|
import { DescriptorMap } from '../../core/descriptor';
|
|
4
|
+
import { TransactionExplanation } from '../TransactionExplanation';
|
|
4
5
|
export declare const DescriptorTransaction: t.IntersectionC<[t.TypeC<{
|
|
5
6
|
xpubsWithDerivationPath: t.TypeC<{
|
|
6
7
|
user: t.IntersectionC<[t.TypeC<{
|
|
@@ -33,4 +34,5 @@ export declare const DescriptorTransaction: t.IntersectionC<[t.TypeC<{
|
|
|
33
34
|
export type DescriptorTransaction = t.TypeOf<typeof DescriptorTransaction>;
|
|
34
35
|
export declare function getDescriptorsFromDescriptorTransaction(tx: DescriptorTransaction): DescriptorMap;
|
|
35
36
|
export declare function getHalfSignedPsbt(tx: DescriptorTransaction, prv: utxolib.BIP32Interface, network: utxolib.Network): utxolib.Psbt;
|
|
37
|
+
export declare function getTransactionExplanationFromPsbt(tx: DescriptorTransaction, network: utxolib.Network): TransactionExplanation;
|
|
36
38
|
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../../src/offlineVault/descriptor/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAU3B,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../../src/offlineVault/descriptor/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAU3B,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAEnE,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAGjC,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAE3E,wBAAgB,uCAAuC,CAAC,EAAE,EAAE,qBAAqB,GAAG,aAAa,CAUhG;AAED,wBAAgB,iBAAiB,CAC/B,EAAE,EAAE,qBAAqB,EACzB,GAAG,EAAE,OAAO,CAAC,cAAc,EAC3B,OAAO,EAAE,OAAO,CAAC,OAAO,GACvB,OAAO,CAAC,IAAI,CAKd;AAED,wBAAgB,iCAAiC,CAC/C,EAAE,EAAE,qBAAqB,EACzB,OAAO,EAAE,OAAO,CAAC,OAAO,GACvB,sBAAsB,CAexB"}
|
|
@@ -36,16 +36,17 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
36
|
exports.DescriptorTransaction = void 0;
|
|
37
37
|
exports.getDescriptorsFromDescriptorTransaction = getDescriptorsFromDescriptorTransaction;
|
|
38
38
|
exports.getHalfSignedPsbt = getHalfSignedPsbt;
|
|
39
|
+
exports.getTransactionExplanationFromPsbt = getTransactionExplanationFromPsbt;
|
|
39
40
|
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
40
41
|
const t = __importStar(require("io-ts"));
|
|
41
42
|
const descriptor_1 = require("../../descriptor");
|
|
42
|
-
const
|
|
43
|
+
const OfflineVaultSignable_1 = require("../OfflineVaultSignable");
|
|
43
44
|
const validatePolicy_1 = require("../../descriptor/validatePolicy");
|
|
44
45
|
const descriptor_2 = require("../../transaction/descriptor");
|
|
45
|
-
exports.DescriptorTransaction = t.intersection([
|
|
46
|
+
exports.DescriptorTransaction = t.intersection([OfflineVaultSignable_1.OfflineVaultSignable, t.type({ descriptors: t.array(descriptor_1.NamedDescriptor) })], 'DescriptorTransaction');
|
|
46
47
|
function getDescriptorsFromDescriptorTransaction(tx) {
|
|
47
48
|
const { descriptors, xpubsWithDerivationPath } = tx;
|
|
48
|
-
const pubkeys = (0,
|
|
49
|
+
const pubkeys = (0, OfflineVaultSignable_1.toKeyTriple)(xpubsWithDerivationPath);
|
|
49
50
|
const policy = (0, validatePolicy_1.getValidatorSome)([
|
|
50
51
|
// allow all 2-of-3-ish descriptors where the keys match the wallet keys
|
|
51
52
|
(0, validatePolicy_1.getValidatorOneOfTemplates)(['Wsh2Of3', 'Wsh2Of3CltvDrop', 'ShWsh2Of3CltvDrop']),
|
|
@@ -60,4 +61,20 @@ function getHalfSignedPsbt(tx, prv, network) {
|
|
|
60
61
|
(0, descriptor_2.signPsbt)(psbt, descriptorMap, prv, { onUnknownInput: 'throw' });
|
|
61
62
|
return psbt;
|
|
62
63
|
}
|
|
63
|
-
|
|
64
|
+
function getTransactionExplanationFromPsbt(tx, network) {
|
|
65
|
+
const psbt = utxolib.bitgo.createPsbtDecode(tx.coinSpecific.txHex, network);
|
|
66
|
+
const descriptorMap = getDescriptorsFromDescriptorTransaction(tx);
|
|
67
|
+
const { outputs, changeOutputs, fee } = (0, descriptor_2.explainPsbt)(psbt, descriptorMap);
|
|
68
|
+
return {
|
|
69
|
+
outputs,
|
|
70
|
+
changeOutputs,
|
|
71
|
+
fee: {
|
|
72
|
+
/* network fee */
|
|
73
|
+
fee,
|
|
74
|
+
/* TODO */
|
|
75
|
+
payGoFeeString: undefined,
|
|
76
|
+
payGoFeeAddress: undefined,
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvb2ZmbGluZVZhdWx0L2Rlc2NyaXB0b3IvdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBc0JBLDBGQVVDO0FBRUQsOENBU0M7QUFFRCw4RUFrQkM7QUEvREQsOERBQWdEO0FBQ2hELHlDQUEyQjtBQUUzQixpREFBbUQ7QUFDbkQsa0VBQTRFO0FBQzVFLG9FQUt5QztBQUV6Qyw2REFBcUU7QUFHeEQsUUFBQSxxQkFBcUIsR0FBRyxDQUFDLENBQUMsWUFBWSxDQUNqRCxDQUFDLDJDQUFvQixFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyw0QkFBZSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQ3pFLHVCQUF1QixDQUN4QixDQUFDO0FBSUYsU0FBZ0IsdUNBQXVDLENBQUMsRUFBeUI7SUFDL0UsTUFBTSxFQUFFLFdBQVcsRUFBRSx1QkFBdUIsRUFBRSxHQUFHLEVBQUUsQ0FBQztJQUNwRCxNQUFNLE9BQU8sR0FBRyxJQUFBLGtDQUFXLEVBQUMsdUJBQXVCLENBQUMsQ0FBQztJQUNyRCxNQUFNLE1BQU0sR0FBRyxJQUFBLGlDQUFnQixFQUFDO1FBQzlCLHdFQUF3RTtRQUN4RSxJQUFBLDJDQUEwQixFQUFDLENBQUMsU0FBUyxFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixDQUFDLENBQUM7UUFDL0UsK0NBQStDO1FBQy9DLElBQUEsNENBQTJCLEdBQUU7S0FDOUIsQ0FBQyxDQUFDO0lBQ0gsT0FBTyxJQUFBLHdDQUF1QixFQUFDLFdBQVcsRUFBRSxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7QUFDL0QsQ0FBQztBQUVELFNBQWdCLGlCQUFpQixDQUMvQixFQUF5QixFQUN6QixHQUEyQixFQUMzQixPQUF3QjtJQUV4QixNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVFLE1BQU0sYUFBYSxHQUFHLHVDQUF1QyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLElBQUEscUJBQVEsRUFBQyxJQUFJLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxFQUFFLGNBQWMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ2hFLE9BQU8sSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUVELFNBQWdCLGlDQUFpQyxDQUMvQyxFQUF5QixFQUN6QixPQUF3QjtJQUV4QixNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVFLE1BQU0sYUFBYSxHQUFHLHVDQUF1QyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLE1BQU0sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxHQUFHLElBQUEsd0JBQVcsRUFBQyxJQUFJLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDekUsT0FBTztRQUNMLE9BQU87UUFDUCxhQUFhO1FBQ2IsR0FBRyxFQUFFO1lBQ0gsaUJBQWlCO1lBQ2pCLEdBQUc7WUFDSCxVQUFVO1lBQ1YsY0FBYyxFQUFFLFNBQVM7WUFDekIsZUFBZSxFQUFFLFNBQVM7U0FDM0I7S0FDRixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0ICogYXMgdCBmcm9tICdpby10cyc7XG5cbmltcG9ydCB7IE5hbWVkRGVzY3JpcHRvciB9IGZyb20gJy4uLy4uL2Rlc2NyaXB0b3InO1xuaW1wb3J0IHsgT2ZmbGluZVZhdWx0U2lnbmFibGUsIHRvS2V5VHJpcGxlIH0gZnJvbSAnLi4vT2ZmbGluZVZhdWx0U2lnbmFibGUnO1xuaW1wb3J0IHtcbiAgZ2V0VmFsaWRhdG9yT25lT2ZUZW1wbGF0ZXMsXG4gIGdldFZhbGlkYXRvclNpZ25lZEJ5VXNlcktleSxcbiAgZ2V0VmFsaWRhdG9yU29tZSxcbiAgdG9EZXNjcmlwdG9yTWFwVmFsaWRhdGUsXG59IGZyb20gJy4uLy4uL2Rlc2NyaXB0b3IvdmFsaWRhdGVQb2xpY3knO1xuaW1wb3J0IHsgRGVzY3JpcHRvck1hcCB9IGZyb20gJy4uLy4uL2NvcmUvZGVzY3JpcHRvcic7XG5pbXBvcnQgeyBleHBsYWluUHNidCwgc2lnblBzYnQgfSBmcm9tICcuLi8uLi90cmFuc2FjdGlvbi9kZXNjcmlwdG9yJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gfSBmcm9tICcuLi9UcmFuc2FjdGlvbkV4cGxhbmF0aW9uJztcblxuZXhwb3J0IGNvbnN0IERlc2NyaXB0b3JUcmFuc2FjdGlvbiA9IHQuaW50ZXJzZWN0aW9uKFxuICBbT2ZmbGluZVZhdWx0U2lnbmFibGUsIHQudHlwZSh7IGRlc2NyaXB0b3JzOiB0LmFycmF5KE5hbWVkRGVzY3JpcHRvcikgfSldLFxuICAnRGVzY3JpcHRvclRyYW5zYWN0aW9uJ1xuKTtcblxuZXhwb3J0IHR5cGUgRGVzY3JpcHRvclRyYW5zYWN0aW9uID0gdC5UeXBlT2Y8dHlwZW9mIERlc2NyaXB0b3JUcmFuc2FjdGlvbj47XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREZXNjcmlwdG9yc0Zyb21EZXNjcmlwdG9yVHJhbnNhY3Rpb24odHg6IERlc2NyaXB0b3JUcmFuc2FjdGlvbik6IERlc2NyaXB0b3JNYXAge1xuICBjb25zdCB7IGRlc2NyaXB0b3JzLCB4cHVic1dpdGhEZXJpdmF0aW9uUGF0aCB9ID0gdHg7XG4gIGNvbnN0IHB1YmtleXMgPSB0b0tleVRyaXBsZSh4cHVic1dpdGhEZXJpdmF0aW9uUGF0aCk7XG4gIGNvbnN0IHBvbGljeSA9IGdldFZhbGlkYXRvclNvbWUoW1xuICAgIC8vIGFsbG93IGFsbCAyLW9mLTMtaXNoIGRlc2NyaXB0b3JzIHdoZXJlIHRoZSBrZXlzIG1hdGNoIHRoZSB3YWxsZXQga2V5c1xuICAgIGdldFZhbGlkYXRvck9uZU9mVGVtcGxhdGVzKFsnV3NoMk9mMycsICdXc2gyT2YzQ2x0dkRyb3AnLCAnU2hXc2gyT2YzQ2x0dkRyb3AnXSksXG4gICAgLy8gYWxsb3cgYWxsIGRlc2NyaXB0b3JzIHNpZ25lZCBieSB0aGUgdXNlciBrZXlcbiAgICBnZXRWYWxpZGF0b3JTaWduZWRCeVVzZXJLZXkoKSxcbiAgXSk7XG4gIHJldHVybiB0b0Rlc2NyaXB0b3JNYXBWYWxpZGF0ZShkZXNjcmlwdG9ycywgcHVia2V5cywgcG9saWN5KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEhhbGZTaWduZWRQc2J0KFxuICB0eDogRGVzY3JpcHRvclRyYW5zYWN0aW9uLFxuICBwcnY6IHV0eG9saWIuQklQMzJJbnRlcmZhY2UsXG4gIG5ldHdvcms6IHV0eG9saWIuTmV0d29ya1xuKTogdXR4b2xpYi5Qc2J0IHtcbiAgY29uc3QgcHNidCA9IHV0eG9saWIuYml0Z28uY3JlYXRlUHNidERlY29kZSh0eC5jb2luU3BlY2lmaWMudHhIZXgsIG5ldHdvcmspO1xuICBjb25zdCBkZXNjcmlwdG9yTWFwID0gZ2V0RGVzY3JpcHRvcnNGcm9tRGVzY3JpcHRvclRyYW5zYWN0aW9uKHR4KTtcbiAgc2lnblBzYnQocHNidCwgZGVzY3JpcHRvck1hcCwgcHJ2LCB7IG9uVW5rbm93bklucHV0OiAndGhyb3cnIH0pO1xuICByZXR1cm4gcHNidDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFRyYW5zYWN0aW9uRXhwbGFuYXRpb25Gcm9tUHNidChcbiAgdHg6IERlc2NyaXB0b3JUcmFuc2FjdGlvbixcbiAgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrXG4pOiBUcmFuc2FjdGlvbkV4cGxhbmF0aW9uIHtcbiAgY29uc3QgcHNidCA9IHV0eG9saWIuYml0Z28uY3JlYXRlUHNidERlY29kZSh0eC5jb2luU3BlY2lmaWMudHhIZXgsIG5ldHdvcmspO1xuICBjb25zdCBkZXNjcmlwdG9yTWFwID0gZ2V0RGVzY3JpcHRvcnNGcm9tRGVzY3JpcHRvclRyYW5zYWN0aW9uKHR4KTtcbiAgY29uc3QgeyBvdXRwdXRzLCBjaGFuZ2VPdXRwdXRzLCBmZWUgfSA9IGV4cGxhaW5Qc2J0KHBzYnQsIGRlc2NyaXB0b3JNYXApO1xuICByZXR1cm4ge1xuICAgIG91dHB1dHMsXG4gICAgY2hhbmdlT3V0cHV0cyxcbiAgICBmZWU6IHtcbiAgICAgIC8qIG5ldHdvcmsgZmVlICovXG4gICAgICBmZWUsXG4gICAgICAvKiBUT0RPICovXG4gICAgICBwYXlHb0ZlZVN0cmluZzogdW5kZWZpbmVkLFxuICAgICAgcGF5R29GZWVBZGRyZXNzOiB1bmRlZmluZWQsXG4gICAgfSxcbiAgfTtcbn1cbiJdfQ==
|
|
@@ -1,3 +1,6 @@
|
|
|
1
1
|
export * as descriptor from './descriptor';
|
|
2
2
|
export * from './OfflineVaultHalfSigned';
|
|
3
|
+
export { getTransactionExplanation } from './TransactionExplanation';
|
|
4
|
+
export { TransactionExplanation } from './TransactionExplanation';
|
|
5
|
+
export { ExplanationOutput } from './TransactionExplanation';
|
|
3
6
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/offlineVault/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/offlineVault/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,0BAA0B,CAAC;AACzC,OAAO,EAAE,yBAAyB,EAAE,MAAM,0BAA0B,CAAC;AACrE,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC"}
|
|
@@ -36,7 +36,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
36
36
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
37
37
|
};
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.descriptor = void 0;
|
|
39
|
+
exports.getTransactionExplanation = exports.descriptor = void 0;
|
|
40
40
|
exports.descriptor = __importStar(require("./descriptor"));
|
|
41
41
|
__exportStar(require("./OfflineVaultHalfSigned"), exports);
|
|
42
|
-
|
|
42
|
+
var TransactionExplanation_1 = require("./TransactionExplanation");
|
|
43
|
+
Object.defineProperty(exports, "getTransactionExplanation", { enumerable: true, get: function () { return TransactionExplanation_1.getTransactionExplanation; } });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvb2ZmbGluZVZhdWx0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJEQUEyQztBQUMzQywyREFBeUM7QUFDekMsbUVBQXFFO0FBQTVELG1JQUFBLHlCQUF5QixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogYXMgZGVzY3JpcHRvciBmcm9tICcuL2Rlc2NyaXB0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9PZmZsaW5lVmF1bHRIYWxmU2lnbmVkJztcbmV4cG9ydCB7IGdldFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gfSBmcm9tICcuL1RyYW5zYWN0aW9uRXhwbGFuYXRpb24nO1xuZXhwb3J0IHsgVHJhbnNhY3Rpb25FeHBsYW5hdGlvbiB9IGZyb20gJy4vVHJhbnNhY3Rpb25FeHBsYW5hdGlvbic7XG5leHBvcnQgeyBFeHBsYW5hdGlvbk91dHB1dCB9IGZyb20gJy4vVHJhbnNhY3Rpb25FeHBsYW5hdGlvbic7XG4iXX0=
|
|
@@ -44,10 +44,12 @@ const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
|
44
44
|
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
45
45
|
const offlineVault_1 = require("../../src/offlineVault");
|
|
46
46
|
const descriptor_1 = require("../../src/offlineVault/descriptor");
|
|
47
|
+
const fixtures_utils_1 = require("../transaction/descriptor/fixtures.utils");
|
|
48
|
+
const { assertEqualFixture } = (0, fixtures_utils_1.getFixtureRoot)(__dirname + '/fixtures');
|
|
47
49
|
function getFixturesNames() {
|
|
48
50
|
// I'm using sync here because mocha cannot do async setup
|
|
49
51
|
// eslint-disable-next-line no-sync
|
|
50
|
-
return fs.readdirSync(__dirname + '/fixtures').filter((f) => f.endsWith('.json'));
|
|
52
|
+
return fs.readdirSync(__dirname + '/fixtures').filter((f) => f.endsWith('.json') && !f.endsWith('.explanation.json'));
|
|
51
53
|
}
|
|
52
54
|
const KeyPair = t.intersection([t.type({ xpub: t.string }), t.partial({ xprv: t.string })]);
|
|
53
55
|
const KeyWithParent = t.intersection([KeyPair, t.partial({ parent: KeyPair })]);
|
|
@@ -115,7 +117,8 @@ describe('OfflineVaultHalfSigned', function () {
|
|
|
115
117
|
for (const mutation of mutations) {
|
|
116
118
|
assert_1.default.throws(() => (0, offlineVault_1.createHalfSigned)('btc', rootPrv, derivationId, mutation));
|
|
117
119
|
}
|
|
120
|
+
await assertEqualFixture(fixtureName.replace(/\.json$/, '.explanation.json'), (0, offlineVault_1.getTransactionExplanation)('btc', response));
|
|
118
121
|
});
|
|
119
122
|
}
|
|
120
123
|
});
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"halfSigned.js","sourceRoot":"","sources":["../../../test/offlineVault/halfSigned.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport assert from 'assert';\nimport crypto from 'crypto';\n\nimport * as t from 'io-ts';\nimport { decodeOrElse } from '@bitgo-beta/sdk-core';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { createHalfSigned, getTransactionExplanation } from '../../src/offlineVault';\nimport { DescriptorTransaction } from '../../src/offlineVault/descriptor';\nimport { getFixtureRoot } from '../transaction/descriptor/fixtures.utils';\n\nconst { assertEqualFixture } = getFixtureRoot(__dirname + '/fixtures');\n\nfunction getFixturesNames(): string[] {\n  // I'm using sync here because mocha cannot do async setup\n  // eslint-disable-next-line no-sync\n  return fs.readdirSync(__dirname + '/fixtures').filter((f) => f.endsWith('.json') && !f.endsWith('.explanation.json'));\n}\n\nconst KeyPair = t.intersection([t.type({ xpub: t.string }), t.partial({ xprv: t.string })]);\n\nconst KeyWithParent = t.intersection([KeyPair, t.partial({ parent: KeyPair })]);\ntype KeyWithParent = t.TypeOf<typeof KeyWithParent>;\n\nconst Fixture = t.type({\n  walletKeys: t.array(KeyWithParent),\n  response: t.unknown,\n});\n\ntype Fixture = t.TypeOf<typeof Fixture>;\n\nasync function readFixture(name: string): Promise<Fixture> {\n  const data = JSON.parse(await fs.promises.readFile(__dirname + '/fixtures/' + name, 'utf-8'));\n  return decodeOrElse('Fixture', Fixture, data, (e) => {\n    throw new Error(`failed to decode fixture ${name}: ${e}`);\n  });\n}\n\nfunction withRotatedXpubs(tx: DescriptorTransaction): DescriptorTransaction {\n  const { user, backup, bitgo } = tx.xpubsWithDerivationPath;\n  return {\n    ...tx,\n    xpubsWithDerivationPath: {\n      user: bitgo,\n      backup: user,\n      bitgo: backup,\n    },\n  };\n}\n\nfunction withRandomXpubs(tx: DescriptorTransaction) {\n  function randomXpub() {\n    const bytes = crypto.getRandomValues(new Uint8Array(32));\n    return utxolib.bip32.fromSeed(Buffer.from(bytes)).neutered().toBase58();\n  }\n  return {\n    ...tx,\n    xpubsWithDerivationPath: {\n      user: randomXpub(),\n      backup: randomXpub(),\n      bitgo: randomXpub(),\n    },\n  };\n}\n\nfunction withoutDescriptors(tx: DescriptorTransaction): DescriptorTransaction {\n  return {\n    ...tx,\n    descriptors: [],\n  };\n}\n\nfunction getDerivationId(v: DescriptorTransaction['xpubsWithDerivationPath']): string {\n  const id = v.user.derivedFromParentWithSeed;\n  assert(id);\n  return id;\n}\n\nfunction getRootPrv(walletKeys: KeyWithParent[]): utxolib.BIP32Interface {\n  assert(walletKeys[0]);\n  assert(walletKeys[0].parent);\n  assert(walletKeys[0].parent.xprv);\n  return utxolib.bip32.fromBase58(walletKeys[0].parent.xprv);\n}\n\ndescribe('OfflineVaultHalfSigned', function () {\n  for (const fixtureName of getFixturesNames()) {\n    it(`can sign fixture ${fixtureName}`, async function () {\n      const { walletKeys, response } = await readFixture(fixtureName);\n      assert(DescriptorTransaction.is(response));\n      const rootPrv = getRootPrv(walletKeys);\n      const derivationId = getDerivationId(response.xpubsWithDerivationPath);\n      createHalfSigned('btc', rootPrv, derivationId, response);\n      const mutations = [withRotatedXpubs(response), withRandomXpubs(response), withoutDescriptors(response)];\n      for (const mutation of mutations) {\n        assert.throws(() => createHalfSigned('btc', rootPrv, derivationId, mutation));\n      }\n      await assertEqualFixture(\n        fixtureName.replace(/\\.json$/, '.explanation.json'),\n        getTransactionExplanation('btc', response)\n      );\n    });\n  }\n});\n"]}
|
|
@@ -9,6 +9,7 @@ const mock_utils_1 = require("../../core/descriptor/psbt/mock.utils");
|
|
|
9
9
|
const descriptor_utils_1 = require("../../core/descriptor/descriptor.utils");
|
|
10
10
|
const key_utils_1 = require("../../core/key.utils");
|
|
11
11
|
const fixtures_utils_1 = require("./fixtures.utils");
|
|
12
|
+
const { assertEqualFixture } = (0, fixtures_utils_1.getFixtureRoot)(__dirname + '/fixtures');
|
|
12
13
|
function assertSignatureCount(expl, signatures, inputSignatures) {
|
|
13
14
|
assert_1.default.deepStrictEqual(expl.signatures, signatures);
|
|
14
15
|
assert_1.default.deepStrictEqual(expl.inputSignatures, inputSignatures);
|
|
@@ -18,11 +19,11 @@ describe('explainPsbt', function () {
|
|
|
18
19
|
const psbt = (0, mock_utils_1.mockPsbtDefaultWithDescriptorTemplate)('Wsh2Of3');
|
|
19
20
|
const keys = (0, key_utils_1.getKeyTriple)('a');
|
|
20
21
|
const descriptorMap = (0, descriptor_utils_1.getDescriptorMap)('Wsh2Of3', keys);
|
|
21
|
-
await
|
|
22
|
+
await assertEqualFixture('explainPsbt.a.json', (0, descriptor_1.explainPsbt)(psbt, descriptorMap));
|
|
22
23
|
psbt.signAllInputsHD(keys[0]);
|
|
23
24
|
assertSignatureCount((0, descriptor_1.explainPsbt)(psbt, descriptorMap), 1, [1, 1]);
|
|
24
25
|
psbt.signAllInputsHD(keys[1]);
|
|
25
26
|
assertSignatureCount((0, descriptor_1.explainPsbt)(psbt, descriptorMap), 2, [2, 2]);
|
|
26
27
|
});
|
|
27
28
|
});
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwbGFpblBzYnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0L3RyYW5zYWN0aW9uL2Rlc2NyaXB0b3IvZXhwbGFpblBzYnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxvREFBNEI7QUFHNUIsb0VBQWtFO0FBQ2xFLHNFQUE4RjtBQUM5Riw2RUFBMEU7QUFDMUUsb0RBQW9EO0FBRXBELHFEQUFrRDtBQUVsRCxNQUFNLEVBQUUsa0JBQWtCLEVBQUUsR0FBRyxJQUFBLCtCQUFjLEVBQUMsU0FBUyxHQUFHLFdBQVcsQ0FBQyxDQUFDO0FBRXZFLFNBQVMsb0JBQW9CLENBQUMsSUFBNEIsRUFBRSxVQUFrQixFQUFFLGVBQXlCO0lBQ3ZHLGdCQUFNLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDcEQsZ0JBQU0sQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxlQUFlLENBQUMsQ0FBQztBQUNoRSxDQUFDO0FBRUQsUUFBUSxDQUFDLGFBQWEsRUFBRTtJQUN0QixFQUFFLENBQUMscUJBQXFCLEVBQUUsS0FBSztRQUM3QixNQUFNLElBQUksR0FBRyxJQUFBLGtEQUFxQyxFQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzlELE1BQU0sSUFBSSxHQUFHLElBQUEsd0JBQVksRUFBQyxHQUFHLENBQUMsQ0FBQztRQUMvQixNQUFNLGFBQWEsR0FBRyxJQUFBLG1DQUFnQixFQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN4RCxNQUFNLGtCQUFrQixDQUFDLG9CQUFvQixFQUFFLElBQUEsd0JBQVcsRUFBQyxJQUFJLEVBQUUsYUFBYSxDQUFDLENBQUMsQ0FBQztRQUNqRixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzlCLG9CQUFvQixDQUFDLElBQUEsd0JBQVcsRUFBQyxJQUFJLEVBQUUsYUFBYSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM5QixvQkFBb0IsQ0FBQyxJQUFBLHdCQUFXLEVBQUMsSUFBSSxFQUFFLGFBQWEsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3BFLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCB7IFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gfSBmcm9tICcuLi8uLi8uLi9zcmMnO1xuaW1wb3J0IHsgZXhwbGFpblBzYnQgfSBmcm9tICcuLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZGVzY3JpcHRvcic7XG5pbXBvcnQgeyBtb2NrUHNidERlZmF1bHRXaXRoRGVzY3JpcHRvclRlbXBsYXRlIH0gZnJvbSAnLi4vLi4vY29yZS9kZXNjcmlwdG9yL3BzYnQvbW9jay51dGlscyc7XG5pbXBvcnQgeyBnZXREZXNjcmlwdG9yTWFwIH0gZnJvbSAnLi4vLi4vY29yZS9kZXNjcmlwdG9yL2Rlc2NyaXB0b3IudXRpbHMnO1xuaW1wb3J0IHsgZ2V0S2V5VHJpcGxlIH0gZnJvbSAnLi4vLi4vY29yZS9rZXkudXRpbHMnO1xuXG5pbXBvcnQgeyBnZXRGaXh0dXJlUm9vdCB9IGZyb20gJy4vZml4dHVyZXMudXRpbHMnO1xuXG5jb25zdCB7IGFzc2VydEVxdWFsRml4dHVyZSB9ID0gZ2V0Rml4dHVyZVJvb3QoX19kaXJuYW1lICsgJy9maXh0dXJlcycpO1xuXG5mdW5jdGlvbiBhc3NlcnRTaWduYXR1cmVDb3VudChleHBsOiBUcmFuc2FjdGlvbkV4cGxhbmF0aW9uLCBzaWduYXR1cmVzOiBudW1iZXIsIGlucHV0U2lnbmF0dXJlczogbnVtYmVyW10pIHtcbiAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChleHBsLnNpZ25hdHVyZXMsIHNpZ25hdHVyZXMpO1xuICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKGV4cGwuaW5wdXRTaWduYXR1cmVzLCBpbnB1dFNpZ25hdHVyZXMpO1xufVxuXG5kZXNjcmliZSgnZXhwbGFpblBzYnQnLCBmdW5jdGlvbiAoKSB7XG4gIGl0KCdoYXMgZXhwZWN0ZWQgdmFsdWVzJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgIGNvbnN0IHBzYnQgPSBtb2NrUHNidERlZmF1bHRXaXRoRGVzY3JpcHRvclRlbXBsYXRlKCdXc2gyT2YzJyk7XG4gICAgY29uc3Qga2V5cyA9IGdldEtleVRyaXBsZSgnYScpO1xuICAgIGNvbnN0IGRlc2NyaXB0b3JNYXAgPSBnZXREZXNjcmlwdG9yTWFwKCdXc2gyT2YzJywga2V5cyk7XG4gICAgYXdhaXQgYXNzZXJ0RXF1YWxGaXh0dXJlKCdleHBsYWluUHNidC5hLmpzb24nLCBleHBsYWluUHNidChwc2J0LCBkZXNjcmlwdG9yTWFwKSk7XG4gICAgcHNidC5zaWduQWxsSW5wdXRzSEQoa2V5c1swXSk7XG4gICAgYXNzZXJ0U2lnbmF0dXJlQ291bnQoZXhwbGFpblBzYnQocHNidCwgZGVzY3JpcHRvck1hcCksIDEsIFsxLCAxXSk7XG4gICAgcHNidC5zaWduQWxsSW5wdXRzSEQoa2V5c1sxXSk7XG4gICAgYXNzZXJ0U2lnbmF0dXJlQ291bnQoZXhwbGFpblBzYnQocHNidCwgZGVzY3JpcHRvck1hcCksIDIsIFsyLCAyXSk7XG4gIH0pO1xufSk7XG4iXX0=
|
|
@@ -1,2 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
interface FixtureRoot {
|
|
2
|
+
assertEqualFixture(name: string, v: unknown): Promise<void>;
|
|
3
|
+
}
|
|
4
|
+
export declare function getFixtureRoot(root: string): FixtureRoot;
|
|
5
|
+
export {};
|
|
2
6
|
//# sourceMappingURL=fixtures.utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fixtures.utils.d.ts","sourceRoot":"","sources":["../../../../test/transaction/descriptor/fixtures.utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"fixtures.utils.d.ts","sourceRoot":"","sources":["../../../../test/transaction/descriptor/fixtures.utils.ts"],"names":[],"mappings":"AAKA,UAAU,WAAW;IACnB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7D;AAID,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,CAMxD"}
|
|
@@ -3,10 +3,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
6
|
+
exports.getFixtureRoot = getFixtureRoot;
|
|
7
7
|
const assert_1 = __importDefault(require("assert"));
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
8
9
|
const fixtures_utils_1 = require("../../core/fixtures.utils");
|
|
9
|
-
|
|
10
|
-
|
|
10
|
+
function getFixtureRoot(root) {
|
|
11
|
+
return {
|
|
12
|
+
async assertEqualFixture(name, v, normalize = fixtures_utils_1.jsonNormalize) {
|
|
13
|
+
assert_1.default.deepStrictEqual(normalize(v), await (0, fixtures_utils_1.getFixture)(path_1.default.join(root, name), normalize(v)));
|
|
14
|
+
},
|
|
15
|
+
};
|
|
11
16
|
}
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4dHVyZXMudXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0L3RyYW5zYWN0aW9uL2Rlc2NyaXB0b3IvZml4dHVyZXMudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFXQSx3Q0FNQztBQWpCRCxvREFBNEI7QUFDNUIsZ0RBQXdCO0FBRXhCLDhEQUFzRTtBQVF0RSxTQUFnQixjQUFjLENBQUMsSUFBWTtJQUN6QyxPQUFPO1FBQ0wsS0FBSyxDQUFDLGtCQUFrQixDQUFDLElBQVksRUFBRSxDQUFVLEVBQUUsWUFBdUIsOEJBQWE7WUFDckYsZ0JBQU0sQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLE1BQU0sSUFBQSwyQkFBVSxFQUFDLGNBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDOUYsQ0FBQztLQUNGLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7IGdldEZpeHR1cmUsIGpzb25Ob3JtYWxpemUgfSBmcm9tICcuLi8uLi9jb3JlL2ZpeHR1cmVzLnV0aWxzJztcblxuaW50ZXJmYWNlIEZpeHR1cmVSb290IHtcbiAgYXNzZXJ0RXF1YWxGaXh0dXJlKG5hbWU6IHN0cmluZywgdjogdW5rbm93bik6IFByb21pc2U8dm9pZD47XG59XG5cbnR5cGUgTm9ybWFsaXplID0gKHY6IHVua25vd24pID0+IHVua25vd247XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRGaXh0dXJlUm9vdChyb290OiBzdHJpbmcpOiBGaXh0dXJlUm9vdCB7XG4gIHJldHVybiB7XG4gICAgYXN5bmMgYXNzZXJ0RXF1YWxGaXh0dXJlKG5hbWU6IHN0cmluZywgdjogdW5rbm93biwgbm9ybWFsaXplOiBOb3JtYWxpemUgPSBqc29uTm9ybWFsaXplKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKG5vcm1hbGl6ZSh2KSwgYXdhaXQgZ2V0Rml4dHVyZShwYXRoLmpvaW4ocm9vdCwgbmFtZSksIG5vcm1hbGl6ZSh2KSkpO1xuICAgIH0sXG4gIH07XG59XG4iXX0=
|
|
@@ -11,6 +11,7 @@ const toPlainObject_utils_1 = require("../../core/toPlainObject.utils");
|
|
|
11
11
|
const verifyTransaction_1 = require("../../../src/transaction/descriptor/verifyTransaction");
|
|
12
12
|
const parseToAmountType_1 = require("../../../src/transaction/descriptor/parseToAmountType");
|
|
13
13
|
const fixtures_utils_1 = require("./fixtures.utils");
|
|
14
|
+
const { assertEqualFixture } = (0, fixtures_utils_1.getFixtureRoot)(__dirname + '/fixtures');
|
|
14
15
|
function toBaseOutput(output, amountType) {
|
|
15
16
|
(0, assert_1.default)(output.address);
|
|
16
17
|
return {
|
|
@@ -37,9 +38,9 @@ describe('parse', function () {
|
|
|
37
38
|
}
|
|
38
39
|
describe('toBase', function () {
|
|
39
40
|
it('should return the correct BaseParsedTransactionOutputs', async function () {
|
|
40
|
-
await
|
|
41
|
-
await
|
|
42
|
-
await
|
|
41
|
+
await assertEqualFixture('parseWithoutRecipients.json', (0, toPlainObject_utils_1.toPlainObject)(getBaseParsedTransaction([])));
|
|
42
|
+
await assertEqualFixture('parseWithRecipient.json', (0, toPlainObject_utils_1.toPlainObject)(getBaseParsedTransaction([psbt.txOutputs[0]])));
|
|
43
|
+
await assertEqualFixture('parseWithRecipient.json',
|
|
43
44
|
// max recipient: ignore actual value
|
|
44
45
|
(0, toPlainObject_utils_1.toPlainObject)(getBaseParsedTransaction([toMaxOutput(psbt.txOutputs[0])])));
|
|
45
46
|
});
|
|
@@ -75,4 +76,4 @@ describe('parse', function () {
|
|
|
75
76
|
});
|
|
76
77
|
});
|
|
77
78
|
});
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parse.js","sourceRoot":"","sources":["../../../../test/transaction/descriptor/parse.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport { mockPsbtDefaultWithDescriptorTemplate } from '../../core/descriptor/psbt/mock.utils';\nimport { ParsedOutputsBigInt, toBaseParsedTransactionOutputsFromPsbt } from '../../../src/transaction/descriptor/parse';\nimport { getDefaultXPubs, getDescriptorMap } from '../../core/descriptor/descriptor.utils';\nimport { toPlainObject } from '../../core/toPlainObject.utils';\nimport {\n  AggregateValidationError,\n  assertExpectedOutputDifference,\n  ErrorImplicitExternalOutputs,\n  ErrorMissingOutputs,\n} from '../../../src/transaction/descriptor/verifyTransaction';\nimport { toAmountType } from '../../../src/transaction/descriptor/parseToAmountType';\nimport { BaseOutput } from '../../../src';\n\nimport { assertEqualFixture } from './fixtures.utils';\n\ntype OutputWithValue<T = number | bigint | string> = {\n  address?: string;\n  value: T;\n};\n\nfunction toBaseOutput<TNumber>(output: OutputWithValue, amountType: 'bigint' | 'string'): BaseOutput<TNumber> {\n  assert(output.address);\n  return {\n    address: output.address,\n    amount: toAmountType(output.value, amountType) as TNumber,\n  };\n}\n\nfunction toBaseOutputBigInt(output: OutputWithValue): BaseOutput<bigint> {\n  return toBaseOutput(output, 'bigint');\n}\n\nfunction toBaseOutputString(output: OutputWithValue): BaseOutput<string> {\n  return toBaseOutput(output, 'string');\n}\n\nfunction toMaxOutput(output: OutputWithValue): OutputWithValue<'max'> {\n  return {\n    ...output,\n    value: 'max',\n  };\n}\n\ndescribe('parse', function () {\n  const psbt = mockPsbtDefaultWithDescriptorTemplate('Wsh2Of3');\n\n  function getBaseParsedTransaction(recipients: OutputWithValue[]): ParsedOutputsBigInt {\n    return toBaseParsedTransactionOutputsFromPsbt(\n      psbt,\n      getDescriptorMap('Wsh2Of3', getDefaultXPubs('a')),\n      recipients.map(toBaseOutputString),\n      psbt.network\n    );\n  }\n\n  describe('toBase', function () {\n    it('should return the correct BaseParsedTransactionOutputs', async function () {\n      await assertEqualFixture('parseWithoutRecipients.json', toPlainObject(getBaseParsedTransaction([])));\n      await assertEqualFixture('parseWithRecipient.json', toPlainObject(getBaseParsedTransaction([psbt.txOutputs[0]])));\n      await assertEqualFixture(\n        'parseWithRecipient.json',\n        // max recipient: ignore actual value\n        toPlainObject(getBaseParsedTransaction([toMaxOutput(psbt.txOutputs[0])]))\n      );\n    });\n\n    function assertEqualValidationError(actual: unknown, expected: AggregateValidationError) {\n      if (actual instanceof AggregateValidationError) {\n        assert.deepStrictEqual(actual.errors, expected.errors);\n      } else {\n        throw new Error('unexpected error type');\n      }\n    }\n\n    function assertValidationError(f: () => void, expected: AggregateValidationError) {\n      assert.throws(f, (err) => {\n        assertEqualValidationError(err, expected);\n        return true;\n      });\n    }\n\n    it('should throw expected errors', function () {\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([])),\n        new AggregateValidationError([\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([])),\n        new AggregateValidationError([\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([psbt.txOutputs[1]])),\n        new AggregateValidationError([\n          new ErrorMissingOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[1]), external: true }]),\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([toMaxOutput(psbt.txOutputs[1])])),\n        new AggregateValidationError([\n          new ErrorMissingOutputs([{ ...toBaseOutputBigInt(toMaxOutput(psbt.txOutputs[1])), external: true }]),\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n    });\n  });\n});\n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parse.js","sourceRoot":"","sources":["../../../../test/transaction/descriptor/parse.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport { mockPsbtDefaultWithDescriptorTemplate } from '../../core/descriptor/psbt/mock.utils';\nimport { ParsedOutputsBigInt, toBaseParsedTransactionOutputsFromPsbt } from '../../../src/transaction/descriptor/parse';\nimport { getDefaultXPubs, getDescriptorMap } from '../../core/descriptor/descriptor.utils';\nimport { toPlainObject } from '../../core/toPlainObject.utils';\nimport {\n  AggregateValidationError,\n  assertExpectedOutputDifference,\n  ErrorImplicitExternalOutputs,\n  ErrorMissingOutputs,\n} from '../../../src/transaction/descriptor/verifyTransaction';\nimport { toAmountType } from '../../../src/transaction/descriptor/parseToAmountType';\nimport { BaseOutput } from '../../../src';\n\nimport { getFixtureRoot } from './fixtures.utils';\n\nconst { assertEqualFixture } = getFixtureRoot(__dirname + '/fixtures');\n\ntype OutputWithValue<T = number | bigint | string> = {\n  address?: string;\n  value: T;\n};\n\nfunction toBaseOutput<TNumber>(output: OutputWithValue, amountType: 'bigint' | 'string'): BaseOutput<TNumber> {\n  assert(output.address);\n  return {\n    address: output.address,\n    amount: toAmountType(output.value, amountType) as TNumber,\n  };\n}\n\nfunction toBaseOutputBigInt(output: OutputWithValue): BaseOutput<bigint> {\n  return toBaseOutput(output, 'bigint');\n}\n\nfunction toBaseOutputString(output: OutputWithValue): BaseOutput<string> {\n  return toBaseOutput(output, 'string');\n}\n\nfunction toMaxOutput(output: OutputWithValue): OutputWithValue<'max'> {\n  return {\n    ...output,\n    value: 'max',\n  };\n}\n\ndescribe('parse', function () {\n  const psbt = mockPsbtDefaultWithDescriptorTemplate('Wsh2Of3');\n\n  function getBaseParsedTransaction(recipients: OutputWithValue[]): ParsedOutputsBigInt {\n    return toBaseParsedTransactionOutputsFromPsbt(\n      psbt,\n      getDescriptorMap('Wsh2Of3', getDefaultXPubs('a')),\n      recipients.map(toBaseOutputString),\n      psbt.network\n    );\n  }\n\n  describe('toBase', function () {\n    it('should return the correct BaseParsedTransactionOutputs', async function () {\n      await assertEqualFixture('parseWithoutRecipients.json', toPlainObject(getBaseParsedTransaction([])));\n      await assertEqualFixture('parseWithRecipient.json', toPlainObject(getBaseParsedTransaction([psbt.txOutputs[0]])));\n      await assertEqualFixture(\n        'parseWithRecipient.json',\n        // max recipient: ignore actual value\n        toPlainObject(getBaseParsedTransaction([toMaxOutput(psbt.txOutputs[0])]))\n      );\n    });\n\n    function assertEqualValidationError(actual: unknown, expected: AggregateValidationError) {\n      if (actual instanceof AggregateValidationError) {\n        assert.deepStrictEqual(actual.errors, expected.errors);\n      } else {\n        throw new Error('unexpected error type');\n      }\n    }\n\n    function assertValidationError(f: () => void, expected: AggregateValidationError) {\n      assert.throws(f, (err) => {\n        assertEqualValidationError(err, expected);\n        return true;\n      });\n    }\n\n    it('should throw expected errors', function () {\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([])),\n        new AggregateValidationError([\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([])),\n        new AggregateValidationError([\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([psbt.txOutputs[1]])),\n        new AggregateValidationError([\n          new ErrorMissingOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[1]), external: true }]),\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n\n      assertValidationError(\n        () => assertExpectedOutputDifference(getBaseParsedTransaction([toMaxOutput(psbt.txOutputs[1])])),\n        new AggregateValidationError([\n          new ErrorMissingOutputs([{ ...toBaseOutputBigInt(toMaxOutput(psbt.txOutputs[1])), external: true }]),\n          new ErrorImplicitExternalOutputs([{ ...toBaseOutputBigInt(psbt.txOutputs[0]), external: true }]),\n        ])\n      );\n    });\n  });\n});\n"]}
|