@witnet/sdk 1.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +103 -0
- package/dist/package.json +72 -0
- package/dist/src/bin/helpers.d.ts +91 -0
- package/dist/src/bin/helpers.d.ts.map +1 -0
- package/dist/src/bin/helpers.js +816 -0
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +47 -0
- package/dist/src/lib/crypto/account.d.ts +32 -0
- package/dist/src/lib/crypto/account.d.ts.map +1 -0
- package/dist/src/lib/crypto/account.js +106 -0
- package/dist/src/lib/crypto/coinbase.d.ts +10 -0
- package/dist/src/lib/crypto/coinbase.d.ts.map +1 -0
- package/dist/src/lib/crypto/coinbase.js +28 -0
- package/dist/src/lib/crypto/index.d.ts +8 -0
- package/dist/src/lib/crypto/index.d.ts.map +1 -0
- package/dist/src/lib/crypto/index.js +30 -0
- package/dist/src/lib/crypto/interfaces.d.ts +85 -0
- package/dist/src/lib/crypto/interfaces.d.ts.map +1 -0
- package/dist/src/lib/crypto/interfaces.js +3 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts +55 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.js +339 -0
- package/dist/src/lib/crypto/payloads/StakePayload.d.ts +28 -0
- package/dist/src/lib/crypto/payloads/StakePayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/StakePayload.js +142 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts +36 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.js +154 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts +25 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +128 -0
- package/dist/src/lib/crypto/payloads.d.ts +57 -0
- package/dist/src/lib/crypto/payloads.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads.js +170 -0
- package/dist/src/lib/crypto/signer.d.ts +33 -0
- package/dist/src/lib/crypto/signer.d.ts.map +1 -0
- package/dist/src/lib/crypto/signer.js +194 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.d.ts +15 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.js +23 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts +12 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.js +17 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts +18 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +53 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts +11 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.js +16 -0
- package/dist/src/lib/crypto/transmitters.d.ts +47 -0
- package/dist/src/lib/crypto/transmitters.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters.js +416 -0
- package/dist/src/lib/crypto/types.d.ts +161 -0
- package/dist/src/lib/crypto/types.d.ts.map +1 -0
- package/dist/src/lib/crypto/types.js +273 -0
- package/dist/src/lib/crypto/utils.d.ts +21 -0
- package/dist/src/lib/crypto/utils.d.ts.map +1 -0
- package/dist/src/lib/crypto/utils.js +156 -0
- package/dist/src/lib/crypto/wallet.d.ts +120 -0
- package/dist/src/lib/crypto/wallet.d.ts.map +1 -0
- package/dist/src/lib/crypto/wallet.js +258 -0
- package/dist/src/lib/index.d.ts +5 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +44 -0
- package/dist/src/lib/radon/ccdr/eth.d.ts +160 -0
- package/dist/src/lib/radon/ccdr/eth.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/eth.js +272 -0
- package/dist/src/lib/radon/ccdr/index.d.ts +14 -0
- package/dist/src/lib/radon/ccdr/index.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/index.js +39 -0
- package/dist/src/lib/radon/ccdr/wit.d.ts +23 -0
- package/dist/src/lib/radon/ccdr/wit.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/wit.js +35 -0
- package/dist/src/lib/radon/filters.d.ts +14 -0
- package/dist/src/lib/radon/filters.d.ts.map +1 -0
- package/dist/src/lib/radon/filters.js +45 -0
- package/dist/src/lib/radon/index.d.ts +296 -0
- package/dist/src/lib/radon/index.d.ts.map +1 -0
- package/dist/src/lib/radon/index.js +707 -0
- package/dist/src/lib/radon/reducers.d.ts +29 -0
- package/dist/src/lib/radon/reducers.d.ts.map +1 -0
- package/dist/src/lib/radon/reducers.js +66 -0
- package/dist/src/lib/radon/types.d.ts +521 -0
- package/dist/src/lib/radon/types.d.ts.map +1 -0
- package/dist/src/lib/radon/types.js +936 -0
- package/dist/src/lib/radon/utils.d.ts +53 -0
- package/dist/src/lib/radon/utils.d.ts.map +1 -0
- package/dist/src/lib/radon/utils.js +153 -0
- package/dist/src/lib/rpc/index.d.ts +3 -0
- package/dist/src/lib/rpc/index.d.ts.map +1 -0
- package/dist/src/lib/rpc/index.js +19 -0
- package/dist/src/lib/rpc/nodes.d.ts +40 -0
- package/dist/src/lib/rpc/nodes.d.ts.map +1 -0
- package/dist/src/lib/rpc/nodes.js +293 -0
- package/dist/src/lib/rpc/provider.d.ts +88 -0
- package/dist/src/lib/rpc/provider.d.ts.map +1 -0
- package/dist/src/lib/rpc/provider.js +336 -0
- package/dist/src/lib/rpc/reporter.d.ts +18 -0
- package/dist/src/lib/rpc/reporter.d.ts.map +1 -0
- package/dist/src/lib/rpc/reporter.js +30 -0
- package/dist/src/lib/rpc/types.d.ts +409 -0
- package/dist/src/lib/rpc/types.d.ts.map +1 -0
- package/dist/src/lib/rpc/types.js +81 -0
- package/dist/src/lib/types.d.ts +18 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +7 -0
- package/dist/src/lib/utils.d.ts +13 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +97 -0
- package/dist/witnet/assets/index.d.ts +30 -0
- package/dist/witnet/assets/index.d.ts.map +1 -0
- package/dist/witnet/assets/index.js +6 -0
- package/dist/witnet/assets/modals/index.d.ts +18 -0
- package/dist/witnet/assets/modals/index.d.ts.map +1 -0
- package/dist/witnet/assets/modals/index.js +21 -0
- package/dist/witnet/assets/modals/web3/eth.d.ts +5 -0
- package/dist/witnet/assets/modals/web3/eth.d.ts.map +1 -0
- package/dist/witnet/assets/modals/web3/eth.js +26 -0
- package/dist/witnet/assets/modals/web3/wit.d.ts +4 -0
- package/dist/witnet/assets/modals/web3/wit.d.ts.map +1 -0
- package/dist/witnet/assets/modals/web3/wit.js +20 -0
- package/dist/witnet/assets/requests.d.ts +11 -0
- package/dist/witnet/assets/requests.d.ts.map +1 -0
- package/dist/witnet/assets/requests.js +88 -0
- package/dist/witnet/witnet.proto.json +1325 -0
- package/package.json +72 -0
- package/src/bin/cli/history.js +31 -0
- package/src/bin/cli/inspect.js +359 -0
- package/src/bin/cli/network.js +592 -0
- package/src/bin/cli/nodes.js +364 -0
- package/src/bin/cli/radon.js +814 -0
- package/src/bin/cli/wallet.js +1000 -0
- package/src/bin/helpers.js +829 -0
- package/src/bin/postinstall.js +9 -0
- package/src/bin/toolkit.js +294 -0
- package/witnet/assets/_index.js +8 -0
- package/witnet/assets/_requests.js +25 -0
- package/witnet/assets/_sources.js +36 -0
- package/witnet/assets/_templates.js +36 -0
- package/witnet/assets/index.js +4 -0
- package/witnet/assets/modals/index.js +25 -0
- package/witnet/assets/modals/web3/btc.js +0 -0
- package/witnet/assets/modals/web3/eth.js +29 -0
- package/witnet/assets/modals/web3/sol.js +0 -0
- package/witnet/assets/modals/web3/wit.js +23 -0
- package/witnet/assets/requests.js +94 -0
- package/witnet/witnet.proto.json +1325 -0
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.parseXprv = exports.BigMath = exports.Signature = exports.RecoverableSignature = exports.PublicKeyHash = exports.PublicKey = exports.bech32 = void 0;
|
|
4
|
+
exports.decipherXprv = decipherXprv;
|
|
5
|
+
exports.selectUtxos = selectUtxos;
|
|
6
|
+
exports.sha256 = sha256;
|
|
7
|
+
exports.totalCoins = totalCoins;
|
|
8
|
+
const secp256k1 = require("secp256k1");
|
|
9
|
+
const bech32_1 = require("bech32");
|
|
10
|
+
const crypto_1 = require("crypto");
|
|
11
|
+
const types_1 = require("./types");
|
|
12
|
+
var bech32_2 = require("bech32");
|
|
13
|
+
Object.defineProperty(exports, "bech32", { enumerable: true, get: function () { return bech32_2.bech32; } });
|
|
14
|
+
var types_2 = require("./types");
|
|
15
|
+
Object.defineProperty(exports, "PublicKey", { enumerable: true, get: function () { return types_2.PublicKey; } });
|
|
16
|
+
Object.defineProperty(exports, "PublicKeyHash", { enumerable: true, get: function () { return types_2.PublicKeyHash; } });
|
|
17
|
+
Object.defineProperty(exports, "RecoverableSignature", { enumerable: true, get: function () { return types_2.RecoverableSignature; } });
|
|
18
|
+
Object.defineProperty(exports, "Signature", { enumerable: true, get: function () { return types_2.Signature; } });
|
|
19
|
+
exports.BigMath = {
|
|
20
|
+
max(value, ...values) {
|
|
21
|
+
for (const v of values)
|
|
22
|
+
if (v > value)
|
|
23
|
+
value = v;
|
|
24
|
+
return value;
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
const CHAIN_CODE_LENGTH = 32;
|
|
28
|
+
const DEPTH_LENGTH = 1;
|
|
29
|
+
const KEY_LENGTH = 33;
|
|
30
|
+
const KEY_PATH_LENGTH = 4;
|
|
31
|
+
const BECH32_LIMIT = (DEPTH_LENGTH
|
|
32
|
+
+ ((Math.pow(256, DEPTH_LENGTH) - 1) * KEY_PATH_LENGTH)
|
|
33
|
+
+ CHAIN_CODE_LENGTH
|
|
34
|
+
+ KEY_LENGTH);
|
|
35
|
+
const getExpectedDataLength = (depth) => (DEPTH_LENGTH
|
|
36
|
+
+ depth * KEY_PATH_LENGTH
|
|
37
|
+
+ CHAIN_CODE_LENGTH
|
|
38
|
+
+ KEY_LENGTH);
|
|
39
|
+
function decipherXprv(slip32, passwd) {
|
|
40
|
+
const { prefix, words } = bech32_1.bech32.decode(slip32, BECH32_LIMIT);
|
|
41
|
+
if (prefix !== "xprv") {
|
|
42
|
+
throw Error(`Invalid XPRV header: "${prefix}" != "xprv"`);
|
|
43
|
+
}
|
|
44
|
+
const buffer = new Uint8Array(bech32_1.bech32.fromWords(words)).buffer;
|
|
45
|
+
const iv = buffer.slice(0, 16);
|
|
46
|
+
const salt = buffer.slice(16, 48);
|
|
47
|
+
const data = buffer.slice(48);
|
|
48
|
+
const key = (0, crypto_1.pbkdf2Sync)(passwd, Buffer.from(salt), 10000, 32, 'sha256');
|
|
49
|
+
const decipher = (0, crypto_1.createDecipheriv)("aes-256-cbc", key, Buffer.from(iv));
|
|
50
|
+
let decrypted = decipher.update(Buffer.from(data), undefined, 'utf-8');
|
|
51
|
+
decrypted += decipher.final('utf-8');
|
|
52
|
+
return decrypted;
|
|
53
|
+
}
|
|
54
|
+
const parseXprv = (slip32) => {
|
|
55
|
+
// decode slip32 string
|
|
56
|
+
const { prefix, words } = bech32_1.bech32.decode(slip32, BECH32_LIMIT);
|
|
57
|
+
const bytes = bech32_1.bech32.fromWords(words);
|
|
58
|
+
// check prefix
|
|
59
|
+
if (prefix !== "xprv") {
|
|
60
|
+
throw Error(`Invalid XPRV: bad header: "${prefix}" != "xprv"`);
|
|
61
|
+
}
|
|
62
|
+
// check expected data length
|
|
63
|
+
const depth = bytes[0];
|
|
64
|
+
if (depth !== 0) {
|
|
65
|
+
throw Error(`Invalid XPRV: not a master private key (depth: ${depth})`);
|
|
66
|
+
}
|
|
67
|
+
const expectedLength = getExpectedDataLength(depth);
|
|
68
|
+
if (bytes.length !== expectedLength) {
|
|
69
|
+
throw Error("Invalid XPRV: bad data length"
|
|
70
|
+
+ `(expected: ${expectedLength}, was: ${bytes.length}`);
|
|
71
|
+
}
|
|
72
|
+
const buffer = new Uint8Array(bytes).buffer;
|
|
73
|
+
// extract key path (32-bit unsigned integers, big endian)
|
|
74
|
+
const keyPath = [];
|
|
75
|
+
const keyPathView = new DataView(buffer, DEPTH_LENGTH, depth * KEY_PATH_LENGTH);
|
|
76
|
+
for (let i = 0; i < depth; i++) {
|
|
77
|
+
keyPath.push((keyPathView.getUint32(i * KEY_PATH_LENGTH, false)));
|
|
78
|
+
}
|
|
79
|
+
// extract chain code
|
|
80
|
+
const chainCode = new Uint8Array(CHAIN_CODE_LENGTH);
|
|
81
|
+
const chainCodeOffset = DEPTH_LENGTH + depth * KEY_PATH_LENGTH;
|
|
82
|
+
const chainCodeView = new DataView(buffer, chainCodeOffset, CHAIN_CODE_LENGTH);
|
|
83
|
+
for (let i = 0; i < chainCode.length; i++) {
|
|
84
|
+
chainCode[i] = (chainCodeView.getUint8(i));
|
|
85
|
+
}
|
|
86
|
+
// extract key bytes
|
|
87
|
+
const privateKey = new Uint8Array(KEY_LENGTH);
|
|
88
|
+
const privateKeyView = new DataView(buffer, chainCodeOffset + CHAIN_CODE_LENGTH);
|
|
89
|
+
for (let i = 0; i < privateKey.length; i++) {
|
|
90
|
+
privateKey[i] = (privateKeyView.getUint8(i));
|
|
91
|
+
}
|
|
92
|
+
// check if private or public key are valid
|
|
93
|
+
if (privateKey[0] !== 0 || !secp256k1.privateKeyVerify(privateKey.slice(1))) {
|
|
94
|
+
throw Error(`Malformed slip32: not a private key`);
|
|
95
|
+
}
|
|
96
|
+
return {
|
|
97
|
+
chainCode,
|
|
98
|
+
keyPath,
|
|
99
|
+
privateKey: privateKey.slice(1),
|
|
100
|
+
};
|
|
101
|
+
};
|
|
102
|
+
exports.parseXprv = parseXprv;
|
|
103
|
+
function selectUtxos(specs) {
|
|
104
|
+
const strategy = specs.strategy || types_1.UtxoSelectionStrategy.SlimFit;
|
|
105
|
+
switch (strategy) {
|
|
106
|
+
case types_1.UtxoSelectionStrategy.BigFirst:
|
|
107
|
+
case types_1.UtxoSelectionStrategy.SlimFit:
|
|
108
|
+
specs.utxos = specs.utxos.sort((a, b) => (a.value > b.value) ? -1 : ((a.value < b.value) ? 1 : 0));
|
|
109
|
+
break;
|
|
110
|
+
case types_1.UtxoSelectionStrategy.Random:
|
|
111
|
+
const len = specs.utxos.length;
|
|
112
|
+
for (let i = 0; i < len; i++) {
|
|
113
|
+
const index = Math.floor(Math.random() * (len - i));
|
|
114
|
+
const tmp = specs.utxos[index];
|
|
115
|
+
specs.utxos[index] = specs.utxos[len - i - 1];
|
|
116
|
+
specs.utxos[len - i - 1] = tmp;
|
|
117
|
+
}
|
|
118
|
+
break;
|
|
119
|
+
case types_1.UtxoSelectionStrategy.SmallFirst:
|
|
120
|
+
specs.utxos = specs.utxos.sort((a, b) => (a.value < b.value) ? -1 : ((a.value > b.value) ? 1 : 0));
|
|
121
|
+
break;
|
|
122
|
+
}
|
|
123
|
+
// filter locked UTXOs:
|
|
124
|
+
const now = Math.floor(Date.now() / 1000);
|
|
125
|
+
specs.utxos = specs.utxos.filter(utxo => utxo.timelock <= now);
|
|
126
|
+
// if target value is specified, filter spare UTXOs
|
|
127
|
+
const pedros = specs?.value?.pedros;
|
|
128
|
+
if (pedros) {
|
|
129
|
+
if (strategy === types_1.UtxoSelectionStrategy.SlimFit) {
|
|
130
|
+
const slimFitIndex = specs.utxos.findIndex(utxo => utxo.value <= pedros);
|
|
131
|
+
if (slimFitIndex >= 1) {
|
|
132
|
+
return specs.utxos.slice(slimFitIndex - 1, slimFitIndex);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
let covered = 0n;
|
|
136
|
+
return specs.utxos.filter(utxo => {
|
|
137
|
+
const filter = covered <= pedros;
|
|
138
|
+
covered += BigInt(utxo.value);
|
|
139
|
+
return filter;
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
return specs.utxos;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
function sha256(buffer) {
|
|
147
|
+
const hash = (0, crypto_1.createHash)('sha256');
|
|
148
|
+
hash.update(buffer);
|
|
149
|
+
return hash.digest();
|
|
150
|
+
}
|
|
151
|
+
function totalCoins(balance) {
|
|
152
|
+
return types_1.Coins.fromPedros(BigInt(balance.locked)
|
|
153
|
+
+ BigInt(balance.staked)
|
|
154
|
+
+ BigInt(balance.unlocked));
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require(\"secp256k1\")\r\n\r\nimport { bech32 } from 'bech32'\r\nimport { createDecipheriv, createHash, pbkdf2Sync } from 'crypto'\r\nimport { Balance } from '../types'\r\nimport { Coins, Utxo, UtxoSelectionStrategy } from './types'\r\n\r\nexport { bech32 } from 'bech32'\r\n\r\nexport { PrivateKey, PublicKey, PublicKeyHash, KeyedSignature, RecoverableSignature, Signature } from \"./types\"\r\n\r\nexport const BigMath = {\r\n    max(value: bigint, ...values: bigint[]): bigint {\r\n        for (const v of values)\r\n            if (v > value) value = v\r\n                return value\r\n    },\r\n}\r\n\r\nconst CHAIN_CODE_LENGTH = 32\r\nconst DEPTH_LENGTH = 1\r\nconst KEY_LENGTH = 33\r\nconst KEY_PATH_LENGTH = 4\r\n\r\nconst BECH32_LIMIT = (\r\n    DEPTH_LENGTH \r\n        + ((Math.pow(256, DEPTH_LENGTH) - 1) * KEY_PATH_LENGTH) \r\n        + CHAIN_CODE_LENGTH \r\n        + KEY_LENGTH\r\n);\r\n\r\nconst getExpectedDataLength = (depth: number) => (\r\n    DEPTH_LENGTH\r\n        + depth * KEY_PATH_LENGTH\r\n        + CHAIN_CODE_LENGTH\r\n        + KEY_LENGTH\r\n);\r\n\r\nexport function decipherXprv(slip32: string, passwd: string): string {\r\n    const { prefix, words } = bech32.decode(slip32, BECH32_LIMIT)\r\n    if (prefix !== \"xprv\") {\r\n        throw Error(`Invalid XPRV header: \"${prefix}\" != \"xprv\"`)\r\n    }\r\n    const buffer = new Uint8Array(bech32.fromWords(words)).buffer\r\n    const iv = buffer.slice(0, 16)\r\n    const salt = buffer.slice(16, 48)\r\n    const data = buffer.slice(48)\r\n    const key = pbkdf2Sync(passwd, Buffer.from(salt), 10000, 32, 'sha256')    \r\n    const decipher = createDecipheriv(\"aes-256-cbc\", key, Buffer.from(iv))\r\n    let decrypted = decipher.update(Buffer.from(data), undefined, 'utf-8')\r\n    decrypted += decipher.final('utf-8')\r\n    return decrypted\r\n}\r\n\r\nexport const parseXprv = (slip32: string): {\r\n    chainCode: Uint8Array,\r\n    keyPath: Array<number>,\r\n    privateKey: Uint8Array,\r\n} => {\r\n    // decode slip32 string\r\n    const { prefix, words } = bech32.decode(slip32, BECH32_LIMIT)\r\n    const bytes = bech32.fromWords(words)\r\n\r\n    // check prefix\r\n    if (prefix !== \"xprv\") {\r\n        throw Error(`Invalid XPRV: bad header: \"${prefix}\" != \"xprv\"`)\r\n    }\r\n\r\n    // check expected data length\r\n    const depth = bytes[0]\r\n    if (depth !== 0) {\r\n        throw Error(`Invalid XPRV: not a master private key (depth: ${depth})`)\r\n    }\r\n    const expectedLength = getExpectedDataLength(depth)\r\n    if (bytes.length !== expectedLength) {\r\n        throw Error(\r\n            \"Invalid XPRV: bad data length\"\r\n                + `(expected: ${expectedLength}, was: ${bytes.length}`\r\n        )\r\n    }\r\n    const buffer = new Uint8Array(bytes).buffer\r\n\r\n    // extract key path (32-bit unsigned integers, big endian)\r\n    const keyPath: Array<number> = []\r\n    const keyPathView = new DataView(buffer, DEPTH_LENGTH, depth * KEY_PATH_LENGTH)\r\n    for (let i = 0; i < depth; i++) {\r\n        keyPath.push((keyPathView.getUint32(i * KEY_PATH_LENGTH, false)))\r\n    }\r\n\r\n    // extract chain code\r\n    const chainCode: Uint8Array = new Uint8Array(CHAIN_CODE_LENGTH)\r\n    const chainCodeOffset = DEPTH_LENGTH + depth * KEY_PATH_LENGTH\r\n    const chainCodeView = new DataView(buffer, chainCodeOffset, CHAIN_CODE_LENGTH)\r\n    for (let i = 0; i < chainCode.length; i++) {\r\n        chainCode[i] = (chainCodeView.getUint8(i))\r\n    }\r\n\r\n    // extract key bytes\r\n    const privateKey: Uint8Array = new Uint8Array(KEY_LENGTH)\r\n    const privateKeyView = new DataView(buffer, chainCodeOffset + CHAIN_CODE_LENGTH)\r\n    for (let i = 0; i < privateKey.length; i++) {\r\n        privateKey[i] = (privateKeyView.getUint8(i))\r\n    }\r\n\r\n    // check if private or public key are valid\r\n    if (privateKey[0] !== 0 || !secp256k1.privateKeyVerify(privateKey.slice(1))) {\r\n        throw Error(`Malformed slip32: not a private key`)\r\n    } \r\n\r\n    return {\r\n        chainCode,\r\n        keyPath,\r\n        privateKey: privateKey.slice(1),\r\n    }\r\n};\r\n\r\nexport function selectUtxos(specs: { \r\n    utxos: Array<Utxo>, \r\n    value?: Coins, \r\n    strategy?: UtxoSelectionStrategy, \r\n}): Array<Utxo> {\r\n    const strategy = specs.strategy || UtxoSelectionStrategy.SlimFit\r\n    switch (strategy) {\r\n        case UtxoSelectionStrategy.BigFirst:\r\n        case UtxoSelectionStrategy.SlimFit:\r\n            specs.utxos = specs.utxos.sort((a, b) => (a.value > b.value) ? -1 : ((a.value < b.value) ? 1 : 0))\r\n            break\r\n\r\n        case UtxoSelectionStrategy.Random:\r\n            const len = specs.utxos.length\r\n            for (let i = 0; i < len; i ++) {\r\n                const index = Math.floor(Math.random() * (len - i))\r\n                const tmp = specs.utxos[index]\r\n                specs.utxos[index] = specs.utxos[len - i - 1]\r\n                specs.utxos[len - i - 1] = tmp\r\n            }\r\n            break\r\n\r\n        case UtxoSelectionStrategy.SmallFirst:\r\n            specs.utxos = specs.utxos.sort((a, b) => (a.value < b.value) ? -1 : ((a.value > b.value) ? 1 : 0))\r\n            break\r\n    }\r\n    \r\n    // filter locked UTXOs:\r\n    const now = Math.floor(Date.now() / 1000)\r\n    specs.utxos = specs.utxos.filter(utxo => utxo.timelock <= now)\r\n\r\n    // if target value is specified, filter spare UTXOs\r\n    const pedros = specs?.value?.pedros\r\n    if (pedros) {\r\n        if (strategy === UtxoSelectionStrategy.SlimFit) {\r\n            const slimFitIndex = specs.utxos.findIndex(utxo => utxo.value <= pedros)\r\n            if (slimFitIndex >= 1) {\r\n                return specs.utxos.slice(slimFitIndex - 1, slimFitIndex)\r\n            }\r\n        }\r\n        let covered: bigint = 0n \r\n        return specs.utxos.filter(utxo => {\r\n            const filter = covered <= pedros\r\n            covered += BigInt(utxo.value)\r\n            return filter\r\n        })\r\n    } else {\r\n        return specs.utxos\r\n    }\r\n}\r\n\r\nexport function sha256(buffer: any) {\r\n    const hash = createHash('sha256')\r\n    hash.update(buffer)\r\n    return hash.digest()\r\n}\r\n\r\nexport function totalCoins(balance: Balance): Coins {\r\n    return Coins.fromPedros(\r\n        BigInt(balance.locked)\r\n            + BigInt(balance.staked)\r\n            + BigInt(balance.unlocked)\r\n    )\r\n}"]}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { Balance, Network, QueryStakesOrder, StakeEntry } from "../types";
|
|
2
|
+
import { IAccount, IBIP32, ICoinbase, IJsonRpcProvider, ISigner, IWallet } from "./interfaces";
|
|
3
|
+
import { Coins, PublicKey, PublicKeyHashString, Utxo, UtxoCacheInfo, UtxoSelectionStrategy } from "./types";
|
|
4
|
+
export declare class Wallet implements IWallet {
|
|
5
|
+
protected root: IBIP32;
|
|
6
|
+
protected _accounts: Array<IAccount>;
|
|
7
|
+
readonly coinbase: ICoinbase;
|
|
8
|
+
readonly provider: IJsonRpcProvider;
|
|
9
|
+
strategy: UtxoSelectionStrategy;
|
|
10
|
+
/**
|
|
11
|
+
* Create a Wallet by reading the XPRV master key from the WITNET_SDK_WALLET_MASTER_KEY environment variable.
|
|
12
|
+
* @param specs Wallet creation parameters.
|
|
13
|
+
*/
|
|
14
|
+
static fromEnv(options: {
|
|
15
|
+
/**
|
|
16
|
+
* Password to decrypt the XPRV master key read from environment, in case it's encrypted.
|
|
17
|
+
*/
|
|
18
|
+
passwd?: string;
|
|
19
|
+
/**
|
|
20
|
+
* Number of consecutive accounts with no funds before stopping derivation of new Wallet accounts.
|
|
21
|
+
*/
|
|
22
|
+
gap?: number;
|
|
23
|
+
/**
|
|
24
|
+
* Maximum number of accounts to derive.
|
|
25
|
+
*/
|
|
26
|
+
limit?: number;
|
|
27
|
+
/**
|
|
28
|
+
* Specific Wit/RPC provider to use for interacting with the Witnet network.
|
|
29
|
+
*/
|
|
30
|
+
provider?: IJsonRpcProvider;
|
|
31
|
+
/**
|
|
32
|
+
* UTXO selection strategy when building transactions out of this wallet (default: UtxoSelectionStrategy.SmallFirst).
|
|
33
|
+
*/
|
|
34
|
+
strategy?: UtxoSelectionStrategy;
|
|
35
|
+
/**
|
|
36
|
+
* Only derive accounts that hold some unlocked balance of $WIT.
|
|
37
|
+
*/
|
|
38
|
+
onlyWithFunds?: boolean;
|
|
39
|
+
}): Promise<Wallet>;
|
|
40
|
+
/**
|
|
41
|
+
* Create a Wallet by using passed XPRV master key.
|
|
42
|
+
* @param xprv Decrypted XPRV master key string.
|
|
43
|
+
* @param options Wallet creation parameters.
|
|
44
|
+
*/
|
|
45
|
+
static fromXprv(xprv: string, options?: {
|
|
46
|
+
/**
|
|
47
|
+
* Number of consecutive accounts with no funds before stopping derivation of new Wallet accounts.
|
|
48
|
+
*/
|
|
49
|
+
gap?: number;
|
|
50
|
+
/**
|
|
51
|
+
* Maximum number of accounts to derive.
|
|
52
|
+
*/
|
|
53
|
+
limit?: number;
|
|
54
|
+
/**
|
|
55
|
+
* Specific Wit/RPC provider to use for interacting with the Witnet network.
|
|
56
|
+
*/
|
|
57
|
+
provider?: IJsonRpcProvider;
|
|
58
|
+
/**
|
|
59
|
+
* UTXO selection strategy when building transactions out of this wallet (default: UtxoSelectionStrategy.SmallFirst).
|
|
60
|
+
*/
|
|
61
|
+
strategy?: UtxoSelectionStrategy;
|
|
62
|
+
/**
|
|
63
|
+
* Only derive accounts holding some $WIT funds (either locked, staked or unlocked).
|
|
64
|
+
*/
|
|
65
|
+
onlyWithFunds?: boolean;
|
|
66
|
+
}): Promise<Wallet>;
|
|
67
|
+
/**
|
|
68
|
+
* Create a Wallet by using passed XPRV master key.
|
|
69
|
+
* @param xprv Encrypted XPRV master key string.
|
|
70
|
+
* @param passwd Password to decipher the XPRV master key.
|
|
71
|
+
* @param options Wallet creation parameters.
|
|
72
|
+
*/
|
|
73
|
+
static fromEncryptedXprv(xprv: string, passwd: string, options?: {
|
|
74
|
+
/**
|
|
75
|
+
* Number of consecutive accounts with no funds before stopping derivation of new Wallet accounts.
|
|
76
|
+
*/
|
|
77
|
+
gap?: number;
|
|
78
|
+
/**
|
|
79
|
+
* Maximum number of accounts to derive.
|
|
80
|
+
*/
|
|
81
|
+
limit?: number;
|
|
82
|
+
/**
|
|
83
|
+
* Specific Wit/RPC provider to use for interacting with the Witnet network.
|
|
84
|
+
*/
|
|
85
|
+
provider?: IJsonRpcProvider;
|
|
86
|
+
/**
|
|
87
|
+
* UTXO selection strategy when building transactions out of this wallet (default: UtxoSelectionStrategy.SmallFirst).
|
|
88
|
+
*/
|
|
89
|
+
strategy?: UtxoSelectionStrategy;
|
|
90
|
+
/**
|
|
91
|
+
* Only derive accounts holding some $WIT funds (either locked, staked or unlocked).
|
|
92
|
+
*/
|
|
93
|
+
onlyWithFunds?: boolean;
|
|
94
|
+
}): Promise<Wallet>;
|
|
95
|
+
constructor(root: IBIP32, provider: IJsonRpcProvider, strategy?: UtxoSelectionStrategy);
|
|
96
|
+
get accounts(): Array<IAccount>;
|
|
97
|
+
get cacheInfo(): UtxoCacheInfo;
|
|
98
|
+
get changePkh(): PublicKeyHashString;
|
|
99
|
+
get network(): Network | undefined;
|
|
100
|
+
get pkh(): PublicKeyHashString;
|
|
101
|
+
get publicKey(): PublicKey;
|
|
102
|
+
addUtxos(...utxos: Array<Utxo>): {
|
|
103
|
+
excluded: Array<Utxo>;
|
|
104
|
+
included: Array<Utxo>;
|
|
105
|
+
};
|
|
106
|
+
consumeUtxos(...utxos: Array<Utxo>): Array<Utxo>;
|
|
107
|
+
getBalance(): Promise<Balance>;
|
|
108
|
+
getDelegatees(order?: QueryStakesOrder, leftJoin?: boolean): Promise<Array<StakeEntry>>;
|
|
109
|
+
getUtxos(reload?: boolean): Promise<Array<Utxo>>;
|
|
110
|
+
selectUtxos(specs?: {
|
|
111
|
+
value?: Coins;
|
|
112
|
+
reload?: boolean;
|
|
113
|
+
strategy?: UtxoSelectionStrategy;
|
|
114
|
+
}): Promise<Array<Utxo>>;
|
|
115
|
+
deriveAccounts(limit: number): Array<IAccount>;
|
|
116
|
+
exploreAccounts(limit?: number, gap?: number): Promise<Array<IAccount>>;
|
|
117
|
+
getAccount(pkh: PublicKeyHashString, gap?: number): IAccount | undefined;
|
|
118
|
+
getSigner(pkh?: PublicKeyHashString, gap?: number): ISigner | undefined;
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=wallet.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/wallet.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAiB,MAAM,UAAU,CAAA;AAGxF,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,gBAAgB,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAC9F,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,mBAAmB,EAAE,IAAI,EAAE,aAAa,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAI3G,qBAAa,MAAO,YAAW,OAAO;IAClC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC;IAEvB,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAM;IAE1C,SAAgB,QAAQ,EAAE,SAAS,CAAC;IACpC,SAAgB,QAAQ,EAAE,gBAAgB,CAAC;IACpC,QAAQ,EAAE,qBAAqB,CAAC;IAEvC;;;OAGG;WACU,OAAO,CAAC,OAAO,EAAE;QAC1B;;WAEG;QACH,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB;;WAEG;QACH,GAAG,CAAC,EAAE,MAAM,CAAC;QACb;;WAEG;QACH,KAAK,CAAC,EAAE,MAAM,CAAC;QACf;;WAEG;QACH,QAAQ,CAAC,EAAE,gBAAgB,CAAC;QAC5B;;WAEG;QACH,QAAQ,CAAC,EAAE,qBAAqB,CAAC;QACjC;;WAEG;QACH,aAAa,CAAC,EAAE,OAAO,CAAC;KAC3B,GAAG,OAAO,CAAC,MAAM,CAAC;IAWnB;;;;OAIG;WACU,QAAQ,CACjB,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;QACN;;WAEG;QACH,GAAG,CAAC,EAAE,MAAM,CAAC;QACb;;WAEG;QACH,KAAK,CAAC,EAAE,MAAM,CAAC;QACf;;WAEG;QACH,QAAQ,CAAC,EAAE,gBAAgB,CAAC;QAC5B;;WAEG;QACH,QAAQ,CAAC,EAAE,qBAAqB,CAAC;QACjC;;WAEG;QACH,aAAa,CAAC,EAAE,OAAO,CAAC;KAC3B,GACF,OAAO,CAAC,MAAM,CAAC;IAgBlB;;;;;OAKG;WACU,iBAAiB,CAC1B,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE;QACN;;WAEG;QACH,GAAG,CAAC,EAAE,MAAM,CAAC;QACb;;WAEG;QACH,KAAK,CAAC,EAAE,MAAM,CAAC;QACf;;WAEG;QACH,QAAQ,CAAC,EAAE,gBAAgB,CAAC;QAC5B;;WAEG;QACH,QAAQ,CAAC,EAAE,qBAAqB,CAAC;QACjC;;WAEG;QACH,aAAa,CAAC,EAAE,OAAO,CAAC;KAC3B,GACF,OAAO,CAAC,MAAM,CAAC;gBAIN,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,CAAC,EAAE,qBAAqB;IAQtF,IAAW,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,CAErC;IAED,IAAW,SAAS,IAAI,aAAa,CAYpC;IAED,IAAW,SAAS,IAAI,mBAAmB,CAE1C;IAED,IAAW,OAAO,IAAI,OAAO,GAAG,SAAS,CAExC;IAED,IAAW,GAAG,IAAI,mBAAmB,CAEpC;IAED,IAAW,SAAS,IAAI,SAAS,CAEhC;IAEM,QAAQ,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG;QAAE,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;KAAE;IAajF,YAAY,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC;IAO1C,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC;IAuB9B,aAAa,CAAC,KAAK,CAAC,EAAE,gBAAgB,EAAE,QAAQ,UAAO,GAAG,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAkBpF,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAShD,WAAW,CAAC,KAAK,CAAC,EAAE;QAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;QACd,MAAM,CAAC,EAAE,OAAO,CAAA;QAChB,QAAQ,CAAC,EAAE,qBAAqB,CAAA;KACnC,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IASjB,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC;IAgBxC,eAAe,CAAC,KAAK,SAAI,EAAE,GAAG,SAAc,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAe7E,UAAU,CAAC,GAAG,EAAE,mBAAmB,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,SAAS;IAgBxE,SAAS,CAAC,GAAG,CAAC,EAAE,mBAAmB,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;CAKjF"}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.Wallet = void 0;
|
|
40
|
+
const utils = __importStar(require("./utils"));
|
|
41
|
+
const bip32_1 = __importDefault(require("bip32"));
|
|
42
|
+
const ecc = __importStar(require("tiny-secp256k1"));
|
|
43
|
+
const bip32 = (0, bip32_1.default)(ecc);
|
|
44
|
+
const rpc_1 = require("../rpc");
|
|
45
|
+
const types_1 = require("../types");
|
|
46
|
+
const account_1 = require("./account");
|
|
47
|
+
const coinbase_1 = require("./coinbase");
|
|
48
|
+
const types_2 = require("./types");
|
|
49
|
+
const DEFAULT_GAP = 20;
|
|
50
|
+
class Wallet {
|
|
51
|
+
/**
|
|
52
|
+
* Create a Wallet by reading the XPRV master key from the WITNET_SDK_WALLET_MASTER_KEY environment variable.
|
|
53
|
+
* @param specs Wallet creation parameters.
|
|
54
|
+
*/
|
|
55
|
+
static async fromEnv(options) {
|
|
56
|
+
const xprv = process.env.WITNET_SDK_WALLET_MASTER_KEY;
|
|
57
|
+
if (!xprv)
|
|
58
|
+
throw Error(`WITNET_SDK_WALLET_MASTER_KEY must be set on environment.`);
|
|
59
|
+
if (xprv.length > 117) {
|
|
60
|
+
if (!options.passwd)
|
|
61
|
+
throw Error(`Missing password for WITNET_SDK_WALLET_MASTER_KEY.`);
|
|
62
|
+
return Wallet.fromEncryptedXprv(xprv, options?.passwd, options);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
return Wallet.fromXprv(xprv, options);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Create a Wallet by using passed XPRV master key.
|
|
70
|
+
* @param xprv Decrypted XPRV master key string.
|
|
71
|
+
* @param options Wallet creation parameters.
|
|
72
|
+
*/
|
|
73
|
+
static async fromXprv(xprv, options) {
|
|
74
|
+
const { chainCode, privateKey } = utils.parseXprv(xprv);
|
|
75
|
+
const root = bip32.fromPrivateKey(Buffer.from(privateKey), Buffer.from(chainCode));
|
|
76
|
+
const provider = options?.provider || (await rpc_1.JsonRpcProvider.fromEnv());
|
|
77
|
+
await provider.constants();
|
|
78
|
+
const wallet = new Wallet(root, provider, options?.strategy);
|
|
79
|
+
if (options?.onlyWithFunds) {
|
|
80
|
+
await wallet.exploreAccounts(options?.limit || 0, options?.gap);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
wallet.deriveAccounts(options?.limit || 1);
|
|
84
|
+
}
|
|
85
|
+
// load up utxos cache
|
|
86
|
+
await wallet.getUtxos(true);
|
|
87
|
+
return wallet;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Create a Wallet by using passed XPRV master key.
|
|
91
|
+
* @param xprv Encrypted XPRV master key string.
|
|
92
|
+
* @param passwd Password to decipher the XPRV master key.
|
|
93
|
+
* @param options Wallet creation parameters.
|
|
94
|
+
*/
|
|
95
|
+
static async fromEncryptedXprv(xprv, passwd, options) {
|
|
96
|
+
return Wallet.fromXprv(utils.decipherXprv(xprv, passwd), options);
|
|
97
|
+
}
|
|
98
|
+
constructor(root, provider, strategy) {
|
|
99
|
+
this._accounts = [];
|
|
100
|
+
this.provider = provider;
|
|
101
|
+
this.coinbase = new coinbase_1.Coinbase(root, provider, strategy);
|
|
102
|
+
this.root = root;
|
|
103
|
+
this.strategy = strategy || types_2.UtxoSelectionStrategy.SmallFirst;
|
|
104
|
+
this.deriveAccounts(1);
|
|
105
|
+
}
|
|
106
|
+
get accounts() {
|
|
107
|
+
return this._accounts;
|
|
108
|
+
}
|
|
109
|
+
get cacheInfo() {
|
|
110
|
+
const info = { expendable: 0n, size: 0, timelock: Number.MAX_SAFE_INTEGER };
|
|
111
|
+
this.accounts?.forEach(account => {
|
|
112
|
+
const accountInfo = account.cacheInfo;
|
|
113
|
+
info.expendable += accountInfo.expendable;
|
|
114
|
+
info.size += accountInfo.size;
|
|
115
|
+
if (accountInfo.timelock !== 0 && accountInfo.timelock < info.timelock) {
|
|
116
|
+
info.timelock = accountInfo.timelock;
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
if (info.timelock === Number.MAX_SAFE_INTEGER)
|
|
120
|
+
info.timelock = 0;
|
|
121
|
+
return info;
|
|
122
|
+
}
|
|
123
|
+
get changePkh() {
|
|
124
|
+
return this.accounts.length > 0 ? this.accounts[0].changePkh : this.coinbase.pkh;
|
|
125
|
+
}
|
|
126
|
+
get network() {
|
|
127
|
+
return this.provider.network;
|
|
128
|
+
}
|
|
129
|
+
get pkh() {
|
|
130
|
+
return this.accounts.length > 0 ? this.accounts[0].pkh : this.coinbase.pkh;
|
|
131
|
+
}
|
|
132
|
+
get publicKey() {
|
|
133
|
+
return this.accounts.length > 0 ? this.accounts[0].publicKey : this.coinbase.publicKey;
|
|
134
|
+
}
|
|
135
|
+
addUtxos(...utxos) {
|
|
136
|
+
const included = [];
|
|
137
|
+
this.accounts.forEach(account => {
|
|
138
|
+
const _utxos = account.addUtxos(...utxos);
|
|
139
|
+
utxos = _utxos.excluded;
|
|
140
|
+
included.push(..._utxos.included);
|
|
141
|
+
});
|
|
142
|
+
return {
|
|
143
|
+
excluded: utxos,
|
|
144
|
+
included
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
consumeUtxos(...utxos) {
|
|
148
|
+
this.accounts.forEach(account => {
|
|
149
|
+
utxos = account.consumeUtxos(...utxos);
|
|
150
|
+
});
|
|
151
|
+
return utxos;
|
|
152
|
+
}
|
|
153
|
+
async getBalance() {
|
|
154
|
+
if (this._accounts.length > 0) {
|
|
155
|
+
return Promise
|
|
156
|
+
.all(this._accounts.map(async (acc) => {
|
|
157
|
+
const balance = await acc.getBalance();
|
|
158
|
+
// console.log(acc.index, acc.pkh, balance.unlocked);
|
|
159
|
+
return balance;
|
|
160
|
+
}))
|
|
161
|
+
.then((balances) => {
|
|
162
|
+
return balances.reduce((prev, curr) => {
|
|
163
|
+
// console.log("\nprev =>", prev.unlocked)
|
|
164
|
+
// console.log("curr =>", curr.unlocked)
|
|
165
|
+
return {
|
|
166
|
+
locked: prev.locked + curr.locked,
|
|
167
|
+
staked: prev.staked + curr.staked,
|
|
168
|
+
unlocked: prev.unlocked + curr.unlocked,
|
|
169
|
+
};
|
|
170
|
+
}, { locked: 0n, staked: 0n, unlocked: 0n });
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
return this.coinbase.getBalance();
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
async getDelegatees(order, leftJoin = true) {
|
|
178
|
+
const records = [];
|
|
179
|
+
records.push(...await this.coinbase.getDelegatees(order));
|
|
180
|
+
await Promise.all(this._accounts.map(account => account.getDelegatees(order, leftJoin).then(entries => records.push(...entries))));
|
|
181
|
+
if (order) {
|
|
182
|
+
const reverse = order?.reverse ? (+1) : (-1);
|
|
183
|
+
return records.sort((a, b) => {
|
|
184
|
+
switch (order.by) {
|
|
185
|
+
case types_1.StakesOrderBy.Coins: return ((a.value.coins < b.value.coins) ? 1 : ((a.value.coins > b.value.coins) ? -1 : 0)) * reverse;
|
|
186
|
+
case types_1.StakesOrderBy.Mining: return (b.value.epochs.mining - a.value.epochs.mining) * reverse;
|
|
187
|
+
case types_1.StakesOrderBy.Witnessing: return (b.value.epochs.witnessing - a.value.epochs.witnessing) * reverse;
|
|
188
|
+
case types_1.StakesOrderBy.Nonce: return (b.value.nonce - a.value.nonce) * reverse;
|
|
189
|
+
}
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
return records;
|
|
193
|
+
}
|
|
194
|
+
async getUtxos(reload) {
|
|
195
|
+
return Promise
|
|
196
|
+
.all(this.accounts.map(account => account.getUtxos(reload)))
|
|
197
|
+
.then(async (utxoss) => {
|
|
198
|
+
// utxoss.push(await this.coinbase.getUtxos(reload))
|
|
199
|
+
return utxoss.flat();
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
async selectUtxos(specs) {
|
|
203
|
+
return this
|
|
204
|
+
.getUtxos(specs?.reload)
|
|
205
|
+
.then(utxos => utils.selectUtxos({ utxos, value: specs?.value, strategy: specs?.strategy || this.strategy }));
|
|
206
|
+
}
|
|
207
|
+
// ================================================================================================================
|
|
208
|
+
// --- IWallet ----------------------------------------------------------------------------------------------------
|
|
209
|
+
deriveAccounts(limit) {
|
|
210
|
+
if (limit > this._accounts.length) {
|
|
211
|
+
const startIndex = this._accounts.length > 0 ? this.accounts[this.accounts.length - 1].index + 1 : 0;
|
|
212
|
+
limit = limit - this._accounts.length;
|
|
213
|
+
for (let ix = 0; ix < limit; ix++) {
|
|
214
|
+
this._accounts.push(new account_1.Account(this.root, this.provider, startIndex + ix, this.strategy));
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
return this._accounts;
|
|
218
|
+
}
|
|
219
|
+
async exploreAccounts(limit = 0, gap = DEFAULT_GAP) {
|
|
220
|
+
if (limit === 0 || limit > this.accounts.length) {
|
|
221
|
+
const lastIndex = (x) => x.length > 0 ? x[x.length - 1].index + 1 : 0;
|
|
222
|
+
const startIndex = lastIndex(this.accounts);
|
|
223
|
+
for (let index = startIndex; index < lastIndex(this.accounts) + gap; index++) {
|
|
224
|
+
const account = new account_1.Account(this.root, this.provider, index, this.strategy);
|
|
225
|
+
if (utils.totalCoins(await account.getBalance()).pedros > 0n) {
|
|
226
|
+
this.accounts.push(account);
|
|
227
|
+
if (limit && this.accounts.length >= limit)
|
|
228
|
+
break;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
return this._accounts;
|
|
233
|
+
}
|
|
234
|
+
getAccount(pkh, gap) {
|
|
235
|
+
let account = this._accounts.find(account => account.internal.pkh === pkh || account.pkh === pkh);
|
|
236
|
+
if (!account) {
|
|
237
|
+
for (let index = 0; index < (gap || DEFAULT_GAP); index++) {
|
|
238
|
+
account = new account_1.Account(this.root, this.provider, index, this.strategy);
|
|
239
|
+
if (account.pkh === pkh || account.internal.pkh === pkh) {
|
|
240
|
+
this._accounts.push(account);
|
|
241
|
+
return account;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
return undefined;
|
|
245
|
+
}
|
|
246
|
+
else {
|
|
247
|
+
return account;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
getSigner(pkh, gap) {
|
|
251
|
+
if (!pkh)
|
|
252
|
+
return this.accounts[0]?.getSigner() || this.coinbase.getSigner(pkh);
|
|
253
|
+
const account = this.getAccount(pkh, gap);
|
|
254
|
+
return account?.getSigner(pkh) || this.coinbase.getSigner(pkh);
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
exports.Wallet = Wallet;
|
|
258
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../../../src/lib/crypto/wallet.ts"],"names":[],"mappings":"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","sourcesContent":["import * as utils from \"./utils\"\r\n\r\nimport BIP32Factory from 'bip32';\r\nimport * as ecc from 'tiny-secp256k1';\r\nconst bip32 = BIP32Factory(ecc);\r\n\r\nimport { JsonRpcProvider } from \"../rpc\"\r\nimport { Balance, Network, QueryStakesOrder, StakeEntry, StakesOrderBy } from \"../types\"\r\nimport { Account } from \"./account\"\r\nimport { Coinbase } from \"./coinbase\"\r\nimport { IAccount, IBIP32, ICoinbase, IJsonRpcProvider, ISigner, IWallet } from \"./interfaces\"\r\nimport { Coins, PublicKey, PublicKeyHashString, Utxo, UtxoCacheInfo, UtxoSelectionStrategy } from \"./types\"\r\n\r\nconst DEFAULT_GAP = 20;\r\n\r\nexport class Wallet implements IWallet {\r\n    protected root: IBIP32;\r\n    \r\n    protected _accounts: Array<IAccount> = [];\r\n\r\n    public readonly coinbase: ICoinbase;\r\n    public readonly provider: IJsonRpcProvider;\r\n    public strategy: UtxoSelectionStrategy;\r\n\r\n    /**\r\n     * Create a Wallet by reading the XPRV master key from the WITNET_SDK_WALLET_MASTER_KEY environment variable.\r\n     * @param specs Wallet creation parameters.\r\n     */\r\n    static async fromEnv(options: {\r\n        /**\r\n         * Password to decrypt the XPRV master key read from environment, in case it's encrypted.\r\n         */\r\n        passwd?: string,\r\n        /**\r\n         * Number of consecutive accounts with no funds before stopping derivation of new Wallet accounts.\r\n         */\r\n        gap?: number,\r\n        /**\r\n         * Maximum number of accounts to derive. \r\n         */\r\n        limit?: number,\r\n        /**\r\n         * Specific Wit/RPC provider to use for interacting with the Witnet network.\r\n         */\r\n        provider?: IJsonRpcProvider, \r\n        /**\r\n         * UTXO selection strategy when building transactions out of this wallet (default: UtxoSelectionStrategy.SmallFirst).\r\n         */\r\n        strategy?: UtxoSelectionStrategy, \r\n        /**\r\n         * Only derive accounts that hold some unlocked balance of $WIT.\r\n         */\r\n        onlyWithFunds?: boolean,\r\n    }): Promise<Wallet> {\r\n        const xprv = process.env.WITNET_SDK_WALLET_MASTER_KEY\r\n        if (!xprv) throw Error(`WITNET_SDK_WALLET_MASTER_KEY must be set on environment.`)\r\n        if (xprv.length > 117) {\r\n            if (!options.passwd) throw Error(`Missing password for WITNET_SDK_WALLET_MASTER_KEY.`)\r\n            return Wallet.fromEncryptedXprv(xprv, options?.passwd, options)\r\n        } else {\r\n            return Wallet.fromXprv(xprv, options)\r\n        }\r\n    }\r\n    \r\n    /**\r\n     * Create a Wallet by using passed XPRV master key.\r\n     * @param xprv Decrypted XPRV master key string.\r\n     * @param options Wallet creation parameters.\r\n     */\r\n    static async fromXprv(\r\n        xprv: string,\r\n        options?: {\r\n            /**\r\n             * Number of consecutive accounts with no funds before stopping derivation of new Wallet accounts.\r\n             */\r\n            gap?: number,\r\n            /**\r\n             * Maximum number of accounts to derive. \r\n             */\r\n            limit?: number,\r\n            /**\r\n             * Specific Wit/RPC provider to use for interacting with the Witnet network.\r\n             */\r\n            provider?: IJsonRpcProvider, \r\n            /**\r\n             * UTXO selection strategy when building transactions out of this wallet (default: UtxoSelectionStrategy.SmallFirst).\r\n             */\r\n            strategy?: UtxoSelectionStrategy, \r\n            /**\r\n             * Only derive accounts holding some $WIT funds (either locked, staked or unlocked).\r\n             */\r\n            onlyWithFunds?: boolean,\r\n        }\r\n    ): Promise<Wallet> {\r\n        const { chainCode, privateKey } = utils.parseXprv(xprv);\r\n        const root = bip32.fromPrivateKey(Buffer.from(privateKey), Buffer.from(chainCode));\r\n        const provider = options?.provider || (await JsonRpcProvider.fromEnv())\r\n        await provider.constants()\r\n        const wallet = new Wallet(root, provider, options?.strategy)\r\n        if (options?.onlyWithFunds) {\r\n            await wallet.exploreAccounts(options?.limit || 0, options?.gap)\r\n        } else {\r\n            wallet.deriveAccounts(options?.limit || 1)\r\n        }\r\n        // load up utxos cache\r\n        await wallet.getUtxos(true)\r\n        return wallet\r\n    }\r\n\r\n    /**\r\n     * Create a Wallet by using passed XPRV master key.\r\n     * @param xprv Encrypted XPRV master key string.\r\n     * @param passwd Password to decipher the XPRV master key.\r\n     * @param options Wallet creation parameters.\r\n     */\r\n    static async fromEncryptedXprv(\r\n        xprv: string,\r\n        passwd: string,\r\n        options?: {\r\n            /**\r\n             * Number of consecutive accounts with no funds before stopping derivation of new Wallet accounts.\r\n             */\r\n            gap?: number,\r\n            /**\r\n             * Maximum number of accounts to derive. \r\n             */\r\n            limit?: number,\r\n            /**\r\n             * Specific Wit/RPC provider to use for interacting with the Witnet network.\r\n             */\r\n            provider?: IJsonRpcProvider, \r\n            /**\r\n             * UTXO selection strategy when building transactions out of this wallet (default: UtxoSelectionStrategy.SmallFirst).\r\n             */\r\n            strategy?: UtxoSelectionStrategy, \r\n            /**\r\n             * Only derive accounts holding some $WIT funds (either locked, staked or unlocked).\r\n             */\r\n            onlyWithFunds?: boolean,\r\n        }\r\n    ): Promise<Wallet> {\r\n        return Wallet.fromXprv(utils.decipherXprv(xprv, passwd), options)\r\n    }\r\n    \r\n    constructor(root: IBIP32, provider: IJsonRpcProvider, strategy?: UtxoSelectionStrategy) {\r\n        this.provider = provider\r\n        this.coinbase = new Coinbase(root, provider, strategy)\r\n        this.root = root\r\n        this.strategy = strategy || UtxoSelectionStrategy.SmallFirst\r\n        this.deriveAccounts(1)\r\n    }\r\n\r\n    public get accounts(): Array<IAccount> {\r\n        return this._accounts\r\n    }\r\n\r\n    public get cacheInfo(): UtxoCacheInfo {\r\n        const info: UtxoCacheInfo = { expendable: 0n, size: 0, timelock: Number.MAX_SAFE_INTEGER }\r\n        this.accounts?.forEach(account => {\r\n            const accountInfo = account.cacheInfo\r\n            info.expendable += accountInfo.expendable\r\n            info.size += accountInfo.size\r\n            if (accountInfo.timelock !== 0 && accountInfo.timelock < info.timelock) {\r\n                info.timelock = accountInfo.timelock\r\n            }\r\n        })\r\n        if (info.timelock === Number.MAX_SAFE_INTEGER) info.timelock = 0;\r\n        return info;\r\n    }\r\n\r\n    public get changePkh(): PublicKeyHashString {\r\n        return this.accounts.length > 0 ? this.accounts[0].changePkh : this.coinbase.pkh\r\n    }\r\n\r\n    public get network(): Network | undefined {\r\n        return this.provider.network\r\n    }\r\n\r\n    public get pkh(): PublicKeyHashString {\r\n        return this.accounts.length > 0 ? this.accounts[0].pkh : this.coinbase.pkh\r\n    }\r\n\r\n    public get publicKey(): PublicKey {\r\n        return this.accounts.length > 0 ? this.accounts[0].publicKey : this.coinbase.publicKey\r\n    }\r\n\r\n    public addUtxos(...utxos: Array<Utxo>): { excluded: Array<Utxo>, included: Array<Utxo> } {\r\n        const included: Array<Utxo> = []\r\n        this.accounts.forEach(account => {\r\n            const _utxos = account.addUtxos(...utxos)\r\n            utxos = _utxos.excluded\r\n            included.push(..._utxos.included)\r\n        })\r\n        return {\r\n            excluded: utxos,\r\n            included\r\n        }\r\n    }\r\n\r\n    public consumeUtxos(...utxos: Array<Utxo>): Array<Utxo> {\r\n        this.accounts.forEach(account => {\r\n            utxos = account.consumeUtxos(...utxos)\r\n        })\r\n        return utxos\r\n    }\r\n\r\n    public async getBalance(): Promise<Balance> {\r\n        if (this._accounts.length > 0) {\r\n            return Promise\r\n                .all(this._accounts.map(async (acc: IAccount) => { \r\n                    const balance = await acc.getBalance()\r\n                    // console.log(acc.index, acc.pkh, balance.unlocked); \r\n                    return balance }))\r\n                .then((balances: Array<Balance>) => {\r\n                    return balances.reduce((prev, curr) => {\r\n                        // console.log(\"\\nprev =>\", prev.unlocked)\r\n                        // console.log(\"curr =>\", curr.unlocked)\r\n                        return {\r\n                            locked: prev.locked + curr.locked,\r\n                            staked: prev.staked + curr.staked,\r\n                            unlocked: prev.unlocked + curr.unlocked,\r\n                        }\r\n                    }, { locked: 0n, staked: 0n, unlocked: 0n })\r\n                })\r\n        } else {\r\n            return this.coinbase.getBalance()\r\n        }\r\n    }\r\n\r\n    public async getDelegatees(order?: QueryStakesOrder, leftJoin = true): Promise<Array<StakeEntry>> {\r\n        const records: Array<StakeEntry> = []\r\n        records.push(...await this.coinbase.getDelegatees(order))\r\n        await Promise.all(this._accounts.map(account => account.getDelegatees(order, leftJoin).then(entries => records.push(...entries))))\r\n        if (order) {\r\n            const reverse = order?.reverse ? (+1) : (-1)\r\n            return records.sort((a, b) => {\r\n                switch (order.by) {\r\n                    case StakesOrderBy.Coins: return ((a.value.coins < b.value.coins) ? 1 : ((a.value.coins > b.value.coins) ? -1 : 0)) * reverse;\r\n                    case StakesOrderBy.Mining: return (b.value.epochs.mining - a.value.epochs.mining) * reverse;\r\n                    case StakesOrderBy.Witnessing: return (b.value.epochs.witnessing - a.value.epochs.witnessing) * reverse;\r\n                    case StakesOrderBy.Nonce: return (b.value.nonce - a.value.nonce) * reverse;\r\n                }\r\n            })\r\n        }\r\n        return records\r\n    }\r\n\r\n    public async getUtxos(reload?: boolean): Promise<Array<Utxo>> {\r\n        return Promise\r\n            .all(this.accounts.map(account => account.getUtxos(reload)))\r\n            .then(async (utxoss: Array<Array<Utxo>>) => {\r\n                // utxoss.push(await this.coinbase.getUtxos(reload))\r\n                return utxoss.flat()\r\n            })\r\n    }\r\n\r\n    public async selectUtxos(specs?: {\r\n        value?: Coins,\r\n        reload?: boolean\r\n        strategy?: UtxoSelectionStrategy\r\n    }): Promise<Array<Utxo>> {\r\n        return this\r\n            .getUtxos(specs?.reload)\r\n            .then(utxos => utils.selectUtxos({ utxos, value: specs?.value, strategy: specs?.strategy || this.strategy }))\r\n    }\r\n\r\n    // ================================================================================================================\r\n    // --- IWallet ----------------------------------------------------------------------------------------------------\r\n\r\n    public deriveAccounts(limit: number): Array<IAccount> {\r\n        if (limit > this._accounts.length) {\r\n            const startIndex = this._accounts.length > 0 ? this.accounts[this.accounts.length - 1].index + 1 : 0\r\n            limit = limit - this._accounts.length\r\n            for (let ix = 0; ix < limit; ix ++) {\r\n                this._accounts.push(new Account(\r\n                    this.root,\r\n                    this.provider,\r\n                    startIndex + ix,\r\n                    this.strategy\r\n                ))\r\n            }\r\n        }\r\n        return this._accounts\r\n    }\r\n\r\n    public async exploreAccounts(limit = 0, gap = DEFAULT_GAP): Promise<Array<IAccount>> {\r\n        if (limit === 0 || limit > this.accounts.length) {\r\n            const lastIndex = (x: Array<IAccount>) => x.length > 0 ? x[x.length - 1].index + 1 : 0\r\n            const startIndex = lastIndex(this.accounts)\r\n            for (let index = startIndex; index < lastIndex(this.accounts) + gap; index ++) {\r\n                const account = new Account(this.root, this.provider, index, this.strategy)\r\n                if (utils.totalCoins(await account.getBalance()).pedros > 0n) {\r\n                    this.accounts.push(account)\r\n                    if (limit && this.accounts.length >= limit) break;\r\n                }\r\n            }\r\n        }\r\n        return this._accounts\r\n    }\r\n\r\n    public getAccount(pkh: PublicKeyHashString, gap?: number): IAccount | undefined {\r\n        let account = this._accounts.find(account => account.internal.pkh === pkh || account.pkh === pkh)\r\n        if (!account) {\r\n            for (let index = 0; index < (gap || DEFAULT_GAP); index ++) {\r\n                account = new Account(this.root, this.provider, index, this.strategy)\r\n                if (account.pkh === pkh || account.internal.pkh === pkh) {\r\n                    this._accounts.push(account)\r\n                    return account\r\n                }\r\n            }\r\n            return undefined\r\n        } else {\r\n            return account\r\n        }\r\n    }\r\n\r\n    public getSigner(pkh?: PublicKeyHashString, gap?: number): ISigner | undefined {\r\n        if (!pkh) return this.accounts[0]?.getSigner() || this.coinbase.getSigner(pkh);\r\n        const account = this.getAccount(pkh, gap)\r\n        return account?.getSigner(pkh) || this.coinbase.getSigner(pkh)\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAA;AACxB,OAAO,KAAK,KAAK,MAAM,SAAS,CAAA;AAChC,cAAc,OAAO,CAAA;AACrB,cAAc,SAAS,CAAA"}
|