mainnet-js 2.7.34 → 3.0.0-next.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (195) hide show
  1. package/dist/index.html +1 -1
  2. package/dist/{mainnet-2.7.34.js → mainnet-3.0.0-next.1.js} +728 -708
  3. package/dist/module/cache/MemoryCache.d.ts +0 -1
  4. package/dist/module/cache/MemoryCache.d.ts.map +1 -1
  5. package/dist/module/cache/MemoryCache.js +5 -7
  6. package/dist/module/cache/MemoryCache.js.map +1 -1
  7. package/dist/module/cache/index.d.ts +1 -0
  8. package/dist/module/cache/index.d.ts.map +1 -1
  9. package/dist/module/cache/index.js +1 -0
  10. package/dist/module/cache/index.js.map +1 -1
  11. package/dist/module/cache/walletCache.d.ts +45 -0
  12. package/dist/module/cache/walletCache.d.ts.map +1 -0
  13. package/dist/module/cache/walletCache.js +140 -0
  14. package/dist/module/cache/walletCache.js.map +1 -0
  15. package/dist/module/chain.d.ts +1 -1
  16. package/dist/module/chain.js +1 -1
  17. package/dist/module/chain.js.map +1 -1
  18. package/dist/module/constant.d.ts +1 -1
  19. package/dist/module/constant.d.ts.map +1 -1
  20. package/dist/module/constant.js +1 -1
  21. package/dist/module/constant.js.map +1 -1
  22. package/dist/module/enum.d.ts +1 -7
  23. package/dist/module/enum.d.ts.map +1 -1
  24. package/dist/module/enum.js +0 -6
  25. package/dist/module/enum.js.map +1 -1
  26. package/dist/module/history/{electrumTransformer.d.ts → getHistory.d.ts} +3 -3
  27. package/dist/module/history/getHistory.d.ts.map +1 -0
  28. package/dist/module/history/{electrumTransformer.js → getHistory.js} +17 -14
  29. package/dist/module/history/getHistory.js.map +1 -0
  30. package/dist/module/index.d.ts +3 -1
  31. package/dist/module/index.d.ts.map +1 -1
  32. package/dist/module/index.js +3 -1
  33. package/dist/module/index.js.map +1 -1
  34. package/dist/module/interface.d.ts +7 -2
  35. package/dist/module/interface.d.ts.map +1 -1
  36. package/dist/module/interface.js.map +1 -1
  37. package/dist/module/message/interface.d.ts +2 -2
  38. package/dist/module/message/interface.d.ts.map +1 -1
  39. package/dist/module/message/interface.js +0 -3
  40. package/dist/module/message/interface.js.map +1 -1
  41. package/dist/module/message/signed.d.ts +5 -5
  42. package/dist/module/message/signed.d.ts.map +1 -1
  43. package/dist/module/message/signed.js +8 -8
  44. package/dist/module/message/signed.js.map +1 -1
  45. package/dist/module/network/ElectrumNetworkProvider.d.ts +2 -2
  46. package/dist/module/network/ElectrumNetworkProvider.d.ts.map +1 -1
  47. package/dist/module/network/ElectrumNetworkProvider.js +3 -2
  48. package/dist/module/network/ElectrumNetworkProvider.js.map +1 -1
  49. package/dist/module/network/NetworkProvider.d.ts +2 -2
  50. package/dist/module/network/NetworkProvider.d.ts.map +1 -1
  51. package/dist/module/network/constant.js +4 -4
  52. package/dist/module/network/constant.js.map +1 -1
  53. package/dist/module/network/getRelayFeeCache.js +2 -2
  54. package/dist/module/network/getRelayFeeCache.js.map +1 -1
  55. package/dist/module/rate/ExchangeRate.d.ts +2 -1
  56. package/dist/module/rate/ExchangeRate.d.ts.map +1 -1
  57. package/dist/module/rate/ExchangeRate.js +4 -1
  58. package/dist/module/rate/ExchangeRate.js.map +1 -1
  59. package/dist/module/transaction/Wif.d.ts +25 -23
  60. package/dist/module/transaction/Wif.d.ts.map +1 -1
  61. package/dist/module/transaction/Wif.js +26 -25
  62. package/dist/module/transaction/Wif.js.map +1 -1
  63. package/dist/module/transaction/allocateFee.d.ts +3 -3
  64. package/dist/module/transaction/allocateFee.d.ts.map +1 -1
  65. package/dist/module/transaction/allocateFee.js +5 -6
  66. package/dist/module/transaction/allocateFee.js.map +1 -1
  67. package/dist/module/util/amountInSatoshi.d.ts +1 -1
  68. package/dist/module/util/amountInSatoshi.d.ts.map +1 -1
  69. package/dist/module/util/amountInSatoshi.js +3 -9
  70. package/dist/module/util/amountInSatoshi.js.map +1 -1
  71. package/dist/module/util/asSendRequestObject.d.ts.map +1 -1
  72. package/dist/module/util/asSendRequestObject.js +10 -7
  73. package/dist/module/util/asSendRequestObject.js.map +1 -1
  74. package/dist/module/util/checkUtxos.d.ts +2 -2
  75. package/dist/module/util/checkUtxos.d.ts.map +1 -1
  76. package/dist/module/util/checkUtxos.js +11 -12
  77. package/dist/module/util/checkUtxos.js.map +1 -1
  78. package/dist/module/util/convert.d.ts +3 -0
  79. package/dist/module/util/convert.d.ts.map +1 -1
  80. package/dist/module/util/convert.js +12 -0
  81. package/dist/module/util/convert.js.map +1 -1
  82. package/dist/module/util/deriveCashaddr.d.ts.map +1 -1
  83. package/dist/module/util/deriveCashaddr.js +6 -0
  84. package/dist/module/util/deriveCashaddr.js.map +1 -1
  85. package/dist/module/util/deriveNetwork.js +1 -1
  86. package/dist/module/util/deriveNetwork.js.map +1 -1
  87. package/dist/module/util/hd.d.ts +3 -0
  88. package/dist/module/util/hd.d.ts.map +1 -0
  89. package/dist/module/util/hd.js +11 -0
  90. package/dist/module/util/hd.js.map +1 -0
  91. package/dist/module/util/index.d.ts +3 -3
  92. package/dist/module/util/index.d.ts.map +1 -1
  93. package/dist/module/util/index.js +3 -3
  94. package/dist/module/util/index.js.map +1 -1
  95. package/dist/module/util/satoshiToAmount.d.ts +1 -1
  96. package/dist/module/util/satoshiToAmount.d.ts.map +1 -1
  97. package/dist/module/util/satoshiToAmount.js +3 -9
  98. package/dist/module/util/satoshiToAmount.js.map +1 -1
  99. package/dist/module/util/sumSendRequestAmounts.d.ts.map +1 -1
  100. package/dist/module/util/sumSendRequestAmounts.js +3 -4
  101. package/dist/module/util/sumSendRequestAmounts.js.map +1 -1
  102. package/dist/module/util/sumUtxoValue.d.ts +3 -3
  103. package/dist/module/util/sumUtxoValue.d.ts.map +1 -1
  104. package/dist/module/util/sumUtxoValue.js +2 -2
  105. package/dist/module/util/sumUtxoValue.js.map +1 -1
  106. package/dist/module/wallet/Base.d.ts +45 -103
  107. package/dist/module/wallet/Base.d.ts.map +1 -1
  108. package/dist/module/wallet/Base.js +99 -298
  109. package/dist/module/wallet/Base.js.map +1 -1
  110. package/dist/module/wallet/HDWallet.d.ts +164 -0
  111. package/dist/module/wallet/HDWallet.d.ts.map +1 -0
  112. package/dist/module/wallet/HDWallet.js +486 -0
  113. package/dist/module/wallet/HDWallet.js.map +1 -0
  114. package/dist/module/wallet/Util.js +1 -1
  115. package/dist/module/wallet/Util.js.map +1 -1
  116. package/dist/module/wallet/Watch.d.ts +151 -0
  117. package/dist/module/wallet/Watch.d.ts.map +1 -0
  118. package/dist/module/wallet/Watch.js +307 -0
  119. package/dist/module/wallet/Watch.js.map +1 -0
  120. package/dist/module/wallet/Wif.d.ts +23 -29
  121. package/dist/module/wallet/Wif.d.ts.map +1 -1
  122. package/dist/module/wallet/Wif.js +204 -267
  123. package/dist/module/wallet/Wif.js.map +1 -1
  124. package/dist/module/wallet/createWallet.d.ts +7 -1
  125. package/dist/module/wallet/createWallet.d.ts.map +1 -1
  126. package/dist/module/wallet/createWallet.js +26 -17
  127. package/dist/module/wallet/createWallet.js.map +1 -1
  128. package/dist/module/wallet/interface.d.ts +5 -6
  129. package/dist/module/wallet/interface.d.ts.map +1 -1
  130. package/dist/module/wallet/model.d.ts +15 -19
  131. package/dist/module/wallet/model.d.ts.map +1 -1
  132. package/dist/module/wallet/model.js +5 -25
  133. package/dist/module/wallet/model.js.map +1 -1
  134. package/dist/tsconfig.tsbuildinfo +1 -1
  135. package/package.json +1 -1
  136. package/src/cache/MemoryCache.ts +5 -5
  137. package/src/cache/index.ts +1 -0
  138. package/src/cache/walletCache.ts +239 -0
  139. package/src/chain.ts +1 -1
  140. package/src/constant.ts +1 -1
  141. package/src/enum.ts +0 -6
  142. package/src/history/{electrumTransformer.test.ts → getHistory.test.ts} +26 -53
  143. package/src/history/{electrumTransformer.ts → getHistory.ts} +31 -15
  144. package/src/index.ts +3 -1
  145. package/src/interface.ts +8 -2
  146. package/src/message/interface.ts +2 -28
  147. package/src/message/signed.test.ts +36 -48
  148. package/src/message/signed.ts +9 -12
  149. package/src/network/Connection.test.ts +3 -3
  150. package/src/network/ElectrumNetworkProvider.ts +5 -5
  151. package/src/network/NetworkProvider.ts +2 -2
  152. package/src/network/Rpc.test.ts +3 -4
  153. package/src/network/constant.ts +4 -4
  154. package/src/network/getRelayFeeCache.ts +2 -2
  155. package/src/rate/ExchangeRate.test.ts +2 -44
  156. package/src/rate/ExchangeRate.ts +5 -2
  157. package/src/transaction/Wif.ts +59 -52
  158. package/src/transaction/allocateFee.test.ts +110 -131
  159. package/src/transaction/allocateFee.ts +14 -15
  160. package/src/util/amountInSatoshi.test.ts +1 -9
  161. package/src/util/amountInSatoshi.ts +6 -10
  162. package/src/util/asSendRequestObject.ts +12 -7
  163. package/src/util/checkUtxos.ts +21 -26
  164. package/src/util/convert.ts +18 -0
  165. package/src/util/deriveCashaddr.ts +8 -0
  166. package/src/util/deriveNetwork.ts +1 -1
  167. package/src/util/derivePublicKeyHash.test.ts +0 -13
  168. package/src/util/hd.ts +16 -0
  169. package/src/util/index.ts +3 -7
  170. package/src/util/satoshiToAmount.test.ts +1 -1
  171. package/src/util/satoshiToAmount.ts +4 -10
  172. package/src/util/sumSendRequestAmounts.ts +3 -4
  173. package/src/util/sumUtxoValue.ts +7 -7
  174. package/src/wallet/Base.ts +147 -420
  175. package/src/wallet/Cashtokens.test.headless.js +11 -11
  176. package/src/wallet/Cashtokens.test.ts +36 -37
  177. package/src/wallet/HDWallet.test.ts +515 -0
  178. package/src/wallet/HDWallet.ts +764 -0
  179. package/src/wallet/Util.ts +1 -1
  180. package/src/wallet/Watch.ts +447 -0
  181. package/src/wallet/Wif.bip39.test.ts +1 -1
  182. package/src/wallet/Wif.test.ts +108 -133
  183. package/src/wallet/Wif.ts +258 -283
  184. package/src/wallet/createWallet.ts +28 -18
  185. package/src/wallet/interface.ts +5 -6
  186. package/src/wallet/model.test.ts +4 -7
  187. package/src/wallet/model.ts +19 -51
  188. package/dist/module/history/electrumTransformer.d.ts.map +0 -1
  189. package/dist/module/history/electrumTransformer.js.map +0 -1
  190. package/dist/module/util/balanceObjectFromSatoshi.d.ts +0 -8
  191. package/dist/module/util/balanceObjectFromSatoshi.d.ts.map +0 -1
  192. package/dist/module/util/balanceObjectFromSatoshi.js +0 -35
  193. package/dist/module/util/balanceObjectFromSatoshi.js.map +0 -1
  194. package/src/util/balanceObjectFromSatoshi.test.ts +0 -58
  195. package/src/util/balanceObjectFromSatoshi.ts +0 -52
