@bitgo-beta/abstract-utxo 1.6.1-alpha.23 → 1.6.1-alpha.230

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.
Files changed (45) hide show
  1. package/CHANGELOG.md +853 -0
  2. package/dist/src/abstractUtxoCoin.d.ts +146 -34
  3. package/dist/src/abstractUtxoCoin.d.ts.map +1 -1
  4. package/dist/src/abstractUtxoCoin.js +350 -187
  5. package/dist/src/descriptor/NamedDescriptor.d.ts +7 -0
  6. package/dist/src/descriptor/NamedDescriptor.d.ts.map +1 -0
  7. package/dist/src/descriptor/NamedDescriptor.js +9 -0
  8. package/dist/src/descriptor/assertDescriptorWalletAddress.d.ts +4 -0
  9. package/dist/src/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  10. package/dist/src/descriptor/assertDescriptorWalletAddress.js +37 -0
  11. package/dist/src/descriptor/index.d.ts +4 -0
  12. package/dist/src/descriptor/index.d.ts.map +1 -0
  13. package/dist/src/descriptor/index.js +11 -0
  14. package/dist/src/index.d.ts +1 -0
  15. package/dist/src/index.d.ts.map +1 -1
  16. package/dist/src/index.js +8 -2
  17. package/dist/src/parseOutput.d.ts.map +1 -1
  18. package/dist/src/parseOutput.js +38 -1
  19. package/dist/src/recovery/RecoveryProvider.d.ts +1 -1
  20. package/dist/src/recovery/RecoveryProvider.d.ts.map +1 -1
  21. package/dist/src/recovery/RecoveryProvider.js +1 -2
  22. package/dist/src/recovery/backupKeyRecovery.d.ts +39 -11
  23. package/dist/src/recovery/backupKeyRecovery.d.ts.map +1 -1
  24. package/dist/src/recovery/backupKeyRecovery.js +124 -83
  25. package/dist/src/recovery/baseApi.d.ts +2 -2
  26. package/dist/src/recovery/baseApi.d.ts.map +1 -1
  27. package/dist/src/recovery/crossChainRecovery.d.ts +12 -3
  28. package/dist/src/recovery/crossChainRecovery.d.ts.map +1 -1
  29. package/dist/src/recovery/crossChainRecovery.js +50 -10
  30. package/dist/src/recovery/index.d.ts +0 -1
  31. package/dist/src/recovery/index.d.ts.map +1 -1
  32. package/dist/src/recovery/index.js +6 -3
  33. package/dist/src/recovery/mempoolApi.d.ts.map +1 -1
  34. package/dist/src/recovery/mempoolApi.js +6 -3
  35. package/dist/src/sign.d.ts +29 -5
  36. package/dist/src/sign.d.ts.map +1 -1
  37. package/dist/src/sign.js +73 -7
  38. package/dist/src/transaction.d.ts +36 -0
  39. package/dist/src/transaction.d.ts.map +1 -0
  40. package/dist/src/transaction.js +278 -0
  41. package/dist/tsconfig.tsbuildinfo +1 -7906
  42. package/package.json +12 -10
  43. package/dist/src/recovery/smartbitApi.d.ts +0 -11
  44. package/dist/src/recovery/smartbitApi.d.ts.map +0 -1
  45. package/dist/src/recovery/smartbitApi.js +0 -36
