mainnet-js 0.4.30 → 0.4.31

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 (62) hide show
  1. package/dist/index.html +1 -1
  2. package/dist/main/constant.d.ts +1 -0
  3. package/dist/main/constant.js +17 -1
  4. package/dist/main/constant.js.map +1 -1
  5. package/dist/main/util/getAddrsByXpubKey.d.ts +22 -0
  6. package/dist/main/util/getAddrsByXpubKey.js +79 -0
  7. package/dist/main/util/getAddrsByXpubKey.js.map +1 -0
  8. package/dist/main/util/getXPubKey.d.ts +1 -0
  9. package/dist/main/util/getXPubKey.js +26 -0
  10. package/dist/main/util/getXPubKey.js.map +1 -0
  11. package/dist/main/util/index.d.ts +5 -3
  12. package/dist/main/util/index.js +13 -6
  13. package/dist/main/util/index.js.map +1 -1
  14. package/dist/main/wallet/Base.d.ts +3 -1
  15. package/dist/main/wallet/Base.js +3 -1
  16. package/dist/main/wallet/Base.js.map +1 -1
  17. package/dist/main/wallet/Wif.d.ts +4 -0
  18. package/dist/main/wallet/Wif.js +72 -3
  19. package/dist/main/wallet/Wif.js.map +1 -1
  20. package/dist/main/wallet/interface.d.ts +4 -0
  21. package/dist/main/wallet/model.d.ts +16 -0
  22. package/dist/main/wallet/model.js +18 -1
  23. package/dist/main/wallet/model.js.map +1 -1
  24. package/dist/mainnet-0.4.31.js +2 -0
  25. package/dist/{mainnet-0.4.30.js.LICENSE.txt → mainnet-0.4.31.js.LICENSE.txt} +0 -0
  26. package/dist/module/constant.d.ts +1 -0
  27. package/dist/module/constant.js +16 -0
  28. package/dist/module/constant.js.map +1 -1
  29. package/dist/module/util/getAddrsByXpubKey.d.ts +22 -0
  30. package/dist/module/util/getAddrsByXpubKey.js +71 -0
  31. package/dist/module/util/getAddrsByXpubKey.js.map +1 -0
  32. package/dist/module/util/getXPubKey.d.ts +1 -0
  33. package/dist/module/util/getXPubKey.js +22 -0
  34. package/dist/module/util/getXPubKey.js.map +1 -0
  35. package/dist/module/util/index.d.ts +5 -3
  36. package/dist/module/util/index.js +5 -3
  37. package/dist/module/util/index.js.map +1 -1
  38. package/dist/module/wallet/Base.d.ts +3 -1
  39. package/dist/module/wallet/Base.js +3 -1
  40. package/dist/module/wallet/Base.js.map +1 -1
  41. package/dist/module/wallet/Wif.d.ts +4 -0
  42. package/dist/module/wallet/Wif.js +76 -7
  43. package/dist/module/wallet/Wif.js.map +1 -1
  44. package/dist/module/wallet/interface.d.ts +4 -0
  45. package/dist/module/wallet/model.d.ts +16 -0
  46. package/dist/module/wallet/model.js +16 -0
  47. package/dist/module/wallet/model.js.map +1 -1
  48. package/dist/tsconfig.browser.tsbuildinfo +1 -1
  49. package/dist/tsconfig.tsbuildinfo +1 -1
  50. package/package.json +1 -1
  51. package/src/constant.ts +17 -0
  52. package/src/util/getAddrsByXpubKey.test.ts +115 -0
  53. package/src/util/getAddrsByXpubKey.ts +98 -0
  54. package/src/util/getXPubKey.ts +36 -0
  55. package/src/util/index.ts +10 -3
  56. package/src/wallet/Base.ts +4 -1
  57. package/src/wallet/Wif.test.ts +173 -1
  58. package/src/wallet/Wif.ts +100 -15
  59. package/src/wallet/createWallet.test.ts +2 -0
  60. package/src/wallet/interface.ts +4 -0
  61. package/src/wallet/model.ts +22 -0
  62. package/dist/mainnet-0.4.30.js +0 -2
package/dist/index.html CHANGED
@@ -1 +1 @@
1
- <!doctype html><html><head><meta charset="utf-8"><title>The Empty Mainnet App</title><meta name="viewport" content="width=device-width,initial-scale=1"><script defer="defer" src="mainnet-0.4.30.js"></script></head><body></body></html>
1
+ <!doctype html><html><head><meta charset="utf-8"><title>The Empty Mainnet App</title><meta name="viewport" content="width=device-width,initial-scale=1"><script defer="defer" src="mainnet-0.4.31.js"></script></head><body></body></html>
@@ -2,3 +2,4 @@ export declare const DELIMITER = ":";
2
2
  export declare const DUST_UTXO_THRESHOLD = 546;
3
3
  export declare const MEMPOOL_CHAIN_LIMIT = 50;
4
4
  export declare const EXCHANGE_RATE_TTL = 250000;
5
+ export declare const DERIVATION_PATHS: string[];
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EXCHANGE_RATE_TTL = exports.MEMPOOL_CHAIN_LIMIT = exports.DUST_UTXO_THRESHOLD = exports.DELIMITER = void 0;
3
+ exports.DERIVATION_PATHS = exports.EXCHANGE_RATE_TTL = exports.MEMPOOL_CHAIN_LIMIT = exports.DUST_UTXO_THRESHOLD = exports.DELIMITER = void 0;
4
4
  exports.DELIMITER = ":";