@@ -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 { binToBase64, binToHex } from "@bitauth/libauth";
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 = await hash_message("test");
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 = await hash_message("测试");
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 = await SignedMessage.sign(msg1, w1.privateKey!);
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 = await SignedMessage.verify(msg1, sig.signature, w1.cashaddr!);
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 = await SignedMessage.verify(msg2, sig.signature, w1.cashaddr!);
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 = await SignedMessage.sign(msg, w.privateKey!);
77
- let result = await SignedMessage.verify(msg, sig.signature, w.cashaddr!);
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 = await SignedMessage.verify("test2", sig.signature, w.cashaddr!);
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 = await SignedMessage.sign(msg, w.privateKey!);
89
+ let sig = SignedMessage.sign(msg, w.privateKey!);
90
90
 
91
- let result = await SignedMessage.verify(msg, sig.signature, w.cashaddr!);
91
+ let result = SignedMessage.verify(msg, sig.signature, w.cashaddr!);
92
92
  expect(result.valid).toBe(true);
93
93
 
94
- result = await SignedMessage.verify("test2", sig.signature, w.cashaddr!);
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 = await SignedMessage.sign(msg, w.privateKey!);
104
- let result = await SignedMessage.verify(msg, sig.signature, w.cashaddr!);
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 = await SignedMessage.verify("测试二", sig.signature, w.cashaddr!);
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 = await SignedMessage.sign(msg, w.privateKey!);
117
- let result = await SignedMessage.verify(
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 = await SignedMessage.verify(
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 = await SignedMessage.sign(msg, w.privateKey!);
143
- let result = await SignedMessage.verify(
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 = await SignedMessage.sign(msg, w.privateKey!);
159
- let result = await SignedMessage.verify(
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 = await SignedMessage.verify(
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 = await SignedMessage.sign(msg, w.privateKey!);
185
- let result = await SignedMessage.verify(msg, sig.signature, w.cashaddr!);
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 = await Wallet.signedMessage.sign(msg1, w1.privateKey!);
198
- let result = await Wallet.signedMessage.verify(
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 = await Wallet.signedMessage.verify(
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 = await w1.sign(msg1);
225
- let result = await w1.verify(msg1, sig.signature);
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 = await w1.verify(msg2, sig.signature);
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 = await w1.verify(beak, beakSig);
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 = await w1.verify(falseMessage, beakSig);
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 = await SignedMessage.sign(msg1, w1.privateKey!);
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 = await SignedMessage.verify(msg1, sig.signature, w1.cashaddr!);
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 = await SignedMessage.verify(
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="
@@ -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 async function hash_message(str: string) {
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 async sign(
64
- message: string,
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 async sign(message: string, privateKey: Uint8Array) {
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 async verify(
112
+ public verify(
116
113
  message: string,
117
114
  signature: string,
118
115
  cashaddr?: string,
119
116
  publicKey?: Uint8Array
120
- ): Promise<VerifyMessageResponseI> {
117
+ ): VerifyMessageResponseI {
121
118
  // Check that the signature is valid for the given message.
122
- const messageHash = await hash_message(message);
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 = await hash160(recoveredPk);
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 async verify(
193
+ public static verify(
197
194
  message: string,
198
195
  signature: string,
199
196
  cashaddr?: string,
@@ -14,7 +14,7 @@ test("Should connect to mainnet", async () => {
14
14
 
15
15
  let wallet = await Wallet.newRandom();
16
16
  expect(wallet.provider == globalThis.BCH).toBeTruthy();
17
- expect(await wallet.getBalance("sat")).toBe(0);
17
+ expect(await wallet.getBalance()).toBe(0n);
18
18
 
19
19
  let height = await globalThis.BCH.getBlockHeight();
20
20
  expect(height).toBeGreaterThan(5000);
@@ -23,7 +23,7 @@ test("Should connect to mainnet", async () => {
23
23
  test("Should use global provider when creating testnet wallet", async () => {
24
24
  let wallet = await TestNetWallet.newRandom();
25
25
  expect(wallet.provider == globalThis.tBCH).toBeTruthy();
26
- expect(await wallet.getBalance("sat")).toBe(0);
26
+ expect(await wallet.getBalance()).toBe(0n);
27
27
 
28
28
  let height = await globalThis.tBCH.getBlockHeight();
29
29
  expect(height).toBeGreaterThan(114);
@@ -34,7 +34,7 @@ test.skip("Should lower overhead in creating wallets", async () => {
34
34
  for (let i = 0; i < 100; i++) {
35
35
  let wallet = await RegTestWallet.newRandom();
36
36
  expect(wallet.provider == globalThis.rBCH).toBeTruthy();
37
- expect(await wallet.getBalance("sat")).toBe(0);
37
+ expect(await wallet.getBalance()).toBe(0n);
38
38
  }
39
39
 
40
40
  let height = await globalThis.rBCH.getBlockHeight();
@@ -9,12 +9,11 @@ import { default as NetworkProvider } from "./NetworkProvider.js";
9
9
  import {
10
10
  HexHeaderI,
11
11
  TxI,
12
- UtxoI,
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 IndexedDbCache();
47
+ this._cache = new MemoryCache();
49
48
  return this._cache;
50
49
  }
51
50
 
@@ -77,16 +76,17 @@ export default class ElectrumNetworkProvider implements NetworkProvider {
77
76
  }
78
77
  }
79
78
 
80
- async getUtxos(cashaddr: string): Promise<UtxoI[]> {
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
- satoshis: utxo.value,
89
+ satoshis: BigInt(utxo.value),
90
90
  height: utxo.height,
91
91
  token: utxo.token_data
92
92
  ? {
@@ -1,4 +1,4 @@
1
- import { TxI, UtxoI, Network, HexHeaderI, HeaderI } from "../interface.js";
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<UtxoI[]>;
15
+ getUtxos(cashaddr: string): Promise<Utxo[]>;
16
16
 
17
17
  /**
18
18
  * Retrieve all balance of an address in satoshi
@@ -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
 
@@ -73,7 +73,7 @@ describe("Rpc tests", () => {
73
73
 
74
74
  let result = false;
75
75
  aliceWallet.watchBalance((balance) => {
76
- expect(balance.bch).toBeGreaterThan(0);
76
+ expect(balance).toBeGreaterThan(0);
77
77
  result = true;
78
78
  // stop watching
79
79
  return true;
@@ -105,8 +105,7 @@ describe("Rpc tests", () => {
105
105
  await aliceWallet.send([
106
106
  {
107
107
  cashaddr: bobWallet.cashaddr!,
108
- value: 1000,
109
- unit: "satoshis",
108
+ value: 1000n,
110
109
  },
111
110
  ]);
112
111
 
@@ -7,8 +7,8 @@ export const networkTickerMap = {
7
7
  };
8
8
 
9
9
  export const mainnetServers = [
10
- "wss://bch.imaginary.cash:50004",
11
- //"wss://blackie.c3-soft.com:50004",
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
- // "wss://chipnet.imaginary.cash:50004",
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"];
@@ -15,9 +15,9 @@ export async function getRelayFeeCache(provider: NetworkProvider) {
15
15
  relayFeePerKbInCoins;
16
16
  }
17
17
  if (typeof relayFeePerKbInCoins === "number") {
18
- return Math.round(relayFeePerKbInCoins * bchParam.subUnits) / 1000;
18
+ return Math.round(relayFeePerKbInCoins * Number(bchParam.subUnits)) / 1000;
19
19
  } else {
20
20
  console.warn("Couldn't get min relay fee, using default instead");
21
- return Math.round(0.00001 * bchParam.subUnits) / 1000;
21
+ return Math.round(0.00001 * Number(bchParam.subUnits)) / 1000;
22
22
  }
23
23
  }
@@ -1,8 +1,5 @@
1
- import { removeFetchMock, setupFetchMock } from "../test/fetch";
2
- import { BalanceResponse } from "../util/balanceObjectFromSatoshi";
3
- import { RegTestWallet } from "../wallet/Wif";
4
- import { ExchangeRate, getRateFromExchange } from "./ExchangeRate";
5
- import { delay } from "../util/delay";
1
+ import { setupFetchMock } from "../test/fetch";
2
+ import { ExchangeRate } from "./ExchangeRate";
6
3
  import { initProviders, disconnectProviders } from "../network";
7
4
  import { Config } from "../config";
8
5
 
@@ -25,45 +22,6 @@ describe("Exchange rate tests", () => {
25
22
  expect(rate).toBe(1337.42);
26
23
  });
27
24
 
28
- test("Test watchBalanceUsd", async () => {
29
- setupFetchMock("https://markets.api.bitcoin.com/live/bitcoin", {
30
- data: {
31
- BCH: 1337.42,
32
- },
33
- });
34
-
35
- const alice = await RegTestWallet.fromId(process.env.ALICE_ID!);
36
- const bob = await RegTestWallet.newRandom();
37
- const balance = (await alice.getBalance()) as BalanceResponse;
38
- let cbCounter = 0;
39
- const cancelWatchFn = await alice.watchBalanceUsd(async (newBalance) => {
40
- cbCounter++;
41
- if (cbCounter === 1) {
42
- expect(newBalance.usd!).toBeGreaterThan(balance.usd!);
43
- }
44
- }, 3000);
45
-
46
- setupFetchMock("https://markets.api.bitcoin.com/live/bitcoin", {
47
- data: {
48
- BCH: 31337.42,
49
- },
50
- });
51
-
52
- await delay(3000);
53
-
54
- await alice.send({
55
- cashaddr: bob.getDepositAddress(),
56
- value: 10000,
57
- unit: "sat",
58
- });
59
-
60
- await delay(3000);
61
-
62
- removeFetchMock("https://markets.api.bitcoin.com/live/bitcoin");
63
- expect(cbCounter).toBe(2);
64
- await cancelWatchFn();
65
- });
66
-
67
25
  test("Test other currencies", async () => {
68
26
  const eurRate = await ExchangeRate.get("eur");
69
27
  expect(eurRate).toBeGreaterThan(0);
@@ -42,7 +42,7 @@ export class ExchangeRate {
42
42
  }
43
43
 
44
44
  static async getRateFromLocalStorage(
45
- symbol,
45
+ symbol: string,
46
46
  useCache = true
47
47
  ): Promise<number> {
48
48
  if (!useCache) {
@@ -136,4 +136,7 @@ export async function getRateFromExchange(symbol: string): Promise<number> {
136
136
  }
137
137
 
138
138
  // do not await and do not throw in case we are offline
139
- ExchangeRate.get("usd").catch(() => {});
139
+ // this promise can be used to warm up the cache
140
+ export const ExchageRatePromise = ExchangeRate.get(Config.DefaultCurrency)
141
+ .then((result) => result)
142
+ .catch((error: Error) => error);