mainnet-js 2.7.33 → 3.0.0-next.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/dist/index.html +1 -1
- package/dist/{mainnet-2.7.33.js → mainnet-3.0.0-next.0.js} +718 -678
- package/dist/module/cache/MemoryCache.d.ts +0 -1
- package/dist/module/cache/MemoryCache.d.ts.map +1 -1
- package/dist/module/cache/MemoryCache.js +5 -7
- package/dist/module/cache/MemoryCache.js.map +1 -1
- package/dist/module/cache/index.d.ts +1 -0
- package/dist/module/cache/index.d.ts.map +1 -1
- package/dist/module/cache/index.js +1 -0
- package/dist/module/cache/index.js.map +1 -1
- package/dist/module/cache/walletCache.d.ts +39 -0
- package/dist/module/cache/walletCache.d.ts.map +1 -0
- package/dist/module/cache/walletCache.js +141 -0
- package/dist/module/cache/walletCache.js.map +1 -0
- package/dist/module/history/{electrumTransformer.d.ts → getHistory.d.ts} +3 -3
- package/dist/module/history/getHistory.d.ts.map +1 -0
- package/dist/module/history/{electrumTransformer.js → getHistory.js} +47 -14
- package/dist/module/history/getHistory.js.map +1 -0
- package/dist/module/index.d.ts +3 -1
- package/dist/module/index.d.ts.map +1 -1
- package/dist/module/index.js +3 -1
- package/dist/module/index.js.map +1 -1
- package/dist/module/interface.d.ts +7 -1
- package/dist/module/interface.d.ts.map +1 -1
- package/dist/module/interface.js.map +1 -1
- package/dist/module/message/interface.d.ts +2 -2
- package/dist/module/message/interface.d.ts.map +1 -1
- package/dist/module/message/interface.js +0 -3
- package/dist/module/message/interface.js.map +1 -1
- package/dist/module/message/signed.d.ts +5 -5
- package/dist/module/message/signed.d.ts.map +1 -1
- package/dist/module/message/signed.js +8 -8
- package/dist/module/message/signed.js.map +1 -1
- package/dist/module/network/ElectrumNetworkProvider.d.ts +2 -2
- package/dist/module/network/ElectrumNetworkProvider.d.ts.map +1 -1
- package/dist/module/network/ElectrumNetworkProvider.js +2 -1
- package/dist/module/network/ElectrumNetworkProvider.js.map +1 -1
- package/dist/module/network/NetworkProvider.d.ts +2 -2
- package/dist/module/network/NetworkProvider.d.ts.map +1 -1
- package/dist/module/network/constant.js +4 -4
- package/dist/module/network/constant.js.map +1 -1
- package/dist/module/transaction/Wif.d.ts +21 -19
- package/dist/module/transaction/Wif.d.ts.map +1 -1
- package/dist/module/transaction/Wif.js +18 -15
- package/dist/module/transaction/Wif.js.map +1 -1
- package/dist/module/util/checkUtxos.d.ts +2 -2
- package/dist/module/util/checkUtxos.d.ts.map +1 -1
- package/dist/module/util/checkUtxos.js +11 -12
- package/dist/module/util/checkUtxos.js.map +1 -1
- package/dist/module/util/deriveCashaddr.d.ts.map +1 -1
- package/dist/module/util/deriveCashaddr.js +6 -0
- package/dist/module/util/deriveCashaddr.js.map +1 -1
- package/dist/module/util/deriveNetwork.js +1 -1
- package/dist/module/util/deriveNetwork.js.map +1 -1
- package/dist/module/util/hd.d.ts +3 -0
- package/dist/module/util/hd.d.ts.map +1 -0
- package/dist/module/util/hd.js +11 -0
- package/dist/module/util/hd.js.map +1 -0
- package/dist/module/util/index.d.ts +1 -0
- package/dist/module/util/index.d.ts.map +1 -1
- package/dist/module/util/index.js +1 -0
- package/dist/module/util/index.js.map +1 -1
- package/dist/module/util/sumUtxoValue.d.ts +3 -3
- package/dist/module/util/sumUtxoValue.d.ts.map +1 -1
- package/dist/module/util/sumUtxoValue.js.map +1 -1
- package/dist/module/wallet/Base.d.ts +37 -93
- package/dist/module/wallet/Base.d.ts.map +1 -1
- package/dist/module/wallet/Base.js +83 -250
- package/dist/module/wallet/Base.js.map +1 -1
- package/dist/module/wallet/HDWallet.d.ts +164 -0
- package/dist/module/wallet/HDWallet.d.ts.map +1 -0
- package/dist/module/wallet/HDWallet.js +486 -0
- package/dist/module/wallet/HDWallet.js.map +1 -0
- package/dist/module/wallet/Watch.d.ts +151 -0
- package/dist/module/wallet/Watch.d.ts.map +1 -0
- package/dist/module/wallet/Watch.js +307 -0
- package/dist/module/wallet/Watch.js.map +1 -0
- package/dist/module/wallet/Wif.d.ts +23 -29
- package/dist/module/wallet/Wif.d.ts.map +1 -1
- package/dist/module/wallet/Wif.js +204 -267
- package/dist/module/wallet/Wif.js.map +1 -1
- package/dist/module/wallet/createWallet.d.ts +7 -1
- package/dist/module/wallet/createWallet.d.ts.map +1 -1
- package/dist/module/wallet/createWallet.js +26 -17
- package/dist/module/wallet/createWallet.js.map +1 -1
- package/dist/module/wallet/interface.d.ts +3 -3
- package/dist/module/wallet/interface.d.ts.map +1 -1
- package/dist/module/wallet/model.d.ts +3 -3
- package/dist/module/wallet/model.d.ts.map +1 -1
- package/dist/module/wallet/model.js +2 -18
- package/dist/module/wallet/model.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/cache/MemoryCache.ts +5 -5
- package/src/cache/index.ts +1 -0
- package/src/cache/walletCache.ts +252 -0
- package/src/history/{electrumTransformer.test.ts → getHistory.test.ts} +6 -19
- package/src/history/{electrumTransformer.ts → getHistory.ts} +63 -15
- package/src/index.ts +3 -1
- package/src/interface.ts +8 -1
- package/src/message/interface.ts +2 -28
- package/src/message/signed.test.ts +36 -48
- package/src/message/signed.ts +9 -12
- package/src/network/ElectrumNetworkProvider.ts +4 -4
- package/src/network/NetworkProvider.ts +2 -2
- package/src/network/Rpc.test.ts +1 -1
- package/src/network/constant.ts +4 -4
- package/src/transaction/Wif.ts +41 -35
- package/src/util/checkUtxos.ts +21 -26
- package/src/util/deriveCashaddr.ts +8 -0
- package/src/util/deriveNetwork.ts +1 -1
- package/src/util/derivePublicKeyHash.test.ts +0 -13
- package/src/util/hd.ts +16 -0
- package/src/util/index.ts +1 -0
- package/src/util/sumUtxoValue.ts +5 -5
- package/src/wallet/Base.ts +123 -332
- package/src/wallet/HDWallet.test.ts +372 -0
- package/src/wallet/HDWallet.ts +764 -0
- package/src/wallet/Watch.ts +447 -0
- package/src/wallet/Wif.ts +258 -283
- package/src/wallet/createWallet.ts +28 -18
- package/src/wallet/interface.ts +3 -3
- package/src/wallet/model.test.ts +2 -2
- package/src/wallet/model.ts +6 -23
- package/dist/module/history/electrumTransformer.d.ts.map +0 -1
- package/dist/module/history/electrumTransformer.js.map +0 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { SignedMessage, hash_message } from "./signed.js";
|
|
2
2
|
import { Wallet, RegTestWallet, TestNetWallet } from "../wallet/Wif.js";
|
|
3
|
-
import {
|
|
3
|
+
import { binToHex } from "@bitauth/libauth";
|
|
4
4
|
|
|
5
5
|
import fs from "fs";
|
|
6
6
|
|
|
@@ -14,13 +14,13 @@ describe("Test message Signing and Verification", () => {
|
|
|
14
14
|
// Test that the double sha256 hash of the wrapped messages matches
|
|
15
15
|
// what would be had internally in electron-cash
|
|
16
16
|
// b'\x18Bitcoin Signed Message:\n' + b'{message.length}' + b'{message}'
|
|
17
|
-
let test_hash =
|
|
17
|
+
let test_hash = hash_message("test");
|
|
18
18
|
expect(binToHex(test_hash)).toBe(
|
|
19
19
|
"9ce428d58e8e4caf619dc6fc7b2c2c28f0561654d1f80f322c038ad5e67ff8a6"
|
|
20
20
|
);
|
|
21
21
|
|
|
22
22
|
// b'\xe6\xb5\x8b\xe8\xaf\x95' in binary python
|
|
23
|
-
let 测试_hash =
|
|
23
|
+
let 测试_hash = hash_message("测试");
|
|
24
24
|
expect(binToHex(测试_hash)).toBe(
|
|
25
25
|
"8d8405050b7a763ccd5683f8470ea7dcbd10a87da2b7fe07eb2679ba71229688"
|
|
26
26
|
);
|
|
@@ -34,12 +34,12 @@ describe("Test message Signing and Verification", () => {
|
|
|
34
34
|
expect(w1.cashaddr!).toBe(
|
|
35
35
|
"bitcoincash:qqehccy89v7ftlfgr9v0zvhjzyy7eatdkqt05lt3nw"
|
|
36
36
|
);
|
|
37
|
-
let sig =
|
|
37
|
+
let sig = SignedMessage.sign(msg1, w1.privateKey!);
|
|
38
38
|
|
|
39
39
|
let coreLibSig =
|
|
40
40
|
"H/9jMOnj4MFbH3d7t4yCQ9i7DgZU/VZ278w3+ySv2F4yIsdqjsc5ng3kmN8OZAThgyfCZOQxZCWza9V5XzlVY0Y=";
|
|
41
41
|
expect(sig.signature).toBe(coreLibSig);
|
|
42
|
-
let result =
|
|
42
|
+
let result = SignedMessage.verify(msg1, sig.signature, w1.cashaddr!);
|
|
43
43
|
expect(result.valid).toBe(true);
|
|
44
44
|
expect(result.details!.messageHash).toBe(
|
|
45
45
|
"gE9BDBFAOqW+yoOzABjnM+LQRWHd4dvUVrsTR+sIWsU="
|
|
@@ -50,7 +50,7 @@ describe("Test message Signing and Verification", () => {
|
|
|
50
50
|
expect(result.details!.signatureType).toBe("recoverable");
|
|
51
51
|
|
|
52
52
|
let msg2 = "Lessons for China from Japan’s lost decade";
|
|
53
|
-
result =
|
|
53
|
+
result = SignedMessage.verify(msg2, sig.signature, w1.cashaddr!);
|
|
54
54
|
expect(result.valid).toBe(false);
|
|
55
55
|
expect(result.details!.messageHash).toBe(
|
|
56
56
|
"070kQIcYPSHApGdOGH0O81N1AkMbNKwCTM3IX2Svd3I="
|
|
@@ -73,11 +73,11 @@ describe("Test message Signing and Verification", () => {
|
|
|
73
73
|
"bchtest:qqf25s9nm4uq982t94vq75v78n4j0e4r4vdf9j48wn"
|
|
74
74
|
);
|
|
75
75
|
let msg = "test";
|
|
76
|
-
let sig =
|
|
77
|
-
let result =
|
|
76
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
77
|
+
let result = SignedMessage.verify(msg, sig.signature, w.cashaddr!);
|
|
78
78
|
expect(result.valid).toBe(true);
|
|
79
79
|
|
|
80
|
-
result =
|
|
80
|
+
result = SignedMessage.verify("test2", sig.signature, w.cashaddr!);
|
|
81
81
|
expect(result.valid).toBe(false);
|
|
82
82
|
});
|
|
83
83
|
|
|
@@ -86,12 +86,12 @@ describe("Test message Signing and Verification", () => {
|
|
|
86
86
|
"wif:regtest:cNfsPtqN2bMRS7vH5qd8tR8GMvgXyL5BjnGAKgZ8DYEiCrCCQcP6"
|
|
87
87
|
);
|
|
88
88
|
let msg = "test";
|
|
89
|
-
let sig =
|
|
89
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
90
90
|
|
|
91
|
-
let result =
|
|
91
|
+
let result = SignedMessage.verify(msg, sig.signature, w.cashaddr!);
|
|
92
92
|
expect(result.valid).toBe(true);
|
|
93
93
|
|
|
94
|
-
result =
|
|
94
|
+
result = SignedMessage.verify("test2", sig.signature, w.cashaddr!);
|
|
95
95
|
expect(result.valid).toBe(false);
|
|
96
96
|
});
|
|
97
97
|
|
|
@@ -100,11 +100,11 @@ describe("Test message Signing and Verification", () => {
|
|
|
100
100
|
"wif:regtest:cNfsPtqN2bMRS7vH5qd8tR8GMvgXyL5BjnGAKgZ8DYEiCrCCQcP6"
|
|
101
101
|
);
|
|
102
102
|
let msg = "测试";
|
|
103
|
-
let sig =
|
|
104
|
-
let result =
|
|
103
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
104
|
+
let result = SignedMessage.verify(msg, sig.signature, w.cashaddr!);
|
|
105
105
|
expect(result.valid).toBe(true);
|
|
106
106
|
|
|
107
|
-
result =
|
|
107
|
+
result = SignedMessage.verify("测试二", sig.signature, w.cashaddr!);
|
|
108
108
|
expect(result.valid).toBe(false);
|
|
109
109
|
});
|
|
110
110
|
|
|
@@ -113,8 +113,8 @@ describe("Test message Signing and Verification", () => {
|
|
|
113
113
|
"wif:mainnet:L1TnU2zbNaAqMoVh65Cyvmcjzbrj41Gs9iTLcWbpJCMynXuap6UN"
|
|
114
114
|
);
|
|
115
115
|
let msg = "test";
|
|
116
|
-
let sig =
|
|
117
|
-
let result =
|
|
116
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
117
|
+
let result = SignedMessage.verify(
|
|
118
118
|
msg,
|
|
119
119
|
sig.raw!.schnorr,
|
|
120
120
|
undefined,
|
|
@@ -125,7 +125,7 @@ describe("Test message Signing and Verification", () => {
|
|
|
125
125
|
|
|
126
126
|
let msg2 =
|
|
127
127
|
"Biggest Selloff in 25 Years Hits Japan Bonds as BOJ Loosens Grip";
|
|
128
|
-
let invalid =
|
|
128
|
+
let invalid = SignedMessage.verify(
|
|
129
129
|
msg2,
|
|
130
130
|
sig.raw!.schnorr,
|
|
131
131
|
undefined,
|
|
@@ -139,8 +139,8 @@ describe("Test message Signing and Verification", () => {
|
|
|
139
139
|
"wif:mainnet:L1TnU2zbNaAqMoVh65Cyvmcjzbrj41Gs9iTLcWbpJCMynXuap6UN"
|
|
140
140
|
);
|
|
141
141
|
let msg = "test";
|
|
142
|
-
let sig =
|
|
143
|
-
let result =
|
|
142
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
143
|
+
let result = SignedMessage.verify(
|
|
144
144
|
msg,
|
|
145
145
|
sig.raw!.der,
|
|
146
146
|
undefined,
|
|
@@ -155,8 +155,8 @@ describe("Test message Signing and Verification", () => {
|
|
|
155
155
|
"wif:mainnet:L1TnU2zbNaAqMoVh65Cyvmcjzbrj41Gs9iTLcWbpJCMynXuap6UN"
|
|
156
156
|
);
|
|
157
157
|
let msg = "test";
|
|
158
|
-
let sig =
|
|
159
|
-
let result =
|
|
158
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
159
|
+
let result = SignedMessage.verify(
|
|
160
160
|
msg,
|
|
161
161
|
sig.raw!.ecdsa,
|
|
162
162
|
undefined,
|
|
@@ -167,7 +167,7 @@ describe("Test message Signing and Verification", () => {
|
|
|
167
167
|
|
|
168
168
|
let msg2 =
|
|
169
169
|
"Biggest Selloff in 25 Years Hits Japan Bonds as BOJ Loosens Grip";
|
|
170
|
-
let invalid =
|
|
170
|
+
let invalid = SignedMessage.verify(
|
|
171
171
|
msg2,
|
|
172
172
|
sig.raw!.ecdsa,
|
|
173
173
|
undefined,
|
|
@@ -181,8 +181,8 @@ describe("Test message Signing and Verification", () => {
|
|
|
181
181
|
"wif:mainnet:L1TnU2zbNaAqMoVh65Cyvmcjzbrj41Gs9iTLcWbpJCMynXuap6UN"
|
|
182
182
|
);
|
|
183
183
|
let msg = await loadLargeMessage();
|
|
184
|
-
let sig =
|
|
185
|
-
let result =
|
|
184
|
+
let sig = SignedMessage.sign(msg, w.privateKey!);
|
|
185
|
+
let result = SignedMessage.verify(msg, sig.signature, w.cashaddr!);
|
|
186
186
|
expect(result.valid).toBe(true);
|
|
187
187
|
});
|
|
188
188
|
|
|
@@ -194,21 +194,13 @@ describe("Test message Signing and Verification", () => {
|
|
|
194
194
|
expect(w1.cashaddr!).toBe(
|
|
195
195
|
"bitcoincash:qqehccy89v7ftlfgr9v0zvhjzyy7eatdkqt05lt3nw"
|
|
196
196
|
);
|
|
197
|
-
let sig =
|
|
198
|
-
let result =
|
|
199
|
-
msg1,
|
|
200
|
-
sig.signature,
|
|
201
|
-
w1.cashaddr!
|
|
202
|
-
);
|
|
197
|
+
let sig = SignedMessage.sign(msg1, w1.privateKey!);
|
|
198
|
+
let result = SignedMessage.verify(msg1, sig.signature, w1.cashaddr!);
|
|
203
199
|
expect(result.valid).toBe(true);
|
|
204
200
|
|
|
205
201
|
let msg2 =
|
|
206
202
|
"Biggest Selloff in 25 Years Hits Japan Bonds as BOJ Loosens Grip";
|
|
207
|
-
let invalid =
|
|
208
|
-
msg2,
|
|
209
|
-
sig.signature,
|
|
210
|
-
w1.cashaddr!
|
|
211
|
-
);
|
|
203
|
+
let invalid = SignedMessage.verify(msg2, sig.signature, w1.cashaddr!);
|
|
212
204
|
expect(invalid.valid).toBe(false);
|
|
213
205
|
});
|
|
214
206
|
|
|
@@ -221,13 +213,13 @@ describe("Test message Signing and Verification", () => {
|
|
|
221
213
|
expect(w1.cashaddr!).toBe(
|
|
222
214
|
"bitcoincash:qqehccy89v7ftlfgr9v0zvhjzyy7eatdkqt05lt3nw"
|
|
223
215
|
);
|
|
224
|
-
let sig =
|
|
225
|
-
let result =
|
|
216
|
+
let sig = w1.sign(msg1);
|
|
217
|
+
let result = w1.verify(msg1, sig.signature);
|
|
226
218
|
expect(result.valid).toBe(true);
|
|
227
219
|
|
|
228
220
|
let msg2 =
|
|
229
221
|
"Biggest Selloff in 25 Years Hits Japan Bonds as BOJ Loosens Grip";
|
|
230
|
-
let invalid =
|
|
222
|
+
let invalid = w1.verify(msg2, sig.signature);
|
|
231
223
|
expect(invalid.valid).toBe(false);
|
|
232
224
|
});
|
|
233
225
|
|
|
@@ -244,14 +236,14 @@ describe("Test message Signing and Verification", () => {
|
|
|
244
236
|
expect(w1.cashaddr!).toBe(
|
|
245
237
|
"bitcoincash:qqad5sy4jml3f6vcp246dulsex04xp48wq23d35rqe"
|
|
246
238
|
);
|
|
247
|
-
let result =
|
|
239
|
+
let result = w1.verify(beak, beakSig);
|
|
248
240
|
expect(result.valid).toBe(true);
|
|
249
241
|
expect(result.details?.publicKeyHashMatch).toBe(true);
|
|
250
242
|
expect(result.details?.publicKeyMatch).toBe(false);
|
|
251
243
|
expect(result.details?.signatureValid).toBe(true);
|
|
252
244
|
expect(result.details?.signatureType).toBe("recoverable");
|
|
253
245
|
|
|
254
|
-
let badResult =
|
|
246
|
+
let badResult = w1.verify(falseMessage, beakSig);
|
|
255
247
|
expect(badResult.valid).toBe(false);
|
|
256
248
|
|
|
257
249
|
// While the recoverable sig is valid, it doesn't match the message.
|
|
@@ -289,12 +281,12 @@ describe("Test message Signing and Verification", () => {
|
|
|
289
281
|
expect(w1.cashaddr!).toBe(
|
|
290
282
|
"bitcoincash:qqehccy89v7ftlfgr9v0zvhjzyy7eatdkqt05lt3nw"
|
|
291
283
|
);
|
|
292
|
-
let sig =
|
|
284
|
+
let sig = SignedMessage.sign(msg1, w1.privateKey!);
|
|
293
285
|
|
|
294
286
|
let coreLibSig =
|
|
295
287
|
"H/9jMOnj4MFbH3d7t4yCQ9i7DgZU/VZ278w3+ySv2F4yIsdqjsc5ng3kmN8OZAThgyfCZOQxZCWza9V5XzlVY0Y=";
|
|
296
288
|
expect(sig.signature).toBe(coreLibSig);
|
|
297
|
-
let result =
|
|
289
|
+
let result = SignedMessage.verify(msg1, sig.signature, w1.cashaddr!);
|
|
298
290
|
expect(result.valid).toBe(true);
|
|
299
291
|
expect(result.details!.messageHash).toBe(
|
|
300
292
|
"gE9BDBFAOqW+yoOzABjnM+LQRWHd4dvUVrsTR+sIWsU="
|
|
@@ -304,11 +296,7 @@ describe("Test message Signing and Verification", () => {
|
|
|
304
296
|
expect(result.details!.signatureValid).toBe(true);
|
|
305
297
|
expect(result.details!.signatureType).toBe("recoverable");
|
|
306
298
|
|
|
307
|
-
let result2 =
|
|
308
|
-
msg1,
|
|
309
|
-
sig.signature,
|
|
310
|
-
w1.tokenaddr!
|
|
311
|
-
);
|
|
299
|
+
let result2 = SignedMessage.verify(msg1, sig.signature, w1.tokenaddr!);
|
|
312
300
|
expect(result2.valid).toBe(true);
|
|
313
301
|
expect(result2.details!.messageHash).toBe(
|
|
314
302
|
"gE9BDBFAOqW+yoOzABjnM+LQRWHd4dvUVrsTR+sIWsU="
|
package/src/message/signed.ts
CHANGED
|
@@ -46,7 +46,7 @@ function message_magic(str: string) {
|
|
|
46
46
|
*
|
|
47
47
|
* @returns a promise to the hash of the string.
|
|
48
48
|
*/
|
|
49
|
-
export
|
|
49
|
+
export function hash_message(str: string) {
|
|
50
50
|
const h = sha256.hash;
|
|
51
51
|
return h(h(message_magic(str)));
|
|
52
52
|
}
|
|
@@ -60,11 +60,8 @@ export class SignedMessage implements SignedMessageI {
|
|
|
60
60
|
*
|
|
61
61
|
* @returns a promise to signature as a string
|
|
62
62
|
*/
|
|
63
|
-
public
|
|
64
|
-
message
|
|
65
|
-
privateKey: Uint8Array
|
|
66
|
-
): Promise<SignedMessageResponseI> {
|
|
67
|
-
const messageHash = await hash_message(message);
|
|
63
|
+
public sign(message: string, privateKey: Uint8Array): SignedMessageResponseI {
|
|
64
|
+
const messageHash = hash_message(message);
|
|
68
65
|
const rs = secp256k1.signMessageHashRecoverableCompact(
|
|
69
66
|
privateKey,
|
|
70
67
|
messageHash
|
|
@@ -99,7 +96,7 @@ export class SignedMessage implements SignedMessageI {
|
|
|
99
96
|
};
|
|
100
97
|
}
|
|
101
98
|
|
|
102
|
-
public static
|
|
99
|
+
public static sign(message: string, privateKey: Uint8Array) {
|
|
103
100
|
return new this().sign(message, privateKey);
|
|
104
101
|
}
|
|
105
102
|
/**
|
|
@@ -112,14 +109,14 @@ export class SignedMessage implements SignedMessageI {
|
|
|
112
109
|
*
|
|
113
110
|
* @returns a promise to signature as a string
|
|
114
111
|
*/
|
|
115
|
-
public
|
|
112
|
+
public verify(
|
|
116
113
|
message: string,
|
|
117
114
|
signature: string,
|
|
118
115
|
cashaddr?: string,
|
|
119
116
|
publicKey?: Uint8Array
|
|
120
|
-
):
|
|
117
|
+
): VerifyMessageResponseI {
|
|
121
118
|
// Check that the signature is valid for the given message.
|
|
122
|
-
const messageHash =
|
|
119
|
+
const messageHash = hash_message(message);
|
|
123
120
|
const sig = base64ToBin(signature);
|
|
124
121
|
|
|
125
122
|
let signatureValid = false;
|
|
@@ -139,7 +136,7 @@ export class SignedMessage implements SignedMessageI {
|
|
|
139
136
|
throw new Error(recoveredPk);
|
|
140
137
|
}
|
|
141
138
|
|
|
142
|
-
pkh =
|
|
139
|
+
pkh = hash160(recoveredPk);
|
|
143
140
|
signatureType = "recoverable";
|
|
144
141
|
signatureValid = secp256k1.verifySignatureCompact(
|
|
145
142
|
rawSig,
|
|
@@ -193,7 +190,7 @@ export class SignedMessage implements SignedMessageI {
|
|
|
193
190
|
};
|
|
194
191
|
}
|
|
195
192
|
|
|
196
|
-
public static
|
|
193
|
+
public static verify(
|
|
197
194
|
message: string,
|
|
198
195
|
signature: string,
|
|
199
196
|
cashaddr?: string,
|
|
@@ -9,12 +9,11 @@ import { default as NetworkProvider } from "./NetworkProvider.js";
|
|
|
9
9
|
import {
|
|
10
10
|
HexHeaderI,
|
|
11
11
|
TxI,
|
|
12
|
-
|
|
12
|
+
Utxo,
|
|
13
13
|
ElectrumBalanceI,
|
|
14
14
|
HeaderI,
|
|
15
15
|
} from "../interface.js";
|
|
16
16
|
import { Network } from "../interface.js";
|
|
17
|
-
import { delay } from "../util/delay.js";
|
|
18
17
|
import { ElectrumRawTransaction, ElectrumUtxo } from "./interface.js";
|
|
19
18
|
|
|
20
19
|
import { CancelFn } from "../wallet/interface.js";
|
|
@@ -45,7 +44,7 @@ export default class ElectrumNetworkProvider implements NetworkProvider {
|
|
|
45
44
|
}
|
|
46
45
|
|
|
47
46
|
if (Config.UseMemoryCache && !(this._cache instanceof MemoryCache)) {
|
|
48
|
-
this._cache = new
|
|
47
|
+
this._cache = new MemoryCache();
|
|
49
48
|
return this._cache;
|
|
50
49
|
}
|
|
51
50
|
|
|
@@ -77,13 +76,14 @@ export default class ElectrumNetworkProvider implements NetworkProvider {
|
|
|
77
76
|
}
|
|
78
77
|
}
|
|
79
78
|
|
|
80
|
-
async getUtxos(cashaddr: string): Promise<
|
|
79
|
+
async getUtxos(cashaddr: string): Promise<Utxo[]> {
|
|
81
80
|
const result = await this.performRequest<ElectrumUtxo[]>(
|
|
82
81
|
"blockchain.address.listunspent",
|
|
83
82
|
cashaddr,
|
|
84
83
|
"include_tokens"
|
|
85
84
|
);
|
|
86
85
|
return result.map((utxo) => ({
|
|
86
|
+
address: cashaddr,
|
|
87
87
|
txid: utxo.tx_hash,
|
|
88
88
|
vout: utxo.tx_pos,
|
|
89
89
|
satoshis: utxo.value,
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { TxI,
|
|
1
|
+
import { TxI, Utxo, Network, HexHeaderI, HeaderI } from "../interface.js";
|
|
2
2
|
import { CancelFn } from "../wallet/interface.js";
|
|
3
3
|
|
|
4
4
|
export default interface NetworkProvider {
|
|
@@ -12,7 +12,7 @@ export default interface NetworkProvider {
|
|
|
12
12
|
* @param cashaddr The CashAddress for which we wish to retrieve UTXOs.
|
|
13
13
|
* @returns List of UTXOs spendable by the provided address.
|
|
14
14
|
*/
|
|
15
|
-
getUtxos(cashaddr: string): Promise<
|
|
15
|
+
getUtxos(cashaddr: string): Promise<Utxo[]>;
|
|
16
16
|
|
|
17
17
|
/**
|
|
18
18
|
* Retrieve all balance of an address in satoshi
|
package/src/network/Rpc.test.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { disconnectProviders, initProviders } from "./Connection";
|
|
2
2
|
import { RegTestWallet } from "../wallet/Wif";
|
|
3
3
|
import { getNetworkProvider } from "../network/default";
|
|
4
|
-
import { Network } from "cashscript";
|
|
5
4
|
import { mine } from "../mine";
|
|
5
|
+
import { Network } from "../interface";
|
|
6
6
|
|
|
7
7
|
const aliceWif = `wif:regtest:${process.env.PRIVATE_WIF!}`;
|
|
8
8
|
|
package/src/network/constant.ts
CHANGED
|
@@ -7,8 +7,8 @@ export const networkTickerMap = {
|
|
|
7
7
|
};
|
|
8
8
|
|
|
9
9
|
export const mainnetServers = [
|
|
10
|
-
"wss://bch.imaginary.cash:50004",
|
|
11
|
-
|
|
10
|
+
// "wss://bch.imaginary.cash:50004",
|
|
11
|
+
"wss://blackie.c3-soft.com:50004",
|
|
12
12
|
// "wss://electrum.imaginary.cash:50004",
|
|
13
13
|
// "wss://fulcrum.fountainhead.cash",
|
|
14
14
|
];
|
|
@@ -29,9 +29,9 @@ export const mainnetServers = [
|
|
|
29
29
|
|
|
30
30
|
// chipnet
|
|
31
31
|
export const testnetServers = [
|
|
32
|
-
|
|
32
|
+
"wss://chipnet.imaginary.cash:50004",
|
|
33
33
|
//"wss://blackie.c3-soft.com:64004", // chipnet with protocol 1.5.0
|
|
34
|
-
"wss://chipnet.bch.ninja:50004",
|
|
34
|
+
// "wss://chipnet.bch.ninja:50004",
|
|
35
35
|
];
|
|
36
36
|
|
|
37
37
|
export const regtestServers = ["ws://127.0.0.1:60003"];
|
package/src/transaction/Wif.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import {
|
|
2
2
|
walletTemplateP2pkhNonHd,
|
|
3
|
-
walletTemplateToCompilerBCH,
|
|
4
3
|
cashAddressToLockingBytecode,
|
|
5
4
|
Compiler,
|
|
6
5
|
encodeTransaction,
|
|
@@ -8,14 +7,15 @@ import {
|
|
|
8
7
|
importWalletTemplate,
|
|
9
8
|
AnyCompilerConfiguration,
|
|
10
9
|
AuthenticationProgramStateCommon,
|
|
11
|
-
CompilationContextBCH,
|
|
12
10
|
Output,
|
|
13
11
|
hexToBin,
|
|
14
12
|
verifyTransactionTokens,
|
|
15
13
|
decodeTransaction,
|
|
16
14
|
TransactionTemplateFixed,
|
|
15
|
+
CompilationContextBch,
|
|
16
|
+
walletTemplateToCompilerBch,
|
|
17
17
|
} from "@bitauth/libauth";
|
|
18
|
-
import { NFTCapability, TokenI,
|
|
18
|
+
import { NFTCapability, TokenI, Utxo } from "../interface.js";
|
|
19
19
|
import { allocateFee } from "./allocateFee.js";
|
|
20
20
|
|
|
21
21
|
import { DUST_UTXO_THRESHOLD } from "../constant.js";
|
|
@@ -30,26 +30,31 @@ import { amountInSatoshi } from "../util/amountInSatoshi.js";
|
|
|
30
30
|
import { sumSendRequestAmounts } from "../util/sumSendRequestAmounts.js";
|
|
31
31
|
import { sumUtxoValue } from "../util/sumUtxoValue.js";
|
|
32
32
|
import { FeePaidByEnum } from "../wallet/enum.js";
|
|
33
|
+
import { WalletCacheI } from "../cache/walletCache.js";
|
|
34
|
+
|
|
35
|
+
export const placeholderPrivateKey =
|
|
36
|
+
"0000000000000000000000000000000000000000000000000000000000000001";
|
|
37
|
+
export const placeholderPrivateKeyBin = hexToBin(placeholderPrivateKey);
|
|
33
38
|
|
|
34
39
|
// Build a transaction for a p2pkh transaction for a non HD wallet
|
|
35
40
|
export async function buildP2pkhNonHdTransaction({
|
|
36
41
|
inputs,
|
|
37
42
|
outputs,
|
|
38
43
|
signingKey,
|
|
39
|
-
sourceAddress,
|
|
40
44
|
fee = 0,
|
|
41
45
|
discardChange = false,
|
|
42
46
|
feePaidBy = FeePaidByEnum.change,
|
|
43
47
|
changeAddress = "",
|
|
48
|
+
walletCache,
|
|
44
49
|
}: {
|
|
45
|
-
inputs:
|
|
50
|
+
inputs: Utxo[];
|
|
46
51
|
outputs: Array<SendRequest | TokenSendRequest | OpReturnData>;
|
|
47
|
-
signingKey
|
|
48
|
-
sourceAddress: string;
|
|
52
|
+
signingKey?: Uint8Array;
|
|
49
53
|
fee?: number;
|
|
50
54
|
discardChange?: boolean;
|
|
51
55
|
feePaidBy?: FeePaidByEnum;
|
|
52
56
|
changeAddress?: string;
|
|
57
|
+
walletCache?: WalletCacheI;
|
|
53
58
|
}) {
|
|
54
59
|
if (!signingKey) {
|
|
55
60
|
throw new Error("Missing signing key when building transaction");
|
|
@@ -60,8 +65,8 @@ export async function buildP2pkhNonHdTransaction({
|
|
|
60
65
|
throw new Error("Transaction template error");
|
|
61
66
|
}
|
|
62
67
|
|
|
63
|
-
const compiler =
|
|
64
|
-
const inputAmount =
|
|
68
|
+
const compiler = walletTemplateToCompilerBch(template);
|
|
69
|
+
const inputAmount = sumUtxoValue(inputs);
|
|
65
70
|
|
|
66
71
|
const sendAmount = await sumSendRequestAmounts(outputs);
|
|
67
72
|
|
|
@@ -72,7 +77,7 @@ export async function buildP2pkhNonHdTransaction({
|
|
|
72
77
|
const lockedOutputs = await prepareOutputs(outputs);
|
|
73
78
|
|
|
74
79
|
if (!changeAddress) {
|
|
75
|
-
changeAddress =
|
|
80
|
+
changeAddress = inputs[0].address;
|
|
76
81
|
}
|
|
77
82
|
|
|
78
83
|
if (discardChange !== true) {
|
|
@@ -92,7 +97,7 @@ export async function buildP2pkhNonHdTransaction({
|
|
|
92
97
|
inputs,
|
|
93
98
|
compiler,
|
|
94
99
|
signingKey,
|
|
95
|
-
|
|
100
|
+
walletCache,
|
|
96
101
|
});
|
|
97
102
|
const result = generateTransaction({
|
|
98
103
|
inputs: preparedInputs,
|
|
@@ -121,16 +126,16 @@ export function prepareInputs({
|
|
|
121
126
|
inputs,
|
|
122
127
|
compiler,
|
|
123
128
|
signingKey,
|
|
124
|
-
|
|
129
|
+
walletCache,
|
|
125
130
|
}: {
|
|
126
|
-
inputs:
|
|
131
|
+
inputs: Utxo[];
|
|
127
132
|
compiler: Compiler<
|
|
128
|
-
|
|
129
|
-
AnyCompilerConfiguration<
|
|
133
|
+
CompilationContextBch,
|
|
134
|
+
AnyCompilerConfiguration<CompilationContextBch>,
|
|
130
135
|
AuthenticationProgramStateCommon
|
|
131
136
|
>;
|
|
132
137
|
signingKey: Uint8Array;
|
|
133
|
-
|
|
138
|
+
walletCache?: WalletCacheI;
|
|
134
139
|
}) {
|
|
135
140
|
const preparedInputs: any[] = [];
|
|
136
141
|
const sourceOutputs: any[] = [];
|
|
@@ -160,7 +165,9 @@ export function prepareInputs({
|
|
|
160
165
|
}
|
|
161
166
|
: undefined,
|
|
162
167
|
};
|
|
163
|
-
const key =
|
|
168
|
+
const key =
|
|
169
|
+
walletCache?.getByAddress(i.address)?.privateKey ??
|
|
170
|
+
(signingKey?.length ? signingKey : Uint8Array.from(Array(32)));
|
|
164
171
|
const newInput = {
|
|
165
172
|
outpointIndex: utxoIndex,
|
|
166
173
|
outpointTransactionHash: utxoOutpointTransactionHash,
|
|
@@ -178,7 +185,7 @@ export function prepareInputs({
|
|
|
178
185
|
|
|
179
186
|
preparedInputs.push(newInput);
|
|
180
187
|
|
|
181
|
-
const lockingBytecode = cashAddressToLockingBytecode(
|
|
188
|
+
const lockingBytecode = cashAddressToLockingBytecode(i.address);
|
|
182
189
|
if (typeof lockingBytecode === "string") {
|
|
183
190
|
throw lockingBytecode;
|
|
184
191
|
}
|
|
@@ -292,22 +299,22 @@ export function prepareTokenOutputs(request: TokenSendRequest): Output {
|
|
|
292
299
|
* @returns A promise to a list of unspent outputs
|
|
293
300
|
*/
|
|
294
301
|
export async function getSuitableUtxos(
|
|
295
|
-
inputs:
|
|
302
|
+
inputs: Utxo[],
|
|
296
303
|
amountRequired: bigint | undefined,
|
|
297
304
|
bestHeight: number,
|
|
298
305
|
feePaidBy: FeePaidByEnum,
|
|
299
306
|
requests: SendRequestType[],
|
|
300
|
-
ensureUtxos:
|
|
307
|
+
ensureUtxos: Utxo[] = [],
|
|
301
308
|
tokenOperation: "send" | "genesis" | "mint" | "burn" = "send"
|
|
302
|
-
): Promise<
|
|
303
|
-
const suitableUtxos:
|
|
309
|
+
): Promise<Utxo[]> {
|
|
310
|
+
const suitableUtxos: Utxo[] = [...ensureUtxos];
|
|
304
311
|
let amountAvailable = BigInt(0);
|
|
305
312
|
const tokenRequests = requests.filter(
|
|
306
313
|
(val) => val instanceof TokenSendRequest
|
|
307
314
|
) as TokenSendRequest[];
|
|
308
315
|
|
|
309
316
|
const availableInputs = inputs.slice();
|
|
310
|
-
const selectedInputs:
|
|
317
|
+
const selectedInputs: Utxo[] = [];
|
|
311
318
|
|
|
312
319
|
// find matching utxos for token transfers
|
|
313
320
|
if (tokenOperation === "send") {
|
|
@@ -438,9 +445,8 @@ export async function getFeeAmountSimple({
|
|
|
438
445
|
relayFeePerByteInSatoshi,
|
|
439
446
|
discardChange,
|
|
440
447
|
}: {
|
|
441
|
-
utxos:
|
|
448
|
+
utxos: Utxo[];
|
|
442
449
|
sendRequests: Array<SendRequest | TokenSendRequest | OpReturnData>;
|
|
443
|
-
privateKey: Uint8Array;
|
|
444
450
|
sourceAddress: string;
|
|
445
451
|
relayFeePerByteInSatoshi: number;
|
|
446
452
|
feePaidBy: FeePaidByEnum;
|
|
@@ -494,19 +500,19 @@ export async function getFeeAmountSimple({
|
|
|
494
500
|
export async function getFeeAmount({
|
|
495
501
|
utxos,
|
|
496
502
|
sendRequests,
|
|
497
|
-
privateKey,
|
|
498
503
|
sourceAddress,
|
|
499
504
|
relayFeePerByteInSatoshi,
|
|
500
505
|
feePaidBy,
|
|
501
506
|
discardChange,
|
|
507
|
+
walletCache,
|
|
502
508
|
}: {
|
|
503
|
-
utxos:
|
|
509
|
+
utxos: Utxo[];
|
|
504
510
|
sendRequests: Array<SendRequest | TokenSendRequest | OpReturnData>;
|
|
505
|
-
privateKey: Uint8Array;
|
|
506
511
|
sourceAddress: string;
|
|
507
512
|
relayFeePerByteInSatoshi: number;
|
|
508
513
|
feePaidBy: FeePaidByEnum;
|
|
509
514
|
discardChange?: boolean;
|
|
515
|
+
walletCache?: WalletCacheI;
|
|
510
516
|
}) {
|
|
511
517
|
// build transaction
|
|
512
518
|
if (utxos) {
|
|
@@ -515,12 +521,12 @@ export async function getFeeAmount({
|
|
|
515
521
|
await buildEncodedTransaction({
|
|
516
522
|
inputs: utxos,
|
|
517
523
|
outputs: sendRequests,
|
|
518
|
-
signingKey:
|
|
519
|
-
sourceAddress,
|
|
524
|
+
signingKey: placeholderPrivateKeyBin,
|
|
520
525
|
fee: 0, //DUST_UTXO_THRESHOLD
|
|
521
526
|
discardChange: discardChange ?? false,
|
|
522
527
|
feePaidBy,
|
|
523
528
|
changeAddress: "",
|
|
529
|
+
walletCache,
|
|
524
530
|
});
|
|
525
531
|
|
|
526
532
|
return Math.ceil(draftTransaction.length * relayFeePerByteInSatoshi + 1);
|
|
@@ -536,32 +542,32 @@ export async function buildEncodedTransaction({
|
|
|
536
542
|
inputs,
|
|
537
543
|
outputs,
|
|
538
544
|
signingKey,
|
|
539
|
-
sourceAddress,
|
|
540
545
|
fee = 0,
|
|
541
546
|
discardChange = false,
|
|
542
547
|
feePaidBy = FeePaidByEnum.change,
|
|
543
548
|
changeAddress = "",
|
|
544
549
|
buildUnsigned = false,
|
|
550
|
+
walletCache,
|
|
545
551
|
}: {
|
|
546
|
-
inputs:
|
|
552
|
+
inputs: Utxo[];
|
|
547
553
|
outputs: Array<SendRequest | TokenSendRequest | OpReturnData>;
|
|
548
554
|
signingKey: Uint8Array;
|
|
549
|
-
sourceAddress: string;
|
|
550
555
|
fee?: number;
|
|
551
556
|
discardChange?: boolean;
|
|
552
557
|
feePaidBy?: FeePaidByEnum;
|
|
553
558
|
changeAddress?: string;
|
|
554
559
|
buildUnsigned?: boolean;
|
|
560
|
+
walletCache?: WalletCacheI;
|
|
555
561
|
}) {
|
|
556
562
|
const { transaction, sourceOutputs } = await buildP2pkhNonHdTransaction({
|
|
557
563
|
inputs,
|
|
558
564
|
outputs,
|
|
559
565
|
signingKey,
|
|
560
|
-
sourceAddress,
|
|
561
566
|
fee,
|
|
562
567
|
discardChange,
|
|
563
568
|
feePaidBy,
|
|
564
569
|
changeAddress,
|
|
570
|
+
walletCache,
|
|
565
571
|
});
|
|
566
572
|
|
|
567
573
|
if (buildUnsigned === true) {
|
|
@@ -592,7 +598,7 @@ export async function signUnsignedTransaction(
|
|
|
592
598
|
throw new Error("Transaction template error");
|
|
593
599
|
}
|
|
594
600
|
|
|
595
|
-
const compiler =
|
|
601
|
+
const compiler = walletTemplateToCompilerBch(template);
|
|
596
602
|
const transactionTemplate: Readonly<
|
|
597
603
|
TransactionTemplateFixed<typeof compiler>
|
|
598
604
|
> = { ...decoded };
|