5
5
  // Min amount utxo can be to be accepted by the network
6
6
  exports.DUST_UTXO_THRESHOLD = 546;
@@ -8,4 +8,20 @@ exports.DUST_UTXO_THRESHOLD = 546;
8
8
  exports.MEMPOOL_CHAIN_LIMIT = 50;
9
9
  // time in milliseconds to cache the usd exchange rate
10
10
  exports.EXCHANGE_RATE_TTL = 250000;
11
+ // list of common derivation paths
12
+ // a la: https://github.com/Electron-Cash/Electron-Cash/blob/1de24c509992cfebc22217a2a77c862c2b02bc54/electroncash_gui/qt/installwizard.py#L624
13
+ exports.DERIVATION_PATHS = [
14
+ "m/0",
15
+ "m/0'",
16
+ "m/0'/0",
17
+ "m/0'/0'",
18
+ "m/0'/0'/0'",
19
+ "m/44'/0'/0'",
20
+ "m/44'/0'/0'/0",
21
+ "m/44'/145'/0'",
22
+ "m/44'/145'/0'/0",
23
+ "m/44'/245'/0",
24
+ "m/44'/245'/0'",
25
+ "m/44'/245'/0'/0",
26
+ ];
11
27
  //# sourceMappingURL=constant.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constant.js","sourceRoot":"","sources":["../../src/constant.ts"],"names":[],"mappings":";;;AAAa,QAAA,SAAS,GAAG,GAAG,CAAC;AAE7B,uDAAuD;AAC1C,QAAA,mBAAmB,GAAG,GAAG,CAAC;AAEvC,2BAA2B;AACd,QAAA,mBAAmB,GAAG,EAAE,CAAC;AAEtC,sDAAsD;AACzC,QAAA,iBAAiB,GAAG,MAAM,CAAC"}
