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.
- package/dist/index.html +1 -1
- package/dist/main/constant.d.ts +1 -0
- package/dist/main/constant.js +17 -1
- package/dist/main/constant.js.map +1 -1
- package/dist/main/util/getAddrsByXpubKey.d.ts +22 -0
- package/dist/main/util/getAddrsByXpubKey.js +79 -0
- package/dist/main/util/getAddrsByXpubKey.js.map +1 -0
- package/dist/main/util/getXPubKey.d.ts +1 -0
- package/dist/main/util/getXPubKey.js +26 -0
- package/dist/main/util/getXPubKey.js.map +1 -0
- package/dist/main/util/index.d.ts +5 -3
- package/dist/main/util/index.js +13 -6
- package/dist/main/util/index.js.map +1 -1
- package/dist/main/wallet/Base.d.ts +3 -1
- package/dist/main/wallet/Base.js +3 -1
- package/dist/main/wallet/Base.js.map +1 -1
- package/dist/main/wallet/Wif.d.ts +4 -0
- package/dist/main/wallet/Wif.js +72 -3
- package/dist/main/wallet/Wif.js.map +1 -1
- package/dist/main/wallet/interface.d.ts +4 -0
- package/dist/main/wallet/model.d.ts +16 -0
- package/dist/main/wallet/model.js +18 -1
- package/dist/main/wallet/model.js.map +1 -1
- package/dist/mainnet-0.4.31.js +2 -0
- package/dist/{mainnet-0.4.30.js.LICENSE.txt → mainnet-0.4.31.js.LICENSE.txt} +0 -0
- package/dist/module/constant.d.ts +1 -0
- package/dist/module/constant.js +16 -0
- package/dist/module/constant.js.map +1 -1
- package/dist/module/util/getAddrsByXpubKey.d.ts +22 -0
- package/dist/module/util/getAddrsByXpubKey.js +71 -0
- package/dist/module/util/getAddrsByXpubKey.js.map +1 -0
- package/dist/module/util/getXPubKey.d.ts +1 -0
- package/dist/module/util/getXPubKey.js +22 -0
- package/dist/module/util/getXPubKey.js.map +1 -0
- package/dist/module/util/index.d.ts +5 -3
- package/dist/module/util/index.js +5 -3
- package/dist/module/util/index.js.map +1 -1
- package/dist/module/wallet/Base.d.ts +3 -1
- package/dist/module/wallet/Base.js +3 -1
- package/dist/module/wallet/Base.js.map +1 -1
- package/dist/module/wallet/Wif.d.ts +4 -0
- package/dist/module/wallet/Wif.js +76 -7
- package/dist/module/wallet/Wif.js.map +1 -1
- package/dist/module/wallet/interface.d.ts +4 -0
- package/dist/module/wallet/model.d.ts +16 -0
- package/dist/module/wallet/model.js +16 -0
- package/dist/module/wallet/model.js.map +1 -1
- package/dist/tsconfig.browser.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/constant.ts +17 -0
- package/src/util/getAddrsByXpubKey.test.ts +115 -0
- package/src/util/getAddrsByXpubKey.ts +98 -0
- package/src/util/getXPubKey.ts +36 -0
- package/src/util/index.ts +10 -3
- package/src/wallet/Base.ts +4 -1
- package/src/wallet/Wif.test.ts +173 -1
- package/src/wallet/Wif.ts +100 -15
- package/src/wallet/createWallet.test.ts +2 -0
- package/src/wallet/interface.ts +4 -0
- package/src/wallet/model.ts +22 -0
- 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.
|
|
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>
|
package/dist/main/constant.d.ts
CHANGED
package/dist/main/constant.js
CHANGED
|
@@ -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":"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"}
|
|
@@ -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 {
|
|
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";
|
package/dist/main/util/index.js
CHANGED
|
@@ -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.
|
|
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,
|
|
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
|
|
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
|
package/dist/main/wallet/Base.js
CHANGED
|
@@ -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
|
|
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":";;;AAAA,qCAAgD;AAEhD,kCAAsC;AAEtC,mEAAgE;AAChE,iCAAqC;AAErC,iCAAwC;AAExC;;;GAGG;AACH,MAAa,UAAU;
|
|
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>;
|
package/dist/main/wallet/Wif.js
CHANGED
|
@@ -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
|
-
|
|
284
|
-
if (hasError) {
|
|
353
|
+
if (typeof wifResult === "string") {
|
|
285
354
|
throw Error(wifResult);
|
|
286
355
|
}
|
|
287
356
|
let resultData = wifResult;
|