@@ -0,0 +1,7 @@
1
+ import * as t from 'io-ts';
2
+ export declare const NamedDescriptor: t.TypeC<{
3
+ name: t.StringC;
4
+ value: t.StringC;
5
+ }>;
6
+ export type NamedDescriptor = t.TypeOf<typeof NamedDescriptor>;
7
+ //# sourceMappingURL=NamedDescriptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NamedDescriptor.d.ts","sourceRoot":"","sources":["../../../src/descriptor/NamedDescriptor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,OAAO,CAAC;AAE3B,eAAO,MAAM,eAAe;;;EAG1B,CAAC;AAEH,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,eAAe,CAAC,CAAC"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NamedDescriptor = void 0;
4
+ const t = require("io-ts");
5
+ exports.NamedDescriptor = t.type({
6
+ name: t.string,
7
+ value: t.string,
8
+ });
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTmFtZWREZXNjcmlwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Rlc2NyaXB0b3IvTmFtZWREZXNjcmlwdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDJCQUEyQjtBQUVkLFFBQUEsZUFBZSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDcEMsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNO0lBQ2QsS0FBSyxFQUFFLENBQUMsQ0FBQyxNQUFNO0NBQ2hCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHQgZnJvbSAnaW8tdHMnO1xuXG5leHBvcnQgY29uc3QgTmFtZWREZXNjcmlwdG9yID0gdC50eXBlKHtcbiAgbmFtZTogdC5zdHJpbmcsXG4gIHZhbHVlOiB0LnN0cmluZyxcbn0pO1xuXG5leHBvcnQgdHlwZSBOYW1lZERlc2NyaXB0b3IgPSB0LlR5cGVPZjx0eXBlb2YgTmFtZWREZXNjcmlwdG9yPjtcbiJdfQ==
@@ -0,0 +1,4 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ import { UtxoCoinSpecific, VerifyAddressOptions } from '../abstractUtxoCoin';
3
+ export declare function assertDescriptorWalletAddress(network: utxolib.Network, params: VerifyAddressOptions<UtxoCoinSpecific>, descriptors: unknown): void;
4
+ //# sourceMappingURL=assertDescriptorWalletAddress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"assertDescriptorWalletAddress.d.ts","sourceRoot":"","sources":["../../../src/descriptor/assertDescriptorWalletAddress.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAGhD,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAW7E,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,MAAM,EAAE,oBAAoB,CAAC,gBAAgB,CAAC,EAC9C,WAAW,EAAE,OAAO,GACnB,IAAI,CAuBN"}
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.assertDescriptorWalletAddress = void 0;
4
+ const assert = require("assert");
5
+ const t = require("io-ts");
6
+ const utxolib = require("@bitgo-beta/utxo-lib");
7
+ const wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
8
+ const NamedDescriptor_1 = require("./NamedDescriptor");
9
+ class DescriptorAddressMismatchError extends Error {
10
+ constructor(descriptor, index, derivedAddress, expectedAddress) {
11
+ super(`Address mismatch for descriptor ${descriptor.toString()} at index ${index}: ${derivedAddress} !== ${expectedAddress}`);
12
+ }
13
+ }
14
+ function assertDescriptorWalletAddress(network, params, descriptors) {
15
+ assert(params.coinSpecific);
16
+ assert(t.array(NamedDescriptor_1.NamedDescriptor).is(descriptors));
17
+ assert('descriptorName' in params.coinSpecific);
18
+ assert('descriptorChecksum' in params.coinSpecific);
19
+ const descriptorName = params.coinSpecific.descriptorName;
20
+ const descriptorChecksum = params.coinSpecific.descriptorChecksum;
21
+ const namedDescriptor = descriptors.find((d) => d.name === descriptorName);
22
+ if (!namedDescriptor) {
23
+ throw new Error(`Descriptor ${descriptorName} not found`);
24
+ }
25
+ const descriptor = wasm_miniscript_1.Descriptor.fromString(namedDescriptor.value, 'derivable');
26
+ const checksum = descriptor.toString().slice(-8);
27
+ if (checksum !== descriptorChecksum) {
28
+ throw new Error(`Descriptor checksum mismatch for descriptor name=${descriptorName}: ${checksum} !== ${descriptorChecksum}`);
29
+ }
30
+ const derivedScript = Buffer.from(descriptor.atDerivationIndex(params.index).scriptPubkey());
31
+ const derivedAddress = utxolib.address.fromOutputScript(derivedScript, network);
32
+ if (params.address !== derivedAddress) {
33
+ throw new DescriptorAddressMismatchError(descriptor, params.index, derivedAddress, params.address);
34
+ }
35
+ }
36
+ exports.assertDescriptorWalletAddress = assertDescriptorWalletAddress;
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXJ0RGVzY3JpcHRvcldhbGxldEFkZHJlc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGVzY3JpcHRvci9hc3NlcnREZXNjcmlwdG9yV2FsbGV0QWRkcmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpQ0FBaUM7QUFDakMsMkJBQTJCO0FBQzNCLGdEQUFnRDtBQUNoRCw0REFBb0Q7QUFHcEQsdURBQW9EO0FBRXBELE1BQU0sOEJBQStCLFNBQVEsS0FBSztJQUNoRCxZQUFZLFVBQXNCLEVBQUUsS0FBYSxFQUFFLGNBQXNCLEVBQUUsZUFBdUI7UUFDaEcsS0FBSyxDQUNILG1DQUFtQyxVQUFVLENBQUMsUUFBUSxFQUFFLGFBQWEsS0FBSyxLQUFLLGNBQWMsUUFBUSxlQUFlLEVBQUUsQ0FDdkgsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQUVELFNBQWdCLDZCQUE2QixDQUMzQyxPQUF3QixFQUN4QixNQUE4QyxFQUM5QyxXQUFvQjtJQUVwQixNQUFNLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzVCLE1BQU0sQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLGlDQUFlLENBQUMsQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztJQUNqRCxNQUFNLENBQUMsZ0JBQWdCLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2hELE1BQU0sQ0FBQyxvQkFBb0IsSUFBSSxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDcEQsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxjQUFjLENBQUM7SUFDMUQsTUFBTSxrQkFBa0IsR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLGtCQUFrQixDQUFDO0lBQ2xFLE1BQU0sZUFBZSxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssY0FBYyxDQUFDLENBQUM7SUFDM0UsSUFBSSxDQUFDLGVBQWUsRUFBRTtRQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLGNBQWMsY0FBYyxZQUFZLENBQUMsQ0FBQztLQUMzRDtJQUNELE1BQU0sVUFBVSxHQUFHLDRCQUFVLENBQUMsVUFBVSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDN0UsTUFBTSxRQUFRLEdBQUcsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2pELElBQUksUUFBUSxLQUFLLGtCQUFrQixFQUFFO1FBQ25DLE1BQU0sSUFBSSxLQUFLLENBQ2Isb0RBQW9ELGNBQWMsS0FBSyxRQUFRLFFBQVEsa0JBQWtCLEVBQUUsQ0FDNUcsQ0FBQztLQUNIO0lBQ0QsTUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUM7SUFDN0YsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDaEYsSUFBSSxNQUFNLENBQUMsT0FBTyxLQUFLLGNBQWMsRUFBRTtRQUNyQyxNQUFNLElBQUksOEJBQThCLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxLQUFLLEVBQUUsY0FBYyxFQUFFLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUNwRztBQUNILENBQUM7QUEzQkQsc0VBMkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgKiBhcyB0IGZyb20gJ2lvLXRzJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgRGVzY3JpcHRvciB9IGZyb20gJ0BiaXRnby93YXNtLW1pbmlzY3JpcHQnO1xuXG5pbXBvcnQgeyBVdHhvQ29pblNwZWNpZmljLCBWZXJpZnlBZGRyZXNzT3B0aW9ucyB9IGZyb20gJy4uL2Fic3RyYWN0VXR4b0NvaW4nO1xuaW1wb3J0IHsgTmFtZWREZXNjcmlwdG9yIH0gZnJvbSAnLi9OYW1lZERlc2NyaXB0b3InO1xuXG5jbGFzcyBEZXNjcmlwdG9yQWRkcmVzc01pc21hdGNoRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKGRlc2NyaXB0b3I6IERlc2NyaXB0b3IsIGluZGV4OiBudW1iZXIsIGRlcml2ZWRBZGRyZXNzOiBzdHJpbmcsIGV4cGVjdGVkQWRkcmVzczogc3RyaW5nKSB7XG4gICAgc3VwZXIoXG4gICAgICBgQWRkcmVzcyBtaXNtYXRjaCBmb3IgZGVzY3JpcHRvciAke2Rlc2NyaXB0b3IudG9TdHJpbmcoKX0gYXQgaW5kZXggJHtpbmRleH06ICR7ZGVyaXZlZEFkZHJlc3N9ICE9PSAke2V4cGVjdGVkQWRkcmVzc31gXG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gYXNzZXJ0RGVzY3JpcHRvcldhbGxldEFkZHJlc3MoXG4gIG5ldHdvcms6IHV0eG9saWIuTmV0d29yayxcbiAgcGFyYW1zOiBWZXJpZnlBZGRyZXNzT3B0aW9uczxVdHhvQ29pblNwZWNpZmljPixcbiAgZGVzY3JpcHRvcnM6IHVua25vd25cbik6IHZvaWQge1xuICBhc3NlcnQocGFyYW1zLmNvaW5TcGVjaWZpYyk7XG4gIGFzc2VydCh0LmFycmF5KE5hbWVkRGVzY3JpcHRvcikuaXMoZGVzY3JpcHRvcnMpKTtcbiAgYXNzZXJ0KCdkZXNjcmlwdG9yTmFtZScgaW4gcGFyYW1zLmNvaW5TcGVjaWZpYyk7XG4gIGFzc2VydCgnZGVzY3JpcHRvckNoZWNrc3VtJyBpbiBwYXJhbXMuY29pblNwZWNpZmljKTtcbiAgY29uc3QgZGVzY3JpcHRvck5hbWUgPSBwYXJhbXMuY29pblNwZWNpZmljLmRlc2NyaXB0b3JOYW1lO1xuICBjb25zdCBkZXNjcmlwdG9yQ2hlY2tzdW0gPSBwYXJhbXMuY29pblNwZWNpZmljLmRlc2NyaXB0b3JDaGVja3N1bTtcbiAgY29uc3QgbmFtZWREZXNjcmlwdG9yID0gZGVzY3JpcHRvcnMuZmluZCgoZCkgPT4gZC5uYW1lID09PSBkZXNjcmlwdG9yTmFtZSk7XG4gIGlmICghbmFtZWREZXNjcmlwdG9yKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBEZXNjcmlwdG9yICR7ZGVzY3JpcHRvck5hbWV9IG5vdCBmb3VuZGApO1xuICB9XG4gIGNvbnN0IGRlc2NyaXB0b3IgPSBEZXNjcmlwdG9yLmZyb21TdHJpbmcobmFtZWREZXNjcmlwdG9yLnZhbHVlLCAnZGVyaXZhYmxlJyk7XG4gIGNvbnN0IGNoZWNrc3VtID0gZGVzY3JpcHRvci50b1N0cmluZygpLnNsaWNlKC04KTtcbiAgaWYgKGNoZWNrc3VtICE9PSBkZXNjcmlwdG9yQ2hlY2tzdW0pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgRGVzY3JpcHRvciBjaGVja3N1bSBtaXNtYXRjaCBmb3IgZGVzY3JpcHRvciBuYW1lPSR7ZGVzY3JpcHRvck5hbWV9OiAke2NoZWNrc3VtfSAhPT0gJHtkZXNjcmlwdG9yQ2hlY2tzdW19YFxuICAgICk7XG4gIH1cbiAgY29uc3QgZGVyaXZlZFNjcmlwdCA9IEJ1ZmZlci5mcm9tKGRlc2NyaXB0b3IuYXREZXJpdmF0aW9uSW5kZXgocGFyYW1zLmluZGV4KS5zY3JpcHRQdWJrZXkoKSk7XG4gIGNvbnN0IGRlcml2ZWRBZGRyZXNzID0gdXR4b2xpYi5hZGRyZXNzLmZyb21PdXRwdXRTY3JpcHQoZGVyaXZlZFNjcmlwdCwgbmV0d29yayk7XG4gIGlmIChwYXJhbXMuYWRkcmVzcyAhPT0gZGVyaXZlZEFkZHJlc3MpIHtcbiAgICB0aHJvdyBuZXcgRGVzY3JpcHRvckFkZHJlc3NNaXNtYXRjaEVycm9yKGRlc2NyaXB0b3IsIHBhcmFtcy5pbmRleCwgZGVyaXZlZEFkZHJlc3MsIHBhcmFtcy5hZGRyZXNzKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,4 @@
1
+ export { Miniscript, Descriptor } from '@bitgo/wasm-miniscript';
2
+ export { assertDescriptorWalletAddress } from './assertDescriptorWalletAddress';
3
+ export { NamedDescriptor } from './NamedDescriptor';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/descriptor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,6BAA6B,EAAE,MAAM,iCAAiC,CAAC;AAChF,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NamedDescriptor = exports.assertDescriptorWalletAddress = exports.Descriptor = exports.Miniscript = void 0;
4
+ var wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
5
+ Object.defineProperty(exports, "Miniscript", { enumerable: true, get: function () { return wasm_miniscript_1.Miniscript; } });
6
+ Object.defineProperty(exports, "Descriptor", { enumerable: true, get: function () { return wasm_miniscript_1.Descriptor; } });
7
+ var assertDescriptorWalletAddress_1 = require("./assertDescriptorWalletAddress");
8
+ Object.defineProperty(exports, "assertDescriptorWalletAddress", { enumerable: true, get: function () { return assertDescriptorWalletAddress_1.assertDescriptorWalletAddress; } });
9
+ var NamedDescriptor_1 = require("./NamedDescriptor");
10
+ Object.defineProperty(exports, "NamedDescriptor", { enumerable: true, get: function () { return NamedDescriptor_1.NamedDescriptor; } });
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGVzY3JpcHRvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwwREFBZ0U7QUFBdkQsNkdBQUEsVUFBVSxPQUFBO0FBQUUsNkdBQUEsVUFBVSxPQUFBO0FBQy9CLGlGQUFnRjtBQUF2RSw4SUFBQSw2QkFBNkIsT0FBQTtBQUN0QyxxREFBb0Q7QUFBM0Msa0hBQUEsZUFBZSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgTWluaXNjcmlwdCwgRGVzY3JpcHRvciB9IGZyb20gJ0BiaXRnby93YXNtLW1pbmlzY3JpcHQnO1xuZXhwb3J0IHsgYXNzZXJ0RGVzY3JpcHRvcldhbGxldEFkZHJlc3MgfSBmcm9tICcuL2Fzc2VydERlc2NyaXB0b3JXYWxsZXRBZGRyZXNzJztcbmV4cG9ydCB7IE5hbWVkRGVzY3JpcHRvciB9IGZyb20gJy4vTmFtZWREZXNjcmlwdG9yJztcbiJdfQ==
@@ -3,4 +3,5 @@ export * from './config';
3
3
  export * from './recovery';