1
+ {"version":3,"file":"constant.js","sourceRoot":"","sources":["../../src/constant.ts"],"names":[],"mappings":";;;AAAa,QAAA,SAAS,GAAG,GAAG,CAAC;AAE7B,uDAAuD;AAC1C,QAAA,mBAAmB,GAAG,GAAG,CAAC;AAEvC,2BAA2B;AACd,QAAA,mBAAmB,GAAG,EAAE,CAAC;AAEtC,sDAAsD;AACzC,QAAA,iBAAiB,GAAG,MAAM,CAAC;AAExC,kCAAkC;AAClC,+IAA+I;AAClI,QAAA,gBAAgB,GAAG;IAC9B,KAAK;IACL,MAAM;IACN,QAAQ;IACR,SAAS;IACT,YAAY;IACZ,aAAa;IACb,eAAe;IACf,eAAe;IACf,iBAAiB;IACjB,cAAc;IACd,eAAe;IACf,iBAAiB;CAClB,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { HdKeyNetwork } from "@bitauth/libauth";
2
+ export declare function getAddrsByXpubKey(xpub: string, path: string, count: number): Promise<[unknown, unknown, unknown, unknown, unknown, unknown, unknown, unknown, unknown, unknown]>;
3
+ export declare function getAddrsByXpubKeyObject(obj: any): Promise<[unknown, unknown, unknown, unknown, unknown, unknown, unknown, unknown, unknown, unknown]>;
4
+ export declare function derivePublicNodeCashaddr(xpub: any, index: number, path?: string): Promise<any>;
5
+ export declare function getXpubKeyInfo(hdPublicKey: any): Promise<{
6
+ version: HdKeyNetwork;
7
+ depth: number;
8
+ parentFingerprint: string;
9
+ childNumber: number;
10
+ chain: string;
11
+ data: string;
12
+ fingerprint: string;
13
+ }>;
14
+ export declare function getXpubKeyInfoObject(obj: any): Promise<{
15
+ version: HdKeyNetwork;
16
+ depth: number;
17
+ parentFingerprint: string;
18
+ childNumber: number;
19
+ chain: string;
20
+ data: string;
21
+ fingerprint: string;
22
+ }>;
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getXpubKeyInfoObject = exports.getXpubKeyInfo = exports.derivePublicNodeCashaddr = exports.getAddrsByXpubKeyObject = exports.getAddrsByXpubKey = void 0;
4
+ const libauth_1 = require("@bitauth/libauth");
5
+ const hash160_1 = require("./hash160");
6
+ async function getAddrsByXpubKey(xpub, path, count) {
7
+ let pathComponents = path.split("/");
8
+ let rootStr = pathComponents.shift();
9
+ let root;
10
+ if (rootStr === "M" || rootStr === "m") {
11
+ rootStr = pathComponents.shift();
12
+ }
13
+ root = parseInt(rootStr);
14
+ let result = [];
15
+ const start = parseInt(pathComponents.pop());
16
+ const end = start + count;
17
+ for (let curr = start; curr < end; curr++) {
18
+ let childPath = ["M", root, ...pathComponents, curr].join("/");
19
+ result.push(derivePublicNodeCashaddr(xpub, root, childPath));
20
+ }
21
+ return await Promise.all(result).then((result) => {
22
+ return result;
23
+ });
24
+ }
25
+ exports.getAddrsByXpubKey = getAddrsByXpubKey;
26
+ async function getAddrsByXpubKeyObject(obj) {
27
+ return await getAddrsByXpubKey(obj.xpubkey, obj.path, obj.count);
28
+ }
29
+ exports.getAddrsByXpubKeyObject = getAddrsByXpubKeyObject;
30
+ async function derivePublicNodeCashaddr(xpub, index, path) {
31
+ const crypto = await (0, libauth_1.instantiateBIP32Crypto)();
32
+ const publicParent = await (0, libauth_1.decodeHdPublicKey)(crypto, xpub);
33
+ if (typeof publicParent === "string") {
34
+ throw new Error(publicParent);
35
+ }
36
+ let prefix = publicParent.network === "mainnet" ? "bitcoincash" : "bchtest";
37
+ let node = await (0, libauth_1.deriveHdPublicNodeChild)(crypto, publicParent.node, index);
38
+ if (typeof node === "string") {
39
+ throw new Error(node);
40
+ }
41
+ let cashaddr;
42
+ if (typeof path === "string") {
43
+ if (path[0] !== "M") {
44
+ throw Error("use M for public path derivation");
45
+ }
46
+ let childNode = (0, libauth_1.deriveHdPath)(crypto, publicParent.node, path);
47
+ if (typeof childNode === "string") {
48
+ throw new Error(childNode);
49
+ }
50
+ else {
51
+ let childPkh = await (0, hash160_1.hash160)(childNode.publicKey);
52
+ cashaddr = (0, libauth_1.encodeCashAddress)(prefix, 0, childPkh);
53
+ }
54
+ }
55
+ return cashaddr;
56
+ }
57
+ exports.derivePublicNodeCashaddr = derivePublicNodeCashaddr;
58
+ async function getXpubKeyInfo(hdPublicKey) {
59
+ const crypto = await (0, libauth_1.instantiateBIP32Crypto)();
60
+ let node = (0, libauth_1.decodeHdPublicKey)(crypto, hdPublicKey);
61
+ if (typeof node === "string") {
62
+ throw new Error(node);
63
+ }
64
+ return {
65
+ version: node.network,
66
+ depth: node.node.depth,
67
+ parentFingerprint: (0, libauth_1.binToHex)(node.node.parentFingerprint),
68
+ childNumber: node.node.childIndex,
69
+ chain: (0, libauth_1.binToHex)(node.node.chainCode),
70
+ data: (0, libauth_1.binToHex)(node.node.publicKey),
71
+ fingerprint: (0, libauth_1.binToHex)((await (0, hash160_1.hash160)(node.node.publicKey)).slice(0, 4)),
72
+ };
73
+ }
74
+ exports.getXpubKeyInfo = getXpubKeyInfo;
75
+ async function getXpubKeyInfoObject(obj) {
76
+ return await getXpubKeyInfo(obj.xpubkey);
77
+ }
78
+ exports.getXpubKeyInfoObject = getXpubKeyInfoObject;
79
+ //# sourceMappingURL=getAddrsByXpubKey.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getAddrsByXpubKey.js","sourceRoot":"","sources":["../../../src/util/getAddrsByXpubKey.ts"],"names":[],"mappings":";;;AAAA,8CAU0B;AAG1B,uCAAoC;AAE7B,KAAK,UAAU,iBAAiB,CACrC,IAAY,EACZ,IAAY,EACZ,KAAa;IAEb,IAAI,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACrC,IAAI,OAAO,GAAG,cAAc,CAAC,KAAK,EAAG,CAAC;IACtC,IAAI,IAAY,CAAC;IACjB,IAAI,OAAO,KAAK,GAAG,IAAI,OAAO,KAAK,GAAG,EAAE;QACtC,OAAO,GAAG,cAAc,CAAC,KAAK,EAAG,CAAC;KACnC;IACD,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;IACzB,IAAI,MAAM,GAAQ,EAAE,CAAC;IAErB,MAAM,KAAK,GAAG,QAAQ,CAAC,cAAc,CAAC,GAAG,EAAG,CAAC,CAAC;IAC9C,MAAM,GAAG,GAAG,KAAK,GAAG,KAAK,CAAC;IAC1B,KAAK,IAAI,IAAI,GAAG,KAAK,EAAE,IAAI,GAAG,GAAG,EAAE,IAAI,EAAE,EAAE;QACzC,IAAI,SAAS,GAAG,CAAC,GAAG,EAAE,IAAI,EAAE,GAAG,cAAc,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/D,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;KAC9D;IACD,OAAO,MAAM,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;QAC/C,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC;AAvBD,8CAuBC;AAEM,KAAK,UAAU,uBAAuB,CAAC,GAAG;IAC/C,OAAO,MAAM,iBAAiB,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;AACnE,CAAC;AAFD,0DAEC;AAEM,KAAK,UAAU,wBAAwB,CAC5C,IAAI,EACJ,KAAa,EACb,IAAa;IAEb,MAAM,MAAM,GAAG,MAAM,IAAA,gCAAsB,GAAE,CAAC;IAC9C,MAAM,YAAY,GAAG,MAAM,IAAA,2BAAiB,EAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAE3D,IAAI,OAAO,YAAY,KAAK,QAAQ,EAAE;QACpC,MAAM,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;KAC/B;IACD,IAAI,MAAM,GAAG,YAAY,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;IAE5E,IAAI,IAAI,GAAG,MAAM,IAAA,iCAAuB,EAAC,MAAM,EAAE,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC3E,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC;KACvB;IAED,IAAI,QAAQ,CAAC;IACb,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;YACnB,MAAM,KAAK,CAAC,kCAAkC,CAAC,CAAC;SACjD;QACD,IAAI,SAAS,GAAG,IAAA,sBAAY,EAAC,MAAM,EAAE,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC9D,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC;SAC5B;aAAM;YACL,IAAI,QAAQ,GAAG,MAAM,IAAA,iBAAO,EAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAClD,QAAQ,GAAG,IAAA,2BAAiB,EAAC,MAAM,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;SACnD;KACF;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAhCD,4DAgCC;AAEM,KAAK,UAAU,cAAc,CAAC,WAAW;IAC9C,MAAM,MAAM,GAAG,MAAM,IAAA,gCAAsB,GAAE,CAAC;IAC9C,IAAI,IAAI,GAAG,IAAA,2BAAiB,EAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAClD,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC;KACvB;IACD,OAAO;QACL,OAAO,EAAE,IAAI,CAAC,OAAO;QACrB,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK;QACtB,iBAAiB,EAAE,IAAA,kBAAQ,EAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC;QACxD,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU;QACjC,KAAK,EAAE,IAAA,kBAAQ,EAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC;QACpC,IAAI,EAAE,IAAA,kBAAQ,EAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC;QACnC,WAAW,EAAE,IAAA,kBAAQ,EAAC,CAAC,MAAM,IAAA,iBAAO,EAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;KACxE,CAAC;AACJ,CAAC;AAfD,wCAeC;AAEM,KAAK,UAAU,oBAAoB,CAAC,GAAG;IAC5C,OAAO,MAAM,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAC3C,CAAC;AAFD,oDAEC"}
@@ -0,0 +1 @@
1
+ export declare function getXPubKey(seed: Uint8Array | string, derivationPath: string, network: string): Promise<string>;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getXPubKey = void 0;
4
+ const libauth_1 = require("@bitauth/libauth");
5
+ async function getXPubKey(seed, derivationPath, network) {
6
+ if (typeof seed === "string") {
7
+ seed = (0, libauth_1.hexToBin)(seed);
8
+ }
9
+ const crypto = await (0, libauth_1.instantiateBIP32Crypto)();
10
+ let hdNode = (0, libauth_1.deriveHdPrivateNodeFromSeed)(crypto, seed);
11
+ if (!hdNode.valid) {
12
+ throw Error("Invalid private key derived from mnemonic seed");
13
+ }
14
+ let node = (0, libauth_1.deriveHdPath)(crypto, hdNode, derivationPath);
15
+ if (typeof node === "string") {
16
+ throw node;
17
+ }
18
+ let parentPublicNode = (0, libauth_1.deriveHdPublicNode)(crypto, node);
19
+ let xPubKey = (0, libauth_1.encodeHdPublicKey)(crypto, {
20
+ network: network,
21
+ node: parentPublicNode,
22
+ });
23
+ return xPubKey;
24
+ }
25
+ exports.getXPubKey = getXPubKey;
26
+ //# sourceMappingURL=getXPubKey.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getXPubKey.js","sourceRoot":"","sources":["../../../src/util/getXPubKey.ts"],"names":[],"mappings":";;;AAAA,8CAQ0B;AAEnB,KAAK,UAAU,UAAU,CAC9B,IAAyB,EACzB,cAAsB,EACtB,OAAe;IAEf,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,IAAI,GAAG,IAAA,kBAAQ,EAAC,IAAI,CAAC,CAAC;KACvB;IACD,MAAM,MAAM,GAAG,MAAM,IAAA,gCAAsB,GAAE,CAAC;IAC9C,IAAI,MAAM,GAAG,IAAA,qCAA2B,EAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACvD,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;QACjB,MAAM,KAAK,CAAC,gDAAgD,CAAC,CAAC;KAC/D;IAED,IAAI,IAAI,GAAG,IAAA,sBAAY,EAAC,MAAM,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;IACxD,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,MAAM,IAAI,CAAC;KACZ;IACD,IAAI,gBAAgB,GAAG,IAAA,4BAAkB,EAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAExD,IAAI,OAAO,GAAG,IAAA,2BAAiB,EAAC,MAAM,EAAE;QACtC,OAAO,EAAE,OAAuB;QAChC,IAAI,EAAE,gBAAgB;KACvB,CAAC,CAAC;IACH,OAAO,OAAO,CAAC;AACjB,CAAC;AAzBD,gCAyBC"}
@@ -1,16 +1,18 @@
1
1
  export { amountInSatoshi } from "./amountInSatoshi";
2
2
  export { asSendRequestObject } from "./asSendRequestObject";
3
- export { btoa, atob } from "./base64";
3
+ export { atob, btoa } from "./base64";
4
4
  export { convert, convertObject } from "./convert";
5
5
  export { delay } from "./delay";
6
+ export { derivedNetwork } from "./deriveNetwork";
7
+ export { derivePublicKeyHash } from "./derivePublicKeyHash";
8
+ export { getAddrsByXpubKey, getAddrsByXpubKeyObject, getXpubKeyInfo, getXpubKeyInfoObject, } from "../util/getAddrsByXpubKey";
6
9
  export { getRuntimePlatform, RuntimePlatform } from "./getRuntimePlatform";
7
10
  export { getUsdRate } from "./getUsdRate";
8
11
  export { ExchangeRate } from "../rate/ExchangeRate";
9
- export { derivedNetwork } from "./deriveNetwork";
10
- export { derivePublicKeyHash } from "./derivePublicKeyHash";
11
12
  export { sanitizeAddress } from "./sanitizeAddress";
12
13
  export { sanitizeUnit } from "./sanitizeUnit";
13
14
  export { getRandomInt } from "./randomInt";
15
+ export { getXPubKey } from "../util/getXPubKey";
14
16
  import * as randomValues from "./randomValues";
15
17
  export { randomValues };
16
18
  export { sumUtxoValue } from "./sumUtxoValue";
@@ -19,19 +19,28 @@ var __importStar = (this && this.__importStar) || function (mod) {
19
19
  return result;
20
20
  };
21
21
  Object.defineProperty(exports, "__esModule", { value: true });
22
- exports.balanceResponseFromSatoshi = exports.balanceFromSatoshi = exports.BalanceResponse = exports.sumUtxoValue = exports.randomValues = exports.getRandomInt = exports.sanitizeUnit = exports.sanitizeAddress = exports.derivePublicKeyHash = exports.derivedNetwork = exports.ExchangeRate = exports.getUsdRate = exports.RuntimePlatform = exports.getRuntimePlatform = exports.delay = exports.convertObject = exports.convert = exports.atob = exports.btoa = exports.asSendRequestObject = exports.amountInSatoshi = void 0;
22
+ exports.balanceResponseFromSatoshi = exports.balanceFromSatoshi = exports.BalanceResponse = exports.sumUtxoValue = exports.randomValues = exports.getXPubKey = exports.getRandomInt = exports.sanitizeUnit = exports.sanitizeAddress = exports.ExchangeRate = exports.getUsdRate = exports.RuntimePlatform = exports.getRuntimePlatform = exports.getXpubKeyInfoObject = exports.getXpubKeyInfo = exports.getAddrsByXpubKeyObject = exports.getAddrsByXpubKey = exports.derivePublicKeyHash = exports.derivedNetwork = exports.delay = exports.convertObject = exports.convert = exports.btoa = exports.atob = exports.asSendRequestObject = exports.amountInSatoshi = void 0;
23
23
  var amountInSatoshi_1 = require("./amountInSatoshi");
24
24
  Object.defineProperty(exports, "amountInSatoshi", { enumerable: true, get: function () { return amountInSatoshi_1.amountInSatoshi; } });
25
25
  var asSendRequestObject_1 = require("./asSendRequestObject");
26
26
  Object.defineProperty(exports, "asSendRequestObject", { enumerable: true, get: function () { return asSendRequestObject_1.asSendRequestObject; } });
27
27
  var base64_1 = require("./base64");
28
- Object.defineProperty(exports, "btoa", { enumerable: true, get: function () { return base64_1.btoa; } });
29
28
  Object.defineProperty(exports, "atob", { enumerable: true, get: function () { return base64_1.atob; } });
29
+ Object.defineProperty(exports, "btoa", { enumerable: true, get: function () { return base64_1.btoa; } });
30
30
  var convert_1 = require("./convert");
31
31
  Object.defineProperty(exports, "convert", { enumerable: true, get: function () { return convert_1.convert; } });
32
32
  Object.defineProperty(exports, "convertObject", { enumerable: true, get: function () { return convert_1.convertObject; } });
33
33
  var delay_1 = require("./delay");
34
34
  Object.defineProperty(exports, "delay", { enumerable: true, get: function () { return delay_1.delay; } });
35
+ var deriveNetwork_1 = require("./deriveNetwork");
36
+ Object.defineProperty(exports, "derivedNetwork", { enumerable: true, get: function () { return deriveNetwork_1.derivedNetwork; } });
37
+ var derivePublicKeyHash_1 = require("./derivePublicKeyHash");
38
+ Object.defineProperty(exports, "derivePublicKeyHash", { enumerable: true, get: function () { return derivePublicKeyHash_1.derivePublicKeyHash; } });
39
+ var getAddrsByXpubKey_1 = require("../util/getAddrsByXpubKey");
40
+ Object.defineProperty(exports, "getAddrsByXpubKey", { enumerable: true, get: function () { return getAddrsByXpubKey_1.getAddrsByXpubKey; } });
41
+ Object.defineProperty(exports, "getAddrsByXpubKeyObject", { enumerable: true, get: function () { return getAddrsByXpubKey_1.getAddrsByXpubKeyObject; } });
42
+ Object.defineProperty(exports, "getXpubKeyInfo", { enumerable: true, get: function () { return getAddrsByXpubKey_1.getXpubKeyInfo; } });
43
+ Object.defineProperty(exports, "getXpubKeyInfoObject", { enumerable: true, get: function () { return getAddrsByXpubKey_1.getXpubKeyInfoObject; } });
35
44
  var getRuntimePlatform_1 = require("./getRuntimePlatform");
36
45
  Object.defineProperty(exports, "getRuntimePlatform", { enumerable: true, get: function () { return getRuntimePlatform_1.getRuntimePlatform; } });
37
46
  Object.defineProperty(exports, "RuntimePlatform", { enumerable: true, get: function () { return getRuntimePlatform_1.RuntimePlatform; } });
@@ -39,16 +48,14 @@ var getUsdRate_1 = require("./getUsdRate");
39
48
  Object.defineProperty(exports, "getUsdRate", { enumerable: true, get: function () { return getUsdRate_1.getUsdRate; } });
40
49
  var ExchangeRate_1 = require("../rate/ExchangeRate");
41
50
  Object.defineProperty(exports, "ExchangeRate", { enumerable: true, get: function () { return ExchangeRate_1.ExchangeRate; } });
42
- var deriveNetwork_1 = require("./deriveNetwork");
43
- Object.defineProperty(exports, "derivedNetwork", { enumerable: true, get: function () { return deriveNetwork_1.derivedNetwork; } });
44
- var derivePublicKeyHash_1 = require("./derivePublicKeyHash");
45
- Object.defineProperty(exports, "derivePublicKeyHash", { enumerable: true, get: function () { return derivePublicKeyHash_1.derivePublicKeyHash; } });
46
51
  var sanitizeAddress_1 = require("./sanitizeAddress");
47
52
  Object.defineProperty(exports, "sanitizeAddress", { enumerable: true, get: function () { return sanitizeAddress_1.sanitizeAddress; } });
48
53
  var sanitizeUnit_1 = require("./sanitizeUnit");
49
54
  Object.defineProperty(exports, "sanitizeUnit", { enumerable: true, get: function () { return sanitizeUnit_1.sanitizeUnit; } });
50
55
  var randomInt_1 = require("./randomInt");
51
56
  Object.defineProperty(exports, "getRandomInt", { enumerable: true, get: function () { return randomInt_1.getRandomInt; } });
57
+ var getXPubKey_1 = require("../util/getXPubKey");
58
+ Object.defineProperty(exports, "getXPubKey", { enumerable: true, get: function () { return getXPubKey_1.getXPubKey; } });
52
59
  const randomValues = __importStar(require("./randomValues"));
53
60
  exports.randomValues = randomValues;
54
61
  var sumUtxoValue_1 = require("./sumUtxoValue");
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/util/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAoD;AAA3C,kHAAA,eAAe,OAAA;AACxB,6DAA4D;AAAnD,0HAAA,mBAAmB,OAAA;AAC5B,mCAAsC;AAA7B,8FAAA,IAAI,OAAA;AAAE,8FAAA,IAAI,OAAA;AACnB,qCAAmD;AAA1C,kGAAA,OAAO,OAAA;AAAE,wGAAA,aAAa,OAAA;AAC/B,iCAAgC;AAAvB,8FAAA,KAAK,OAAA;AACd,2DAA2E;AAAlE,wHAAA,kBAAkB,OAAA;AAAE,qHAAA,eAAe,OAAA;AAC5C,2CAA0C;AAAjC,wGAAA,UAAU,OAAA;AACnB,qDAAoD;AAA3C,4GAAA,YAAY,OAAA;AACrB,iDAAiD;AAAxC,+GAAA,cAAc,OAAA;AACvB,6DAA4D;AAAnD,0HAAA,mBAAmB,OAAA;AAC5B,qDAAoD;AAA3C,kHAAA,eAAe,OAAA;AACxB,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AACrB,yCAA2C;AAAlC,yGAAA,YAAY,OAAA;AACrB,6DAA+C;AACtC,oCAAY;AACrB,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AACrB,uEAIoC;AAHlC,2HAAA,eAAe,OAAA;AACf,8HAAA,kBAAkB,OAAA;AAClB,sIAAA,0BAA0B,OAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/util/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAoD;AAA3C,kHAAA,eAAe,OAAA;AACxB,6DAA4D;AAAnD,0HAAA,mBAAmB,OAAA;AAC5B,mCAAsC;AAA7B,8FAAA,IAAI,OAAA;AAAE,8FAAA,IAAI,OAAA;AACnB,qCAAmD;AAA1C,kGAAA,OAAO,OAAA;AAAE,wGAAA,aAAa,OAAA;AAC/B,iCAAgC;AAAvB,8FAAA,KAAK,OAAA;AACd,iDAAiD;AAAxC,+GAAA,cAAc,OAAA;AACvB,6DAA4D;AAAnD,0HAAA,mBAAmB,OAAA;AAC5B,+DAKmC;AAJjC,sHAAA,iBAAiB,OAAA;AACjB,4HAAA,uBAAuB,OAAA;AACvB,mHAAA,cAAc,OAAA;AACd,yHAAA,oBAAoB,OAAA;AAEtB,2DAA2E;AAAlE,wHAAA,kBAAkB,OAAA;AAAE,qHAAA,eAAe,OAAA;AAC5C,2CAA0C;AAAjC,wGAAA,UAAU,OAAA;AACnB,qDAAoD;AAA3C,4GAAA,YAAY,OAAA;AACrB,qDAAoD;AAA3C,kHAAA,eAAe,OAAA;AACxB,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AACrB,yCAA2C;AAAlC,yGAAA,YAAY,OAAA;AACrB,iDAAgD;AAAvC,wGAAA,UAAU,OAAA;AACnB,6DAA+C;AACtC,oCAAY;AACrB,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AACrB,uEAIoC;AAHlC,2HAAA,eAAe,OAAA;AACf,8HAAA,kBAAkB,OAAA;AAClB,sIAAA,0BAA0B,OAAA"}
@@ -10,6 +10,8 @@ import { WalletTypeEnum } from "./enum";
10
10
  export declare class BaseWallet implements WalletI {
11
11
  provider?: any;
12
12
  derivationPath: string;
13
+ parentDerivationPath: string;
14
+ parentXPubKey?: string;
13
15
  mnemonic?: string;
14
16
  address?: string;
15
17
  privateKey?: any;
@@ -104,7 +106,7 @@ export declare class BaseWallet implements WalletI {
104
106
  /**
105
107
  * replaceNamed - replace (recover) named wallet with a new walletId
106
108
  *
107
- * If wallet with a provided name does not exist yet, it will be creted with a `walletId` supplied
109
+ * If wallet with a provided name does not exist yet, it will be created with a `walletId` supplied
108
110
  * If wallet exists it will be overwritten without exception
109
111
  *
110
112
  * @param name user friendly wallet alias
@@ -22,6 +22,7 @@ class BaseWallet {
22
22
  */
23
23
  constructor(name = "", network = enum_1.NetworkType.Mainnet, walletType = enum_2.WalletTypeEnum.Seed) {
24
24
  this.derivationPath = "m/44'/0'/0'/0/0";
25
+ this.parentDerivationPath = "m/44'/0'/0'";
25
26
  this.name = name;
26
27
  this.network = network;
27
28
  this.walletType = walletType;
@@ -69,6 +70,7 @@ class BaseWallet {
69
70
  return {
70
71
  seed: this.mnemonic,
71
72
  derivationPath: this.derivationPath,
73
+ parentDerivationPath: this.parentDerivationPath,
72
74
  };
73
75
  }
74
76
  /**
@@ -136,7 +138,7 @@ class BaseWallet {
136
138
  /**
137
139
  * replaceNamed - replace (recover) named wallet with a new walletId
138
140
  *
139
- * If wallet with a provided name does not exist yet, it will be creted with a `walletId` supplied
141
+ * If wallet with a provided name does not exist yet, it will be created with a `walletId` supplied
140
142
  * If wallet exists it will be overwritten without exception
141
143
  *
142
144
  * @param name user friendly wallet alias
@@ -1 +1 @@
1
- {"version":3,"file":"Base.js","sourceRoot":"","sources":["../../../src/wallet/Base.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Base.js","sourceRoot":"","sources":["../../../src/wallet/Base.ts"],"names":[],"mappings":"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"}
@@ -18,6 +18,8 @@ import { SignedMessageI } from "../message";
18
18
  export declare class Wallet extends BaseWallet {
19
19
  cashaddr?: string;
20
20
  derivationPath: string;
21
+ parentDerivationPath: string;
22
+ parentXPubKey?: string;
21
23
  privateKey?: Uint8Array;
22
24
  publicKeyCompressed?: Uint8Array;
23
25
  privateKeyWif?: string;
@@ -82,7 +84,9 @@ export declare class Wallet extends BaseWallet {
82
84
  private _generateWif;
83
85
  private _generateMnemonic;
84
86
  protected fromId: (walletId: string) => Promise<this>;
87
+ getXPubKeys(paths?: any): Promise<any[]>;
85
88
  protected fromSeed(mnemonic: string, derivationPath?: string): Promise<this>;
89
+ deriveHdPaths(hdPaths: string[]): Promise<any[]>;
86
90
  protected watchOnly(address: string): Promise<this>;
87
91
  protected fromWIF(secret: string): Promise<this>;
88
92
  protected newRandom(name: string, dbName?: string): Promise<this>;
@@ -34,6 +34,7 @@ const index_1 = require("../network/index");
34
34
  const randomBytes_1 = require("../util/randomBytes");
35
35
  const message_1 = require("../message");
36
36
  const amountInSatoshi_1 = require("../util/amountInSatoshi");
37
+ const getXPubKey_1 = require("../util/getXPubKey");
37
38
  const constant_1 = require("../constant");
38
39
  //#endregion Imports
39
40
  const secp256k1Promise = (0, libauth_1.instantiateSecp256k1)();
@@ -47,6 +48,7 @@ class Wallet extends Base_1.BaseWallet {
47
48
  constructor(name = "", network = enum_1.NetworkType.Mainnet, walletType = enum_3.WalletTypeEnum.Seed) {
48
49
  super(name, network, walletType);
49
50
  this.derivationPath = "m/44'/0'/0'/0/0";
51
+ this.parentDerivationPath = "m/44'/0'/0'";
50
52
  this._slpAware = false; // a flag which activates utxo checking against an external slp indexer
51
53
  this._slpSemiAware = false; // a flag which requires an utxo to have more than 546 sats to be spendable and counted in the balance
52
54
  this.fromId = async (walletId) => {
@@ -120,6 +122,10 @@ class Wallet extends Base_1.BaseWallet {
120
122
  network: this.network,
121
123
  seed: this.mnemonic ? this.getSeed().seed : undefined,
122
124
  derivationPath: this.mnemonic ? this.getSeed().derivationPath : undefined,
125
+ parentDerivationPath: this.mnemonic
126
+ ? this.getSeed().parentDerivationPath
127
+ : undefined,
128
+ parentXPubKey: this.parentXPubKey ? this.parentXPubKey : undefined,
123
129
  publicKey: this.publicKey ? (0, libauth_2.binToHex)(this.publicKey) : undefined,
124
130
  publicKeyHash: (0, libauth_2.binToHex)(this.publicKeyHash),
125
131
  privateKey: this.privateKey ? (0, libauth_2.binToHex)(this.privateKey) : undefined,
@@ -222,18 +228,37 @@ class Wallet extends Base_1.BaseWallet {
222
228
  return this.deriveInfo();
223
229
  }
224
230
  async _generateMnemonic() {
225
- const crypto = await (0, libauth_2.instantiateBIP32Crypto)();
226
231
  this.mnemonic = (0, bip39_1.generateMnemonic)();
227
232
  let seed = (0, bip39_1.mnemonicToSeedSync)(this.mnemonic);
233
+ let network = this.isTestnet ? "testnet" : "mainnet";
234
+ this.parentXPubKey = await (0, getXPubKey_1.getXPubKey)(seed, this.parentDerivationPath, network);
235
+ const crypto = await (0, libauth_2.instantiateBIP32Crypto)();
228
236
  let hdNode = (0, libauth_2.deriveHdPrivateNodeFromSeed)(crypto, seed);
229
237
  if (!hdNode.valid) {
230
238
  throw Error("Invalid private key derived from mnemonic seed");
231
239
  }
232
240
  let zerothChild = (0, libauth_2.deriveHdPath)(crypto, hdNode, this.derivationPath);
241
+ if (typeof zerothChild === "string") {
242
+ throw Error(zerothChild);
243
+ }
233
244
  this.privateKey = zerothChild.privateKey;
234
245
  this.walletType = enum_3.WalletTypeEnum.Seed;
235
246
  return await this.deriveInfo();
236
247
  }
248
+ async getXPubKeys(paths) {
249
+ if (this.mnemonic) {
250
+ if (paths) {
251
+ let xPubKeys = await this.deriveHdPaths(paths);
252
+ return [xPubKeys];
253
+ }
254
+ else {
255
+ return await this.deriveHdPaths(constant_1.DERIVATION_PATHS);
256
+ }
257
+ }
258
+ else {
259
+ throw Error("xpubkeys can only be derived from seed type wallets.");
260
+ }
261
+ }
237
262
  // Initialize wallet from a mnemonic phrase
238
263
  async fromSeed(mnemonic, derivationPath) {
239
264
  this.mnemonic = mnemonic;
@@ -245,13 +270,58 @@ class Wallet extends Base_1.BaseWallet {
245
270
  }
246
271
  if (derivationPath) {
247
272
  this.derivationPath = derivationPath;
273
+ // If the derivation path is for the first account child, set the parent derivation path
274
+ let path = derivationPath.split("/");
275
+ if (path.slice(-2).join("/") == "0/0") {
276
+ this.parentDerivationPath = path.slice(0, -2).join("/");
277
+ }
248
278
  }
249
279
  let zerothChild = (0, libauth_2.deriveHdPath)(crypto, hdNode, this.derivationPath);
280
+ if (typeof zerothChild === "string") {
281
+ throw Error(zerothChild);
282
+ }
250
283
  this.privateKey = zerothChild.privateKey;
284
+ let network = this.isTestnet ? "testnet" : "mainnet";
285
+ this.parentXPubKey = await (0, getXPubKey_1.getXPubKey)(seed, this.parentDerivationPath, network);
251
286
  this.walletType = enum_3.WalletTypeEnum.Seed;
252
287
  await this.deriveInfo();
253
288
  return this;
254
289
  }
290
+ // Get common xpub paths from zerothChild privateKey
291
+ async deriveHdPaths(hdPaths) {
292
+ const crypto = await (0, libauth_2.instantiateBIP32Crypto)();
293
+ let seed = (0, bip39_1.mnemonicToSeedSync)(this.mnemonic);
294
+ let hdNode = (0, libauth_2.deriveHdPrivateNodeFromSeed)(crypto, seed);
295
+ if (!hdNode.valid) {
296
+ throw Error("Invalid private key derived from mnemonic seed");
297
+ }
298
+ let result = [];
299
+ for (const path of hdPaths) {
300
+ if (path === "m") {
301
+ throw Error("Storing or sharing of parent public key may lead to loss of funds. Storing or sharing *root* parent public keys is strongly discouraged, although all parent keys have risk. See: https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki#implications");
302
+ }
303
+ let childNode = (0, libauth_2.deriveHdPath)(crypto, hdNode, path);
304
+ if (typeof childNode === "string") {
305
+ throw Error(childNode);
306
+ }
307
+ let node = (0, libauth_2.deriveHdPublicNode)(crypto, childNode);
308
+ if (typeof node === "string") {
309
+ throw Error(node);
310
+ }
311
+ let xPubKey = (0, libauth_1.encodeHdPublicKey)(crypto, {
312
+ network: this.network,
313
+ node: node,
314
+ });
315
+ let key = new model_1.XPubKey({
316
+ path: path,
317
+ xPubKey: xPubKey,
318
+ });
319
+ result.push(await key.ready());
320
+ }
321
+ return await Promise.all(result).then((result) => {
322
+ return result;
323
+ });
324
+ }
255
325
  // Initialize a watch only wallet from a cash addr
256
326
  async watchOnly(address) {
257
327
  this.walletType = enum_3.WalletTypeEnum.Watch;
@@ -280,8 +350,7 @@ class Wallet extends Base_1.BaseWallet {
280
350
  (0, checkWifNetwork_1.checkWifNetwork)(secret, this.network);
281
351
  const sha256 = await sha256Promise;
282
352
  let wifResult = (0, libauth_2.decodePrivateKeyWif)(sha256, secret);
283
- const hasError = typeof wifResult === "string";
284
- if (hasError) {
353
+ if (typeof wifResult === "string") {
285
354
  throw Error(wifResult);
286
355
  }
287
356
  let resultData = wifResult;