4
4
  export * from './replayProtection';
5
5
  export * from './sign';
6
+ export * as descriptor from './descriptor';
6
7
  //# sourceMappingURL=index.d.ts.map
@@ -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"}
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,KAAK,UAAU,MAAM,cAAc,CAAC"}
package/dist/src/index.js CHANGED
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[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);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -10,9 +14,11 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
15
  };
12
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.descriptor = void 0;
13
18
  __exportStar(require("./abstractUtxoCoin"), exports);
14
19
  __exportStar(require("./config"), exports);
15
20
  __exportStar(require("./recovery"), exports);
16
21
  __exportStar(require("./replayProtection"), exports);
17
22
  __exportStar(require("./sign"), exports);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEscURBQW1DO0FBQ25DLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IscURBQW1DO0FBQ25DLHlDQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWJzdHJhY3RVdHhvQ29pbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL3JlY292ZXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vcmVwbGF5UHJvdGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3NpZ24nO1xuIl19
23
+ exports.descriptor = require("./descriptor");
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxREFBbUM7QUFDbkMsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQixxREFBbUM7QUFDbkMseUNBQXVCO0FBRXZCLDZDQUEyQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWJzdHJhY3RVdHhvQ29pbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL3JlY292ZXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vcmVwbGF5UHJvdGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3NpZ24nO1xuXG5leHBvcnQgKiBhcyBkZXNjcmlwdG9yIGZyb20gJy4vZGVzY3JpcHRvcic7XG4iXX0=
@@ -1 +1 @@
1
- {"version":3,"file":"parseOutput.d.ts","sourceRoot":"","sources":["../../src/parseOutput.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,EAEL,cAAc,EAEd,OAAO,EACP,QAAQ,EACR,mBAAmB,EAEnB,mBAAmB,EACpB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAwKjF,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACrC,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,kBAAkB;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,IAAI,EAAE,gBAAgB,CAAC;IACvB,UAAU,EAAE,mBAAmB,CAAC;IAChC,YAAY,EAAE,mBAAmB,CAAC;IAClC,aAAa,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAC9C,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,YAAY,CAAC,EAAE,mBAAmB,CAAC;IACnC,KAAK,CAAC,EAAE,cAAc,CAAC;CACxB;AAED,wBAAsB,WAAW,CAAC,EAChC,aAAa,EACb,IAAI,EACJ,UAAU,EACV,YAAY,EACZ,aAAa,EACb,MAAM,EACN,QAAQ,EACR,YAAY,EACZ,KAAK,GACN,EAAE,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,CA4DtC"}
1
+ {"version":3,"file":"parseOutput.d.ts","sourceRoot":"","sources":["../../src/parseOutput.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,EAEL,cAAc,EAEd,OAAO,EACP,QAAQ,EACR,mBAAmB,EAEnB,mBAAmB,EACpB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,iBAAiB,EAAkB,MAAM,oBAAoB,CAAC;AAwKjG,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACrC,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,kBAAkB;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,IAAI,EAAE,gBAAgB,CAAC;IACvB,UAAU,EAAE,mBAAmB,CAAC;IAChC,YAAY,EAAE,mBAAmB,CAAC;IAClC,aAAa,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAC9C,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,YAAY,CAAC,EAAE,mBAAmB,CAAC;IACnC,KAAK,CAAC,EAAE,cAAc,CAAC;CACxB;AAED,wBAAsB,WAAW,CAAC,EAChC,aAAa,EACb,IAAI,EACJ,UAAU,EACV,YAAY,EACZ,aAAa,EACb,MAAM,EACN,QAAQ,EACR,YAAY,EACZ,KAAK,GACN,EAAE,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,CAsGtC"}
@@ -122,7 +122,34 @@ async function parseOutput({ currentOutput, coin, txPrebuild, verification, keyc
122
122
  debug('Parsing address details for %s', currentAddress);
123
123
  let currentAddressDetails = undefined;
124
124
  let currentAddressType = undefined;
125
+ const RECIPIENT_THRESHOLD = 1000;
125
126
  try {
127
+ // In the case of PSBTs, we can already determine the internal/external status of the output addresses
128
+ // based on the derivation information being included in the PSBT. We can short circuit GET v2.wallet.address
129
+ // and save on network requests. Since we have the derivation information already, we can still verify the address
130
+ if (currentOutput.external !== undefined) {
131
+ // In the case that we have a custom change wallet, we need to verify the address against the custom change keys
132
+ // and not the wallet keys. This check is done in the handleVerifyAddressError function if this error is thrown.
133
+ if (customChange !== undefined) {
134
+ throw new sdk_core_1.UnexpectedAddressError('`address validation failure');
135
+ }
136
+ // If it is an internal address, we can skip the network request and just verify the address locally with the
137
+ // derivation information we have. Otherwise, if the address is external, which is the only remaining case, we
138
+ // can just return the current output as is without contacting the server.
139
+ if ((0, abstractUtxoCoin_1.isWalletOutput)(currentOutput)) {
140
+ const res = await coin.isWalletAddress({
141
+ addressType: abstractUtxoCoin_1.AbstractUtxoCoin.inferAddressType({ chain: currentOutput.chain }) || undefined,
142
+ keychains: keychainArray,
143
+ address: currentAddress,
144
+ chain: currentOutput.chain,
145
+ index: currentOutput.index,
146
+ });
147
+ if (!res) {
148
+ throw new sdk_core_1.UnexpectedAddressError();
149
+ }
150
+ }
151
+ return currentOutput;
152
+ }
126
153
  /**
127
154
  * The only way to determine whether an address is known on the wallet is to initiate a network request and
128
155
  * fetch it. Should the request fail and return a 404, it will throw and therefore has to be caught. For that
@@ -130,6 +157,16 @@ async function parseOutput({ currentOutput, coin, txPrebuild, verification, keyc
130
157
  * details are fetched on the wallet, a local address validation is run, whose errors however are generated
131
158
  * client-side and can therefore be analyzed with more granularity and type checking.
132
159
  */
160
+ /**
161
+ * In order to minimize API requests, we assume that explicit recipients are always external when the
162
+ * recipient list is > 1000 This is not always a valid assumption and could lead greater apparent spend (but never lower)
163
+ */
164
+ if (txParams.recipients !== undefined && txParams.recipients.length > RECIPIENT_THRESHOLD) {
165
+ const isCurrentAddressInRecipients = txParams.recipients.some((recipient) => recipient.address.includes(currentAddress));
166
+ if (isCurrentAddressInRecipients) {
167
+ return { ...currentOutput };
168
+ }
169
+ }
133
170
  const addressDetails = await fetchAddressDetails({
134
171
  reqId,
135
172
  addressDetailsVerification,
@@ -167,4 +204,4 @@ async function parseOutput({ currentOutput, coin, txPrebuild, verification, keyc
167
204
  }
168
205
  }
169
206
  exports.parseOutput = parseOutput;
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseOutput.js","sourceRoot":"","sources":["../../src/parseOutput.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\n\nimport * as debugLib from 'debug';\nimport * as _ from 'lodash';\nimport {\n  AddressVerificationData,\n  IRequestTracer,\n  InvalidAddressDerivationPropertyError,\n  IWallet,\n  Keychain,\n  TransactionPrebuild,\n  UnexpectedAddressError,\n  VerificationOptions,\n} from '@bitgo-beta/sdk-core';\nimport { AbstractUtxoCoin, Output, TransactionParams } from './abstractUtxoCoin';\n\nconst debug = debugLib('bitgo:v2:parseoutput');\n\ninterface HandleVerifyAddressErrorResponse {\n  external: boolean;\n  needsCustomChangeKeySignatureVerification?: boolean;\n}\n\n/**\n * Check an address which failed initial validation to see if it's the base address of a migrated v1 bch wallet.\n *\n * The wallet in question could be a migrated SafeHD BCH wallet, and the transaction we\n * are currently parsing is trying to spend change back to the v1 wallet base address.\n *\n * It does this since we don't allow new address creation for these wallets,\n * and instead return the base address from the v1 wallet when a new address is requested.\n * If this new address is requested for the purposes of spending change back to the wallet,\n * the change will go to the v1 wallet base address. This address *is* on the wallet,\n * but it will still cause an error to be thrown by verifyAddress, since the derivation path\n * used for this address is non-standard. (I have seen these addresses derived using paths m/0/0 and m/101,\n * whereas the v2 addresses are derived using path  m/0/0/${chain}/${index}).\n *\n * This means we need to check for this case explicitly in this catch block, and classify\n * these types of outputs as internal instead of external. Failing to do so would cause the\n * transaction's implicit external outputs (ie, outputs which go to addresses not specified in\n * the recipients array) to add up to more than the 150 basis point limit which we enforce on\n * pay-as-you-go outputs (which should be the only implicit external outputs on our transactions).\n *\n * The 150 basis point limit for implicit external sends is enforced in verifyTransaction,\n * which calls this function to get information on the total external/internal spend amounts\n * for a transaction. The idea here is to protect from the transaction being maliciously modified\n * to add more implicit external spends (eg, to an attacker-controlled wallet).\n *\n * See verifyTransaction for more information on how transaction prebuilds are verified before signing.\n *\n * @param wallet {Wallet} wallet which is making the transaction\n * @param currentAddress {string} address to check for externality relative to v1 wallet base address\n */\nfunction isMigratedAddress(wallet: IWallet, currentAddress: string): boolean {\n  if (_.isString(wallet.migratedFrom()) && wallet.migratedFrom() === currentAddress) {\n    debug('found address %s which was migrated from v1 wallet, address is not external', currentAddress);\n    return true;\n  }\n\n  return false;\n}\n\ninterface VerifyCustomChangeAddressOptions {\n  coin: AbstractUtxoCoin;\n  customChangeKeys: HandleVerifyAddressErrorOptions['customChangeKeys'];\n  addressType: HandleVerifyAddressErrorOptions['addressType'];\n  addressDetails: HandleVerifyAddressErrorOptions['addressDetails'];\n  currentAddress: HandleVerifyAddressErrorOptions['currentAddress'];\n}\n\n/**\n * Check to see if an address is derived from the given custom change keys\n * @param {VerifyCustomChangeAddressOptions} params\n * @return {boolean}\n */\nasync function verifyCustomChangeAddress(params: VerifyCustomChangeAddressOptions): Promise<boolean> {\n  const { coin, customChangeKeys, addressType, addressDetails, currentAddress } = params;\n  try {\n    return await coin.verifyAddress(\n      _.extend({ addressType }, addressDetails, {\n        keychains: customChangeKeys,\n        address: currentAddress,\n      })\n    );\n  } catch (e) {\n    debug('failed to verify custom change address %s', currentAddress);\n    return false;\n  }\n}\n\ninterface HandleVerifyAddressErrorOptions {\n  e: Error;\n  currentAddress: string;\n  wallet: IWallet;\n  txParams: TransactionParams;\n  customChangeKeys?: CustomChangeOptions['keys'];\n  coin: AbstractUtxoCoin;\n  addressDetails?: any;\n  addressType?: string;\n  considerMigratedFromAddressInternal?: boolean;\n}\n\nasync function handleVerifyAddressError({\n  e,\n  currentAddress,\n  wallet,\n  txParams,\n  customChangeKeys,\n  coin,\n  addressDetails,\n  addressType,\n  considerMigratedFromAddressInternal,\n}: HandleVerifyAddressErrorOptions): Promise<HandleVerifyAddressErrorResponse> {\n  // Todo: name server-side errors to avoid message-based checking [BG-5124]\n  const walletAddressNotFound = e.message.includes('wallet address not found');\n  const unexpectedAddress = e instanceof UnexpectedAddressError;\n  if (walletAddressNotFound || unexpectedAddress) {\n    if (unexpectedAddress && !walletAddressNotFound) {\n      // check to see if this is a migrated v1 bch address - it could be internal\n      const isMigrated = isMigratedAddress(wallet, currentAddress);\n      if (isMigrated) {\n        return { external: considerMigratedFromAddressInternal === false };\n      }\n\n      debug('Address %s was found on wallet but could not be reconstructed', currentAddress);\n\n      // attempt to verify address using custom change address keys if the wallet has that feature enabled\n      if (\n        customChangeKeys &&\n        (await verifyCustomChangeAddress({ coin, addressDetails, addressType, currentAddress, customChangeKeys }))\n      ) {\n        // address is valid against the custom change keys. Mark address as not external\n        // and request signature verification for the custom change keys\n        debug('Address %s verified as derived from the custom change keys', currentAddress);\n        return { external: false, needsCustomChangeKeySignatureVerification: true };\n      }\n    }\n\n    // the address was found, but not on the wallet, which simply means it's external\n    debug('Address %s presumed external', currentAddress);\n    return { external: true };\n  } else if (e instanceof InvalidAddressDerivationPropertyError && currentAddress === txParams.changeAddress) {\n    // expect to see this error when passing in a custom changeAddress with no chain or index\n    return { external: false };\n  }\n\n  console.error('Address classification failed for address', currentAddress);\n  console.trace(e);\n  /**\n   * It might be a completely invalid address or a bad validation attempt or something else completely, in\n   * which case we do not proceed and rather rethrow the error, which is safer than assuming that the address\n   * validation failed simply because it's external to the wallet.\n   */\n  throw e;\n}\n\ninterface FetchAddressDetailsOptions {\n  reqId?: IRequestTracer;\n  disableNetworking: boolean;\n  addressDetailsPrebuild: any;\n  addressDetailsVerification: any;\n  currentAddress: string;\n  wallet: IWallet;\n}\n\nasync function fetchAddressDetails({\n  reqId,\n  disableNetworking,\n  addressDetailsPrebuild,\n  addressDetailsVerification,\n  currentAddress,\n  wallet,\n}: FetchAddressDetailsOptions) {\n  let addressDetails = _.extend({}, addressDetailsPrebuild, addressDetailsVerification);\n  debug('Locally available address %s details: %O', currentAddress, addressDetails);\n  if (_.isEmpty(addressDetails) && !disableNetworking) {\n    addressDetails = await wallet.getAddress({ address: currentAddress, reqId });\n    debug('Downloaded address %s details: %O', currentAddress, addressDetails);\n  }\n  return addressDetails;\n}\n\nexport interface CustomChangeOptions {\n  keys: [Keychain, Keychain, Keychain];\n  signatures: [string, string, string];\n}\n\nexport interface ParseOutputOptions {\n  currentOutput: Output;\n  coin: AbstractUtxoCoin;\n  txPrebuild: TransactionPrebuild;\n  verification: VerificationOptions;\n  keychainArray: [Keychain, Keychain, Keychain];\n  wallet: IWallet;\n  txParams: TransactionParams;\n  customChange?: CustomChangeOptions;\n  reqId?: IRequestTracer;\n}\n\nexport async function parseOutput({\n  currentOutput,\n  coin,\n  txPrebuild,\n  verification,\n  keychainArray,\n  wallet,\n  txParams,\n  customChange,\n  reqId,\n}: ParseOutputOptions): Promise<Output> {\n  const disableNetworking = !!verification.disableNetworking;\n  const currentAddress = currentOutput.address;\n\n  // attempt to grab the address details from either the prebuilt tx, or the verification params.\n  // If both of these are empty, then we will try to get the address details from bitgo instead\n  const addressDetailsPrebuild = _.get(txPrebuild, `txInfo.walletAddressDetails.${currentAddress}`, {});\n  const addressDetailsVerification: AddressVerificationData = verification?.addresses?.[currentAddress] ?? {};\n  debug('Parsing address details for %s', currentAddress);\n  let currentAddressDetails = undefined;\n  let currentAddressType: string | undefined = undefined;\n  try {\n    /**\n     * The only way to determine whether an address is known on the wallet is to initiate a network request and\n     * fetch it. Should the request fail and return a 404, it will throw and therefore has to be caught. For that\n     * reason, address wallet ownership detection is wrapped in a try/catch. Additionally, once the address\n     * details are fetched on the wallet, a local address validation is run, whose errors however are generated\n     * client-side and can therefore be analyzed with more granularity and type checking.\n     */\n    const addressDetails = await fetchAddressDetails({\n      reqId,\n      addressDetailsVerification,\n      addressDetailsPrebuild,\n      currentAddress,\n      disableNetworking,\n      wallet,\n    });\n    // verify that the address is on the wallet. verifyAddress throws if\n    // it fails to correctly rederive the address, meaning it's external\n    currentAddressType = AbstractUtxoCoin.inferAddressType(addressDetails) || undefined;\n    currentAddressDetails = addressDetails;\n    await coin.verifyAddress(\n      _.extend({ addressType: currentAddressType }, addressDetails, {\n        keychains: keychainArray,\n        address: currentAddress,\n      })\n    );\n    debug('Address %s verification passed', currentAddress);\n\n    // verify address succeeded without throwing, so the address was\n    // correctly rederived from the wallet keychains, making it not external\n    return _.extend({}, currentOutput, addressDetails, { external: false });\n  } catch (e) {\n    debug('Address %s verification threw an error:', currentAddress, e);\n    return _.extend(\n      {},\n      currentOutput,\n      await handleVerifyAddressError({\n        e,\n        coin,\n        currentAddress,\n        wallet,\n        txParams,\n        customChangeKeys: customChange && customChange.keys,\n        addressDetails: currentAddressDetails,\n        addressType: currentAddressType,\n        considerMigratedFromAddressInternal: verification.considerMigratedFromAddressInternal,\n      })\n    );\n  }\n}\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseOutput.js","sourceRoot":"","sources":["../../src/parseOutput.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\n\nimport * as debugLib from 'debug';\nimport * as _ from 'lodash';\nimport {\n  AddressVerificationData,\n  IRequestTracer,\n  InvalidAddressDerivationPropertyError,\n  IWallet,\n  Keychain,\n  TransactionPrebuild,\n  UnexpectedAddressError,\n  VerificationOptions,\n} from '@bitgo-beta/sdk-core';\nimport { AbstractUtxoCoin, Output, TransactionParams, isWalletOutput } from './abstractUtxoCoin';\n\nconst debug = debugLib('bitgo:v2:parseoutput');\n\ninterface HandleVerifyAddressErrorResponse {\n  external: boolean;\n  needsCustomChangeKeySignatureVerification?: boolean;\n}\n\n/**\n * Check an address which failed initial validation to see if it's the base address of a migrated v1 bch wallet.\n *\n * The wallet in question could be a migrated SafeHD BCH wallet, and the transaction we\n * are currently parsing is trying to spend change back to the v1 wallet base address.\n *\n * It does this since we don't allow new address creation for these wallets,\n * and instead return the base address from the v1 wallet when a new address is requested.\n * If this new address is requested for the purposes of spending change back to the wallet,\n * the change will go to the v1 wallet base address. This address *is* on the wallet,\n * but it will still cause an error to be thrown by verifyAddress, since the derivation path\n * used for this address is non-standard. (I have seen these addresses derived using paths m/0/0 and m/101,\n * whereas the v2 addresses are derived using path  m/0/0/${chain}/${index}).\n *\n * This means we need to check for this case explicitly in this catch block, and classify\n * these types of outputs as internal instead of external. Failing to do so would cause the\n * transaction's implicit external outputs (ie, outputs which go to addresses not specified in\n * the recipients array) to add up to more than the 150 basis point limit which we enforce on\n * pay-as-you-go outputs (which should be the only implicit external outputs on our transactions).\n *\n * The 150 basis point limit for implicit external sends is enforced in verifyTransaction,\n * which calls this function to get information on the total external/internal spend amounts\n * for a transaction. The idea here is to protect from the transaction being maliciously modified\n * to add more implicit external spends (eg, to an attacker-controlled wallet).\n *\n * See verifyTransaction for more information on how transaction prebuilds are verified before signing.\n *\n * @param wallet {Wallet} wallet which is making the transaction\n * @param currentAddress {string} address to check for externality relative to v1 wallet base address\n */\nfunction isMigratedAddress(wallet: IWallet, currentAddress: string): boolean {\n  if (_.isString(wallet.migratedFrom()) && wallet.migratedFrom() === currentAddress) {\n    debug('found address %s which was migrated from v1 wallet, address is not external', currentAddress);\n    return true;\n  }\n\n  return false;\n}\n\ninterface VerifyCustomChangeAddressOptions {\n  coin: AbstractUtxoCoin;\n  customChangeKeys: HandleVerifyAddressErrorOptions['customChangeKeys'];\n  addressType: HandleVerifyAddressErrorOptions['addressType'];\n  addressDetails: HandleVerifyAddressErrorOptions['addressDetails'];\n  currentAddress: HandleVerifyAddressErrorOptions['currentAddress'];\n}\n\n/**\n * Check to see if an address is derived from the given custom change keys\n * @param {VerifyCustomChangeAddressOptions} params\n * @return {boolean}\n */\nasync function verifyCustomChangeAddress(params: VerifyCustomChangeAddressOptions): Promise<boolean> {\n  const { coin, customChangeKeys, addressType, addressDetails, currentAddress } = params;\n  try {\n    return await coin.verifyAddress(\n      _.extend({ addressType }, addressDetails, {\n        keychains: customChangeKeys,\n        address: currentAddress,\n      })\n    );\n  } catch (e) {\n    debug('failed to verify custom change address %s', currentAddress);\n    return false;\n  }\n}\n\ninterface HandleVerifyAddressErrorOptions {\n  e: Error;\n  currentAddress: string;\n  wallet: IWallet;\n  txParams: TransactionParams;\n  customChangeKeys?: CustomChangeOptions['keys'];\n  coin: AbstractUtxoCoin;\n  addressDetails?: any;\n  addressType?: string;\n  considerMigratedFromAddressInternal?: boolean;\n}\n\nasync function handleVerifyAddressError({\n  e,\n  currentAddress,\n  wallet,\n  txParams,\n  customChangeKeys,\n  coin,\n  addressDetails,\n  addressType,\n  considerMigratedFromAddressInternal,\n}: HandleVerifyAddressErrorOptions): Promise<HandleVerifyAddressErrorResponse> {\n  // Todo: name server-side errors to avoid message-based checking [BG-5124]\n  const walletAddressNotFound = e.message.includes('wallet address not found');\n  const unexpectedAddress = e instanceof UnexpectedAddressError;\n  if (walletAddressNotFound || unexpectedAddress) {\n    if (unexpectedAddress && !walletAddressNotFound) {\n      // check to see if this is a migrated v1 bch address - it could be internal\n      const isMigrated = isMigratedAddress(wallet, currentAddress);\n      if (isMigrated) {\n        return { external: considerMigratedFromAddressInternal === false };\n      }\n\n      debug('Address %s was found on wallet but could not be reconstructed', currentAddress);\n\n      // attempt to verify address using custom change address keys if the wallet has that feature enabled\n      if (\n        customChangeKeys &&\n        (await verifyCustomChangeAddress({ coin, addressDetails, addressType, currentAddress, customChangeKeys }))\n      ) {\n        // address is valid against the custom change keys. Mark address as not external\n        // and request signature verification for the custom change keys\n        debug('Address %s verified as derived from the custom change keys', currentAddress);\n        return { external: false, needsCustomChangeKeySignatureVerification: true };\n      }\n    }\n\n    // the address was found, but not on the wallet, which simply means it's external\n    debug('Address %s presumed external', currentAddress);\n    return { external: true };\n  } else if (e instanceof InvalidAddressDerivationPropertyError && currentAddress === txParams.changeAddress) {\n    // expect to see this error when passing in a custom changeAddress with no chain or index\n    return { external: false };\n  }\n\n  console.error('Address classification failed for address', currentAddress);\n  console.trace(e);\n  /**\n   * It might be a completely invalid address or a bad validation attempt or something else completely, in\n   * which case we do not proceed and rather rethrow the error, which is safer than assuming that the address\n   * validation failed simply because it's external to the wallet.\n   */\n  throw e;\n}\n\ninterface FetchAddressDetailsOptions {\n  reqId?: IRequestTracer;\n  disableNetworking: boolean;\n  addressDetailsPrebuild: any;\n  addressDetailsVerification: any;\n  currentAddress: string;\n  wallet: IWallet;\n}\n\nasync function fetchAddressDetails({\n  reqId,\n  disableNetworking,\n  addressDetailsPrebuild,\n  addressDetailsVerification,\n  currentAddress,\n  wallet,\n}: FetchAddressDetailsOptions) {\n  let addressDetails = _.extend({}, addressDetailsPrebuild, addressDetailsVerification);\n  debug('Locally available address %s details: %O', currentAddress, addressDetails);\n  if (_.isEmpty(addressDetails) && !disableNetworking) {\n    addressDetails = await wallet.getAddress({ address: currentAddress, reqId });\n    debug('Downloaded address %s details: %O', currentAddress, addressDetails);\n  }\n  return addressDetails;\n}\n\nexport interface CustomChangeOptions {\n  keys: [Keychain, Keychain, Keychain];\n  signatures: [string, string, string];\n}\n\nexport interface ParseOutputOptions {\n  currentOutput: Output;\n  coin: AbstractUtxoCoin;\n  txPrebuild: TransactionPrebuild;\n  verification: VerificationOptions;\n  keychainArray: [Keychain, Keychain, Keychain];\n  wallet: IWallet;\n  txParams: TransactionParams;\n  customChange?: CustomChangeOptions;\n  reqId?: IRequestTracer;\n}\n\nexport async function parseOutput({\n  currentOutput,\n  coin,\n  txPrebuild,\n  verification,\n  keychainArray,\n  wallet,\n  txParams,\n  customChange,\n  reqId,\n}: ParseOutputOptions): Promise<Output> {\n  const disableNetworking = !!verification.disableNetworking;\n  const currentAddress = currentOutput.address;\n\n  // attempt to grab the address details from either the prebuilt tx, or the verification params.\n  // If both of these are empty, then we will try to get the address details from bitgo instead\n  const addressDetailsPrebuild = _.get(txPrebuild, `txInfo.walletAddressDetails.${currentAddress}`, {});\n  const addressDetailsVerification: AddressVerificationData = verification?.addresses?.[currentAddress] ?? {};\n  debug('Parsing address details for %s', currentAddress);\n  let currentAddressDetails = undefined;\n  let currentAddressType: string | undefined = undefined;\n  const RECIPIENT_THRESHOLD = 1000;\n  try {\n    // In the case of PSBTs, we can already determine the internal/external status of the output addresses\n    // based on the derivation information being included in the PSBT. We can short circuit GET v2.wallet.address\n    // and save on network requests. Since we have the derivation information already, we can still verify the address\n    if (currentOutput.external !== undefined) {\n      // In the case that we have a custom change wallet, we need to verify the address against the custom change keys\n      // and not the wallet keys. This check is done in the handleVerifyAddressError function if this error is thrown.\n      if (customChange !== undefined) {\n        throw new UnexpectedAddressError('`address validation failure');\n      }\n      // If it is an internal address, we can skip the network request and just verify the address locally with the\n      // derivation information we have. Otherwise, if the address is external, which is the only remaining case, we\n      // can just return the current output as is without contacting the server.\n      if (isWalletOutput(currentOutput)) {\n        const res = await coin.isWalletAddress({\n          addressType: AbstractUtxoCoin.inferAddressType({ chain: currentOutput.chain }) || undefined,\n          keychains: keychainArray as { pub: string; commonKeychain?: string | undefined }[],\n          address: currentAddress,\n          chain: currentOutput.chain,\n          index: currentOutput.index,\n        });\n        if (!res) {\n          throw new UnexpectedAddressError();\n        }\n      }\n      return currentOutput;\n    }\n    /**\n     * The only way to determine whether an address is known on the wallet is to initiate a network request and\n     * fetch it. Should the request fail and return a 404, it will throw and therefore has to be caught. For that\n     * reason, address wallet ownership detection is wrapped in a try/catch. Additionally, once the address\n     * details are fetched on the wallet, a local address validation is run, whose errors however are generated\n     * client-side and can therefore be analyzed with more granularity and type checking.\n     */\n\n    /**\n     * In order to minimize API requests, we assume that explicit recipients are always external when the\n     * recipient list is > 1000 This is not always a valid assumption and could lead greater apparent spend (but never lower)\n     */\n    if (txParams.recipients !== undefined && txParams.recipients.length > RECIPIENT_THRESHOLD) {\n      const isCurrentAddressInRecipients = txParams.recipients.some((recipient) =>\n        recipient.address.includes(currentAddress)\n      );\n\n      if (isCurrentAddressInRecipients) {\n        return { ...currentOutput };\n      }\n    }\n\n    const addressDetails = await fetchAddressDetails({\n      reqId,\n      addressDetailsVerification,\n      addressDetailsPrebuild,\n      currentAddress,\n      disableNetworking,\n      wallet,\n    });\n    // verify that the address is on the wallet. verifyAddress throws if\n    // it fails to correctly rederive the address, meaning it's external\n    currentAddressType = AbstractUtxoCoin.inferAddressType(addressDetails) || undefined;\n    currentAddressDetails = addressDetails;\n    await coin.verifyAddress(\n      _.extend({ addressType: currentAddressType }, addressDetails, {\n        keychains: keychainArray,\n        address: currentAddress,\n      })\n    );\n    debug('Address %s verification passed', currentAddress);\n\n    // verify address succeeded without throwing, so the address was\n    // correctly rederived from the wallet keychains, making it not external\n    return _.extend({}, currentOutput, addressDetails, { external: false });\n  } catch (e) {\n    debug('Address %s verification threw an error:', currentAddress, e);\n    return _.extend(\n      {},\n      currentOutput,\n      await handleVerifyAddressError({\n        e,\n        coin,\n        currentAddress,\n        wallet,\n        txParams,\n        customChangeKeys: customChange && customChange.keys,\n        addressDetails: currentAddressDetails,\n        addressType: currentAddressType,\n        considerMigratedFromAddressInternal: verification.considerMigratedFromAddressInternal,\n      })\n    );\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { AddressInfo, TransactionIO } from '@bitgo-beta/blockapis';
2
2
  import { bitgo } from '@bitgo-beta/utxo-lib';
3
- declare type Unspent<TNumber extends number | bigint = number> = bitgo.Unspent<TNumber>;
3
+ type Unspent<TNumber extends number | bigint = number> = bitgo.Unspent<TNumber>;
4
4
  /**
5
5
  * An account with bear minimum information required for recoveries.
6
6
  */
@@ -1 +1 @@
1
- {"version":3,"file":"RecoveryProvider.d.ts","sourceRoot":"","sources":["../../../src/recovery/RecoveryProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiC,WAAW,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAElG,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAE7C,aAAK,OAAO,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAEhF;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM;IACxE,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC1E,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IACtD,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACjD,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;CACxD;AAED,wBAAgB,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAiBrF"}
1
+ {"version":3,"file":"RecoveryProvider.d.ts","sourceRoot":"","sources":["../../../src/recovery/RecoveryProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,WAAW,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAElF,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAE7C,KAAK,OAAO,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAEhF;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM;IACxE,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC1E,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IACtD,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACjD,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;CACxD;AAED,wBAAgB,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAgBrF"}
@@ -7,7 +7,6 @@ function forCoin(coinName, apiToken) {
7
7
  switch (coinName) {
8
8
  case 'btc':
9
9
  case 'tbtc':
10
- return blockapis_1.BlockstreamApi.forCoin(coinName);
11
10
  case 'bch':
12
11
  case 'bcha':
13
12
  case 'bsv':
@@ -21,4 +20,4 @@ function forCoin(coinName, apiToken) {
21
20
  throw new baseApi_1.ApiNotImplementedError(coinName);
22
21
  }
23
22
  exports.forCoin = forCoin;
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVjb3ZlcnlQcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9yZWNvdmVyeS9SZWNvdmVyeVByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFEQUFrRztBQUNsRyx1Q0FBbUQ7QUF1Qm5ELFNBQWdCLE9BQU8sQ0FBQyxRQUFnQixFQUFFLFFBQWlCO0lBQ3pELFFBQVEsUUFBUSxFQUFFO1FBQ2hCLEtBQUssS0FBSyxDQUFDO1FBQ1gsS0FBSyxNQUFNO1lBQ1QsT0FBTywwQkFBYyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMxQyxLQUFLLEtBQUssQ0FBQztRQUNYLEtBQUssTUFBTSxDQUFDO1FBQ1osS0FBSyxLQUFLLENBQUM7UUFDWCxLQUFLLEtBQUssQ0FBQztRQUNYLEtBQUssTUFBTSxDQUFDO1FBQ1osS0FBSyxNQUFNLENBQUM7UUFDWixLQUFLLEtBQUssQ0FBQztRQUNYLEtBQUssS0FBSztZQUNSLE9BQU8seUJBQWEsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztLQUN4RDtJQUVELE1BQU0sSUFBSSxnQ0FBc0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBakJELDBCQWlCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJsb2NrY2hhaXJBcGksIEJsb2Nrc3RyZWFtQXBpLCBBZGRyZXNzSW5mbywgVHJhbnNhY3Rpb25JTyB9IGZyb20gJ0BiaXRnby1iZXRhL2Jsb2NrYXBpcyc7XG5pbXBvcnQgeyBBcGlOb3RJbXBsZW1lbnRlZEVycm9yIH0gZnJvbSAnLi9iYXNlQXBpJztcbmltcG9ydCB7IGJpdGdvIH0gZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG50eXBlIFVuc3BlbnQ8VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludCA9IG51bWJlcj4gPSBiaXRnby5VbnNwZW50PFROdW1iZXI+O1xuXG4vKipcbiAqIEFuIGFjY291bnQgd2l0aCBiZWFyIG1pbmltdW0gaW5mb3JtYXRpb24gcmVxdWlyZWQgZm9yIHJlY292ZXJpZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVjb3ZlcnlBY2NvdW50RGF0YSB7XG4gIHR4Q291bnQ6IG51bWJlcjtcbiAgdG90YWxCYWxhbmNlOiBudW1iZXI7XG59XG5cbi8qKlxuICogRmFjdG9yeSBmb3IgQWRkcmVzc0FwaSAmIFV0eG9BcGlcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSZWNvdmVyeVByb3ZpZGVyPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQgPSBudW1iZXI+IHtcbiAgZ2V0VW5zcGVudHNGb3JBZGRyZXNzZXMoYWRkcmVzc2VzOiBzdHJpbmdbXSk6IFByb21pc2U8VW5zcGVudDxUTnVtYmVyPltdPjtcbiAgZ2V0QWRkcmVzc0luZm8oYWRkcmVzczogc3RyaW5nKTogUHJvbWlzZTxBZGRyZXNzSW5mbz47XG4gIGdldFRyYW5zYWN0aW9uSGV4KHR4aWQ6IHN0cmluZyk6IFByb21pc2U8c3RyaW5nPjtcbiAgZ2V0VHJhbnNhY3Rpb25JTyh0eGlkOiBzdHJpbmcpOiBQcm9taXNlPFRyYW5zYWN0aW9uSU8+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9yQ29pbihjb2luTmFtZTogc3RyaW5nLCBhcGlUb2tlbj86IHN0cmluZyk6IFJlY292ZXJ5UHJvdmlkZXI8bnVtYmVyPiB7XG4gIHN3aXRjaCAoY29pbk5hbWUpIHtcbiAgICBjYXNlICdidGMnOlxuICAgIGNhc2UgJ3RidGMnOlxuICAgICAgcmV0dXJuIEJsb2Nrc3RyZWFtQXBpLmZvckNvaW4oY29pbk5hbWUpO1xuICAgIGNhc2UgJ2JjaCc6XG4gICAgY2FzZSAnYmNoYSc6XG4gICAgY2FzZSAnYnN2JzpcbiAgICBjYXNlICdidGcnOlxuICAgIGNhc2UgJ2Rhc2gnOlxuICAgIGNhc2UgJ2RvZ2UnOlxuICAgIGNhc2UgJ2x0Yyc6XG4gICAgY2FzZSAnemVjJzpcbiAgICAgIHJldHVybiBCbG9ja2NoYWlyQXBpLmZvckNvaW4oY29pbk5hbWUsIHsgYXBpVG9rZW4gfSk7XG4gIH1cblxuICB0aHJvdyBuZXcgQXBpTm90SW1wbGVtZW50ZWRFcnJvcihjb2luTmFtZSk7XG59XG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVjb3ZlcnlQcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9yZWNvdmVyeS9SZWNvdmVyeVByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFEQUFrRjtBQUNsRix1Q0FBbUQ7QUF1Qm5ELFNBQWdCLE9BQU8sQ0FBQyxRQUFnQixFQUFFLFFBQWlCO0lBQ3pELFFBQVEsUUFBUSxFQUFFO1FBQ2hCLEtBQUssS0FBSyxDQUFDO1FBQ1gsS0FBSyxNQUFNLENBQUM7UUFDWixLQUFLLEtBQUssQ0FBQztRQUNYLEtBQUssTUFBTSxDQUFDO1FBQ1osS0FBSyxLQUFLLENBQUM7UUFDWCxLQUFLLEtBQUssQ0FBQztRQUNYLEtBQUssTUFBTSxDQUFDO1FBQ1osS0FBSyxNQUFNLENBQUM7UUFDWixLQUFLLEtBQUssQ0FBQztRQUNYLEtBQUssS0FBSztZQUNSLE9BQU8seUJBQWEsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztLQUN4RDtJQUVELE1BQU0sSUFBSSxnQ0FBc0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBaEJELDBCQWdCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJsb2NrY2hhaXJBcGksIEFkZHJlc3NJbmZvLCBUcmFuc2FjdGlvbklPIH0gZnJvbSAnQGJpdGdvLWJldGEvYmxvY2thcGlzJztcbmltcG9ydCB7IEFwaU5vdEltcGxlbWVudGVkRXJyb3IgfSBmcm9tICcuL2Jhc2VBcGknO1xuaW1wb3J0IHsgYml0Z28gfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5cbnR5cGUgVW5zcGVudDxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyPiA9IGJpdGdvLlVuc3BlbnQ8VE51bWJlcj47XG5cbi8qKlxuICogQW4gYWNjb3VudCB3aXRoIGJlYXIgbWluaW11bSBpbmZvcm1hdGlvbiByZXF1aXJlZCBmb3IgcmVjb3Zlcmllcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSZWNvdmVyeUFjY291bnREYXRhIHtcbiAgdHhDb3VudDogbnVtYmVyO1xuICB0b3RhbEJhbGFuY2U6IG51bWJlcjtcbn1cblxuLyoqXG4gKiBGYWN0b3J5IGZvciBBZGRyZXNzQXBpICYgVXR4b0FwaVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlY292ZXJ5UHJvdmlkZXI8VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludCA9IG51bWJlcj4ge1xuICBnZXRVbnNwZW50c0ZvckFkZHJlc3NlcyhhZGRyZXNzZXM6IHN0cmluZ1tdKTogUHJvbWlzZTxVbnNwZW50PFROdW1iZXI+W10+O1xuICBnZXRBZGRyZXNzSW5mbyhhZGRyZXNzOiBzdHJpbmcpOiBQcm9taXNlPEFkZHJlc3NJbmZvPjtcbiAgZ2V0VHJhbnNhY3Rpb25IZXgodHhpZDogc3RyaW5nKTogUHJvbWlzZTxzdHJpbmc+O1xuICBnZXRUcmFuc2FjdGlvbklPKHR4aWQ6IHN0cmluZyk6IFByb21pc2U8VHJhbnNhY3Rpb25JTz47XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JDb2luKGNvaW5OYW1lOiBzdHJpbmcsIGFwaVRva2VuPzogc3RyaW5nKTogUmVjb3ZlcnlQcm92aWRlcjxudW1iZXI+IHtcbiAgc3dpdGNoIChjb2luTmFtZSkge1xuICAgIGNhc2UgJ2J0Yyc6XG4gICAgY2FzZSAndGJ0Yyc6XG4gICAgY2FzZSAnYmNoJzpcbiAgICBjYXNlICdiY2hhJzpcbiAgICBjYXNlICdic3YnOlxuICAgIGNhc2UgJ2J0Zyc6XG4gICAgY2FzZSAnZGFzaCc6XG4gICAgY2FzZSAnZG9nZSc6XG4gICAgY2FzZSAnbHRjJzpcbiAgICBjYXNlICd6ZWMnOlxuICAgICAgcmV0dXJuIEJsb2NrY2hhaXJBcGkuZm9yQ29pbihjb2luTmFtZSwgeyBhcGlUb2tlbiB9KTtcbiAgfVxuXG4gIHRocm93IG5ldyBBcGlOb3RJbXBsZW1lbnRlZEVycm9yKGNvaW5OYW1lKTtcbn1cbiJdfQ==
@@ -2,16 +2,15 @@
2
2
  * @prettier
3
3
  */
4
4
  import * as utxolib from '@bitgo-beta/utxo-lib';
5
- declare type WalletUnspent<TNumber extends number | bigint = number> = utxolib.bitgo.WalletUnspent<TNumber>;
6
- declare type WalletUnspentJSON = utxolib.bitgo.WalletUnspent & {
5
+ type WalletUnspentJSON = utxolib.bitgo.WalletUnspent & {
7
6
  valueString: string;
8
7
  };
9
- declare type ScriptType2Of3 = utxolib.bitgo.outputScripts.ScriptType2Of3;
8
+ type ScriptType2Of3 = utxolib.bitgo.outputScripts.ScriptType2Of3;
10
9
  import { BitGoBase } from '@bitgo-beta/sdk-core';
11
10
  import { AbstractUtxoCoin } from '../abstractUtxoCoin';
12
11
  import { RecoveryProvider } from './RecoveryProvider';
13
- export interface OfflineVaultTxInfo<TNumber extends number | bigint = number> {
14
- inputs: WalletUnspent<TNumber>[];
12
+ export interface OfflineVaultTxInfo {
13
+ inputs: WalletUnspentJSON[];
15
14
  }
16
15
  export interface FormattedOfflineVaultTxInfo {
17
16
  txInfo: {
@@ -34,16 +33,23 @@ export interface RecoverParams {
34
33
  userKeyPath?: string;
35
34
  recoveryProvider?: RecoveryProvider;
36
35
  }
37
- export declare type BackupKeyRecoveryTransansaction<TNumber extends number | bigint = number> = {
38
- inputs: WalletUnspent<TNumber>[];
36
+ export type BackupKeyRecoveryTransansaction = {
37
+ inputs?: WalletUnspentJSON[];
39
38
  transactionHex: string;
40
39
  coin: string;
41
40
  backupKey: string;
42
- recoveryAmount: TNumber;
43
- tx?: unknown;
41
+ recoveryAmount: number;
42
+ recoveryAmountString: string;
44
43
  };
45
44
  /**
46
- * Builds a funds recovery transaction without BitGo
45
+ * Builds a funds recovery transaction without BitGo.
46
+ *
47
+ * Returns transaction hex in legacy format for unsigned sweep transaction, half signed backup recovery transaction with KRS provider (only keyternal),
48
+ * fully signed backup recovery transaction without a KRS provider.
49
+ *
50
+ * Returns PSBT hex for half signed backup recovery transaction with KRS provider (excluding keyternal)
51
+ * For PSBT hex cases, Unspents are not required in response.
52
+ *
47
53
  * @param coin
48
54
  * @param bitgo
49
55
  * @param params
@@ -57,6 +63,28 @@ export declare type BackupKeyRecoveryTransansaction<TNumber extends number | big
57
63
  * - ignoreAddressTypes: (optional) scripts to ignore
58
64
  * for example: ['p2shP2wsh', 'p2wsh'] will prevent code from checking for wrapped-segwit and native-segwit chains on the public block explorers
59
65
  */
60
- export declare function backupKeyRecovery<TNumber extends number | bigint = number>(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: RecoverParams): Promise<BackupKeyRecoveryTransansaction<TNumber> | FormattedOfflineVaultTxInfo>;
66
+ export declare function backupKeyRecovery(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: RecoverParams): Promise<BackupKeyRecoveryTransansaction | FormattedOfflineVaultTxInfo>;
67
+ export interface BitGoV1Unspent {
68
+ tx_hash: string;
69
+ tx_output_n: number;
70
+ value: number;
71
+ }
72
+ export interface V1SweepParams {
73
+ walletId: string;
74
+ walletPassphrase: string;
75
+ unspents: BitGoV1Unspent[];
76
+ recoveryDestination: string;
77
+ userKey: string;
78
+ otp: string;
79
+ }
80
+ export interface V1RecoverParams extends Omit<V1SweepParams, 'otp'> {
81
+ backupKey: string;
82
+ }
83
+ export declare function v1BackupKeyRecovery(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: V1RecoverParams): Promise<string>;
84
+ export declare function v1Sweep(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: V1SweepParams): Promise<{
85
+ tx: string;
86
+ hash: string;
87
+ status: string;
88
+ }>;
61
89
  export {};
62
90
  //# sourceMappingURL=backupKeyRecovery.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"backupKeyRecovery.d.ts","sourceRoot":"","sources":["../../../src/recovery/backupKeyRecovery.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAYhD,aAAK,aAAa,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;AACpG,aAAK,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,GAAG;IACrD,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AACF,aAAK,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC;AAIjE,OAAO,EACL,SAAS,EAQV,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,OAAO,EAAW,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAO/D,MAAM,WAAW,kBAAkB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM;IAC1E,MAAM,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC;CAClC;AAED,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE;QACN,QAAQ,EAAE,iBAAiB,EAAE,CAAC;KAC/B,CAAC;IACF,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;CACd;AAkED,MAAM,WAAW,aAAa;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,cAAc,EAAE,CAAC;IACrC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACrC;AA8FD,oBAAY,+BAA+B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI;IACtF,MAAM,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC;IACjC,cAAc,EAAE,MAAM,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,OAAO,CAAC;IAExB,EAAE,CAAC,EAAE,OAAO,CAAC;CACd,CAAC;AAEF;;;;;;;;;;;;;;GAcG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,EAC9E,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC,+BAA+B,CAAC,OAAO,CAAC,GAAG,2BAA2B,CAAC,CA0LjF"}
1
+ {"version":3,"file":"backupKeyRecovery.d.ts","sourceRoot":"","sources":["../../../src/recovery/backupKeyRecovery.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAMhD,KAAK,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,GAAG;IACrD,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AACF,KAAK,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC;AAIjE,OAAO,EACL,SAAS,EAQV,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAmB,MAAM,qBAAqB,CAAC;AAExE,OAAO,EAAW,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAM/D,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,iBAAiB,EAAE,CAAC;CAC7B;AAED,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE;QACN,QAAQ,EAAE,iBAAiB,EAAE,CAAC;KAC/B,CAAC;IACF,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;CACd;AAmED,MAAM,WAAW,aAAa;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,cAAc,EAAE,CAAC;IACrC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACrC;AAiHD,MAAM,MAAM,+BAA+B,GAAG;IAC5C,MAAM,CAAC,EAAE,iBAAiB,EAAE,CAAC;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAsB,iBAAiB,CACrC,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC,+BAA+B,GAAG,2BAA2B,CAAC,CAqJxE;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,EAAE,MAAM,CAAC;IACzB,QAAQ,EAAE,cAAc,EAAE,CAAC;IAC3B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,eAAgB,SAAQ,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC;IACjE,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,wBAAsB,mBAAmB,CACvC,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,MAAM,CAAC,CAcjB;AAED,wBAAsB,OAAO,CAC3B,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC;IACT,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC,CAkBD"}