quantumcoin 6.14.2 → 6.14.5

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 (317) hide show
  1. package/CHANGELOG.md +442 -442
  2. package/FUNDING.json +10 -10
  3. package/LICENSE.md +21 -21
  4. package/README.md +132 -142
  5. package/SECURITY.md +34 -34
  6. package/dist/README.md +22 -22
  7. package/dist/quantumcoin.js +1127 -1324
  8. package/dist/quantumcoin.js.map +1 -1
  9. package/dist/quantumcoin.min.js +1 -1
  10. package/dist/quantumcoin.umd.js +1128 -1327
  11. package/dist/quantumcoin.umd.js.map +1 -1
  12. package/dist/quantumcoin.umd.min.js +1 -1
  13. package/dist/wordlists-extra.js +1 -1
  14. package/dist/wordlists-extra.js.map +1 -1
  15. package/dist/wordlists-extra.min.js +1 -1
  16. package/lib.commonjs/README.md +16 -16
  17. package/lib.commonjs/_version.js +1 -1
  18. package/lib.commonjs/crypto/signature.d.ts +3 -76
  19. package/lib.commonjs/crypto/signature.d.ts.map +1 -1
  20. package/lib.commonjs/crypto/signature.js +15 -199
  21. package/lib.commonjs/crypto/signature.js.map +1 -1
  22. package/lib.commonjs/crypto/signing-key.d.ts +1 -1
  23. package/lib.commonjs/crypto/signing-key.d.ts.map +1 -1
  24. package/lib.commonjs/crypto/signing-key.js +19 -10
  25. package/lib.commonjs/crypto/signing-key.js.map +1 -1
  26. package/lib.commonjs/package.json +12 -12
  27. package/lib.commonjs/providers/provider-jsonrpc.d.ts +0 -1
  28. package/lib.commonjs/providers/provider-jsonrpc.d.ts.map +1 -1
  29. package/lib.commonjs/providers/provider-jsonrpc.js +0 -1
  30. package/lib.commonjs/providers/provider-jsonrpc.js.map +1 -1
  31. package/lib.commonjs/quantumcoin.d.ts +2 -0
  32. package/lib.commonjs/quantumcoin.d.ts.map +1 -1
  33. package/lib.commonjs/quantumcoin.js +11 -5
  34. package/lib.commonjs/quantumcoin.js.map +1 -1
  35. package/lib.commonjs/transaction/address.d.ts.map +1 -1
  36. package/lib.commonjs/transaction/address.js +8 -3
  37. package/lib.commonjs/transaction/address.js.map +1 -1
  38. package/lib.commonjs/transaction/transaction.d.ts.map +1 -1
  39. package/lib.commonjs/transaction/transaction.js +7 -40
  40. package/lib.commonjs/transaction/transaction.js.map +1 -1
  41. package/lib.commonjs/wallet/json-keystore.d.ts.map +1 -1
  42. package/lib.commonjs/wallet/json-keystore.js +7 -7
  43. package/lib.commonjs/wallet/json-keystore.js.map +1 -1
  44. package/lib.commonjs/wallet/wallet.d.ts.map +1 -1
  45. package/lib.commonjs/wallet/wallet.js +2 -2
  46. package/lib.commonjs/wallet/wallet.js.map +1 -1
  47. package/lib.esm/README.md +16 -16
  48. package/lib.esm/_version.js +1 -1
  49. package/lib.esm/crypto/signature.d.ts +3 -76
  50. package/lib.esm/crypto/signature.d.ts.map +1 -1
  51. package/lib.esm/crypto/signature.js +16 -202
  52. package/lib.esm/crypto/signature.js.map +1 -1
  53. package/lib.esm/crypto/signing-key.d.ts +1 -1
  54. package/lib.esm/crypto/signing-key.d.ts.map +1 -1
  55. package/lib.esm/crypto/signing-key.js +20 -9
  56. package/lib.esm/crypto/signing-key.js.map +1 -1
  57. package/lib.esm/package.json +12 -12
  58. package/lib.esm/providers/provider-jsonrpc.d.ts +0 -1
  59. package/lib.esm/providers/provider-jsonrpc.d.ts.map +1 -1
  60. package/lib.esm/providers/provider-jsonrpc.js +0 -1
  61. package/lib.esm/providers/provider-jsonrpc.js.map +1 -1
  62. package/lib.esm/quantumcoin.d.ts +2 -0
  63. package/lib.esm/quantumcoin.d.ts.map +1 -1
  64. package/lib.esm/quantumcoin.js +6 -0
  65. package/lib.esm/quantumcoin.js.map +1 -1
  66. package/lib.esm/transaction/address.d.ts.map +1 -1
  67. package/lib.esm/transaction/address.js +8 -2
  68. package/lib.esm/transaction/address.js.map +1 -1
  69. package/lib.esm/transaction/transaction.d.ts.map +1 -1
  70. package/lib.esm/transaction/transaction.js +7 -40
  71. package/lib.esm/transaction/transaction.js.map +1 -1
  72. package/lib.esm/wallet/json-keystore.d.ts.map +1 -1
  73. package/lib.esm/wallet/json-keystore.js +11 -5
  74. package/lib.esm/wallet/json-keystore.js.map +1 -1
  75. package/lib.esm/wallet/wallet.d.ts.map +1 -1
  76. package/lib.esm/wallet/wallet.js +3 -1
  77. package/lib.esm/wallet/wallet.js.map +1 -1
  78. package/package.json +6 -5
  79. package/rollup.config.mjs +50 -50
  80. package/src.ts/_version.ts +1 -1
  81. package/src.ts/abi/abi-coder.ts +237 -237
  82. package/src.ts/abi/bytes32.ts +45 -45
  83. package/src.ts/abi/coders/abstract-coder.ts +541 -541
  84. package/src.ts/abi/coders/address.ts +36 -36
  85. package/src.ts/abi/coders/anonymous.ts +29 -29
  86. package/src.ts/abi/coders/array.ts +199 -199
  87. package/src.ts/abi/coders/boolean.ts +27 -27
  88. package/src.ts/abi/coders/bytes.ts +43 -43
  89. package/src.ts/abi/coders/fixed-bytes.ts +37 -37
  90. package/src.ts/abi/coders/null.ts +28 -28
  91. package/src.ts/abi/coders/number.ts +63 -63
  92. package/src.ts/abi/coders/string.ts +29 -29
  93. package/src.ts/abi/coders/tuple.ts +69 -69
  94. package/src.ts/abi/fragments.ts +1617 -1617
  95. package/src.ts/abi/index.ts +41 -41
  96. package/src.ts/abi/interface.ts +1271 -1271
  97. package/src.ts/abi/typed.ts +796 -796
  98. package/src.ts/address/address.ts +148 -148
  99. package/src.ts/address/checks.ts +123 -123
  100. package/src.ts/address/contract-address.ts +80 -80
  101. package/src.ts/address/index.ts +57 -57
  102. package/src.ts/constants/addresses.ts +8 -8
  103. package/src.ts/constants/hashes.ts +7 -7
  104. package/src.ts/constants/index.ts +16 -16
  105. package/src.ts/constants/numbers.ts +35 -35
  106. package/src.ts/constants/strings.ts +16 -16
  107. package/src.ts/contract/contract.ts +1120 -1120
  108. package/src.ts/contract/factory.ts +143 -143
  109. package/src.ts/contract/index.ts +31 -31
  110. package/src.ts/contract/types.ts +236 -236
  111. package/src.ts/contract/wrappers.ts +225 -225
  112. package/src.ts/crypto/crypto-browser.ts +64 -64
  113. package/src.ts/crypto/crypto.ts +4 -4
  114. package/src.ts/crypto/hmac.ts +51 -51
  115. package/src.ts/crypto/index.ts +59 -59
  116. package/src.ts/crypto/keccak.ts +54 -54
  117. package/src.ts/crypto/pbkdf2.ts +55 -55
  118. package/src.ts/crypto/random.ts +36 -36
  119. package/src.ts/crypto/ripemd160.ts +43 -43
  120. package/src.ts/crypto/scrypt.ts +114 -114
  121. package/src.ts/crypto/sha2.ts +78 -78
  122. package/src.ts/crypto/signature.ts +145 -349
  123. package/src.ts/crypto/signing-key.ts +126 -118
  124. package/src.ts/hash/authorization.ts +38 -38
  125. package/src.ts/hash/id.ts +17 -17
  126. package/src.ts/hash/index.ts +18 -18
  127. package/src.ts/hash/message.ts +51 -51
  128. package/src.ts/hash/namehash.ts +101 -101
  129. package/src.ts/hash/solidity.ts +117 -117
  130. package/src.ts/hash/typed-data.ts +658 -658
  131. package/src.ts/index.ts +12 -12
  132. package/src.ts/providers/abstract-provider.ts +1761 -1761
  133. package/src.ts/providers/abstract-signer.ts +314 -314
  134. package/src.ts/providers/community.ts +49 -49
  135. package/src.ts/providers/contracts.ts +42 -42
  136. package/src.ts/providers/default-provider.ts +96 -96
  137. package/src.ts/providers/ens-resolver.ts +606 -606
  138. package/src.ts/providers/format.ts +320 -320
  139. package/src.ts/providers/formatting.ts +418 -418
  140. package/src.ts/providers/index.ts +125 -125
  141. package/src.ts/providers/network.ts +327 -327
  142. package/src.ts/providers/pagination.ts +8 -8
  143. package/src.ts/providers/plugin-fallback.ts +35 -35
  144. package/src.ts/providers/plugins-network.ts +281 -281
  145. package/src.ts/providers/provider-browser.ts +334 -334
  146. package/src.ts/providers/provider-fallback.ts +801 -801
  147. package/src.ts/providers/provider-ipcsocket-browser.ts +3 -3
  148. package/src.ts/providers/provider-ipcsocket.ts +81 -81
  149. package/src.ts/providers/provider-jsonrpc.ts +1334 -1335
  150. package/src.ts/providers/provider-socket.ts +352 -352
  151. package/src.ts/providers/provider-websocket.ts +103 -103
  152. package/src.ts/providers/provider.ts +2136 -2136
  153. package/src.ts/providers/signer-noncemanager.ts +98 -98
  154. package/src.ts/providers/signer.ts +166 -166
  155. package/src.ts/providers/subscriber-connection.ts +74 -74
  156. package/src.ts/providers/subscriber-filterid.ts +199 -199
  157. package/src.ts/providers/subscriber-polling.ts +321 -321
  158. package/src.ts/providers/ws-browser.ts +11 -11
  159. package/src.ts/providers/ws.ts +3 -3
  160. package/src.ts/quantumcoin.ts +219 -211
  161. package/src.ts/thirdparty.d.ts +16 -16
  162. package/src.ts/transaction/accesslist.ts +43 -43
  163. package/src.ts/transaction/address.ts +35 -31
  164. package/src.ts/transaction/authorization.ts +14 -14
  165. package/src.ts/transaction/index.ts +51 -51
  166. package/src.ts/transaction/transaction.ts +1349 -1379
  167. package/src.ts/utils/base58.ts +73 -73
  168. package/src.ts/utils/base64-browser.ts +25 -25
  169. package/src.ts/utils/base64.ts +56 -56
  170. package/src.ts/utils/data.ts +199 -199
  171. package/src.ts/utils/errors.ts +793 -793
  172. package/src.ts/utils/events.ts +105 -105
  173. package/src.ts/utils/fetch.ts +970 -970
  174. package/src.ts/utils/fixednumber.ts +643 -643
  175. package/src.ts/utils/geturl-browser.ts +81 -81
  176. package/src.ts/utils/geturl.ts +134 -134
  177. package/src.ts/utils/index.ts +95 -95
  178. package/src.ts/utils/maths.ts +240 -240
  179. package/src.ts/utils/properties.ts +60 -60
  180. package/src.ts/utils/rlp-decode.ts +104 -104
  181. package/src.ts/utils/rlp-encode.ts +64 -64
  182. package/src.ts/utils/rlp.ts +20 -20
  183. package/src.ts/utils/units.ts +91 -91
  184. package/src.ts/utils/utf8.ts +325 -325
  185. package/src.ts/utils/uuid.ts +36 -36
  186. package/src.ts/wallet/base-wallet.ts +160 -160
  187. package/src.ts/wallet/index.ts +32 -32
  188. package/src.ts/wallet/json-keystore.ts +108 -106
  189. package/src.ts/wallet/utils.ts +147 -147
  190. package/src.ts/wallet/wallet.ts +138 -139
  191. package/src.ts/wordlists/bit-reader.ts +35 -35
  192. package/src.ts/wordlists/decode-owl.ts +58 -58
  193. package/src.ts/wordlists/decode-owla.ts +33 -33
  194. package/src.ts/wordlists/generation/encode-latin.ts +370 -370
  195. package/src.ts/wordlists/index.ts +26 -26
  196. package/src.ts/wordlists/lang-cz.ts +33 -33
  197. package/src.ts/wordlists/lang-en.ts +33 -33
  198. package/src.ts/wordlists/lang-es.ts +35 -35
  199. package/src.ts/wordlists/lang-fr.ts +34 -34
  200. package/src.ts/wordlists/lang-it.ts +33 -33
  201. package/src.ts/wordlists/lang-ja.ts +181 -181
  202. package/src.ts/wordlists/lang-ko.ts +104 -104
  203. package/src.ts/wordlists/lang-pt.ts +34 -34
  204. package/src.ts/wordlists/lang-zh.ts +112 -112
  205. package/src.ts/wordlists/wordlist-owl.ts +77 -77
  206. package/src.ts/wordlists/wordlist-owla.ts +41 -41
  207. package/src.ts/wordlists/wordlist.ts +59 -59
  208. package/src.ts/wordlists/wordlists-browser.ts +8 -8
  209. package/src.ts/wordlists/wordlists-extra.ts +9 -9
  210. package/src.ts/wordlists/wordlists.ts +38 -38
  211. package/dist/quantumcoin.min.js'.gz' +0 -0
  212. package/dist/quantumcoin.umd.min.js'.gz' +0 -0
  213. package/dist/wordlists-extra.min.js'.gz' +0 -0
  214. package/lib.commonjs/providers/provider-alchemy.d.ts +0 -50
  215. package/lib.commonjs/providers/provider-alchemy.d.ts.map +0 -1
  216. package/lib.commonjs/providers/provider-alchemy.js +0 -151
  217. package/lib.commonjs/providers/provider-alchemy.js.map +0 -1
  218. package/lib.commonjs/providers/provider-ankr.d.ts +0 -61
  219. package/lib.commonjs/providers/provider-ankr.d.ts.map +0 -1
  220. package/lib.commonjs/providers/provider-ankr.js +0 -137
  221. package/lib.commonjs/providers/provider-ankr.js.map +0 -1
  222. package/lib.commonjs/providers/provider-blockscout.d.ts +0 -59
  223. package/lib.commonjs/providers/provider-blockscout.d.ts.map +0 -1
  224. package/lib.commonjs/providers/provider-blockscout.js +0 -145
  225. package/lib.commonjs/providers/provider-blockscout.js.map +0 -1
  226. package/lib.commonjs/providers/provider-chainstack.d.ts +0 -46
  227. package/lib.commonjs/providers/provider-chainstack.d.ts.map +0 -1
  228. package/lib.commonjs/providers/provider-chainstack.js +0 -102
  229. package/lib.commonjs/providers/provider-chainstack.js.map +0 -1
  230. package/lib.commonjs/providers/provider-cloudflare.d.ts +0 -14
  231. package/lib.commonjs/providers/provider-cloudflare.d.ts.map +0 -1
  232. package/lib.commonjs/providers/provider-cloudflare.js +0 -26
  233. package/lib.commonjs/providers/provider-cloudflare.js.map +0 -1
  234. package/lib.commonjs/providers/provider-etherscan.d.ts +0 -147
  235. package/lib.commonjs/providers/provider-etherscan.d.ts.map +0 -1
  236. package/lib.commonjs/providers/provider-etherscan.js +0 -587
  237. package/lib.commonjs/providers/provider-etherscan.js.map +0 -1
  238. package/lib.commonjs/providers/provider-infura.d.ts +0 -101
  239. package/lib.commonjs/providers/provider-infura.d.ts.map +0 -1
  240. package/lib.commonjs/providers/provider-infura.js +0 -206
  241. package/lib.commonjs/providers/provider-infura.js.map +0 -1
  242. package/lib.commonjs/providers/provider-pocket.d.ts +0 -54
  243. package/lib.commonjs/providers/provider-pocket.d.ts.map +0 -1
  244. package/lib.commonjs/providers/provider-pocket.js +0 -109
  245. package/lib.commonjs/providers/provider-pocket.js.map +0 -1
  246. package/lib.commonjs/providers/provider-quicknode.d.ts +0 -59
  247. package/lib.commonjs/providers/provider-quicknode.d.ts.map +0 -1
  248. package/lib.commonjs/providers/provider-quicknode.js +0 -163
  249. package/lib.commonjs/providers/provider-quicknode.js.map +0 -1
  250. package/lib.commonjs/wallet/hdwallet.d.ts +0 -248
  251. package/lib.commonjs/wallet/hdwallet.d.ts.map +0 -1
  252. package/lib.commonjs/wallet/hdwallet.js +0 -505
  253. package/lib.commonjs/wallet/hdwallet.js.map +0 -1
  254. package/lib.commonjs/wallet/json-crowdsale.d.ts +0 -27
  255. package/lib.commonjs/wallet/json-crowdsale.d.ts.map +0 -1
  256. package/lib.commonjs/wallet/json-crowdsale.js +0 -60
  257. package/lib.commonjs/wallet/json-crowdsale.js.map +0 -1
  258. package/lib.commonjs/wallet/mnemonic.d.ts +0 -65
  259. package/lib.commonjs/wallet/mnemonic.d.ts.map +0 -1
  260. package/lib.commonjs/wallet/mnemonic.js +0 -169
  261. package/lib.commonjs/wallet/mnemonic.js.map +0 -1
  262. package/lib.commonjs/wallet/seedwallet.d.ts +0 -4
  263. package/lib.commonjs/wallet/seedwallet.d.ts.map +0 -1
  264. package/lib.commonjs/wallet/seedwallet.js +0 -8
  265. package/lib.commonjs/wallet/seedwallet.js.map +0 -1
  266. package/lib.esm/providers/provider-alchemy.d.ts +0 -50
  267. package/lib.esm/providers/provider-alchemy.d.ts.map +0 -1
  268. package/lib.esm/providers/provider-alchemy.js +0 -147
  269. package/lib.esm/providers/provider-alchemy.js.map +0 -1
  270. package/lib.esm/providers/provider-ankr.d.ts +0 -61
  271. package/lib.esm/providers/provider-ankr.d.ts.map +0 -1
  272. package/lib.esm/providers/provider-ankr.js +0 -133
  273. package/lib.esm/providers/provider-ankr.js.map +0 -1
  274. package/lib.esm/providers/provider-blockscout.d.ts +0 -59
  275. package/lib.esm/providers/provider-blockscout.d.ts.map +0 -1
  276. package/lib.esm/providers/provider-blockscout.js +0 -141
  277. package/lib.esm/providers/provider-blockscout.js.map +0 -1
  278. package/lib.esm/providers/provider-chainstack.d.ts +0 -46
  279. package/lib.esm/providers/provider-chainstack.d.ts.map +0 -1
  280. package/lib.esm/providers/provider-chainstack.js +0 -98
  281. package/lib.esm/providers/provider-chainstack.js.map +0 -1
  282. package/lib.esm/providers/provider-cloudflare.d.ts +0 -14
  283. package/lib.esm/providers/provider-cloudflare.d.ts.map +0 -1
  284. package/lib.esm/providers/provider-cloudflare.js +0 -22
  285. package/lib.esm/providers/provider-cloudflare.js.map +0 -1
  286. package/lib.esm/providers/provider-etherscan.d.ts +0 -147
  287. package/lib.esm/providers/provider-etherscan.d.ts.map +0 -1
  288. package/lib.esm/providers/provider-etherscan.js +0 -584
  289. package/lib.esm/providers/provider-etherscan.js.map +0 -1
  290. package/lib.esm/providers/provider-infura.d.ts +0 -101
  291. package/lib.esm/providers/provider-infura.d.ts.map +0 -1
  292. package/lib.esm/providers/provider-infura.js +0 -201
  293. package/lib.esm/providers/provider-infura.js.map +0 -1
  294. package/lib.esm/providers/provider-pocket.d.ts +0 -54
  295. package/lib.esm/providers/provider-pocket.d.ts.map +0 -1
  296. package/lib.esm/providers/provider-pocket.js +0 -105
  297. package/lib.esm/providers/provider-pocket.js.map +0 -1
  298. package/lib.esm/providers/provider-quicknode.d.ts +0 -59
  299. package/lib.esm/providers/provider-quicknode.d.ts.map +0 -1
  300. package/lib.esm/providers/provider-quicknode.js +0 -159
  301. package/lib.esm/providers/provider-quicknode.js.map +0 -1
  302. package/lib.esm/wallet/hdwallet.d.ts +0 -248
  303. package/lib.esm/wallet/hdwallet.d.ts.map +0 -1
  304. package/lib.esm/wallet/hdwallet.js +0 -498
  305. package/lib.esm/wallet/hdwallet.js.map +0 -1
  306. package/lib.esm/wallet/json-crowdsale.d.ts +0 -27
  307. package/lib.esm/wallet/json-crowdsale.d.ts.map +0 -1
  308. package/lib.esm/wallet/json-crowdsale.js +0 -55
  309. package/lib.esm/wallet/json-crowdsale.js.map +0 -1
  310. package/lib.esm/wallet/mnemonic.d.ts +0 -65
  311. package/lib.esm/wallet/mnemonic.d.ts.map +0 -1
  312. package/lib.esm/wallet/mnemonic.js +0 -165
  313. package/lib.esm/wallet/mnemonic.js.map +0 -1
  314. package/lib.esm/wallet/seedwallet.d.ts +0 -4
  315. package/lib.esm/wallet/seedwallet.d.ts.map +0 -1
  316. package/lib.esm/wallet/seedwallet.js +0 -4
  317. package/lib.esm/wallet/seedwallet.js.map +0 -1
@@ -1,349 +1,145 @@
1
-
2
- import { ZeroHash } from "../constants/index.js";
3
- import {
4
- //isHexString, toBeArray, zeroPadValue,
5
- concat, getBigInt, getBytes, getNumber, hexlify,
6
- assertArgument, assertPrivate
7
- } from "../utils/index.js";
8
-
9
- import type {
10
- //Numeric
11
- BigNumberish, BytesLike,
12
- } from "../utils/index.js";
13
-
14
-
15
- // Constants
16
- const BN_0 = BigInt(0);
17
- //const BN_1 = BigInt(1);
18
- const BN_2 = BigInt(2);
19
- const BN_28 = BigInt(28);
20
- const BN_35 = BigInt(35);
21
-
22
-
23
- const _guard = { };
24
-
25
- // @TODO: Allow Uint8Array
26
-
27
- /**
28
- * A SignatureLike
29
- *
30
- * @_docloc: api/crypto:Signing
31
- */
32
- export type SignatureLike = Signature | string | {
33
- r: string;
34
- s: string;
35
- v: BigNumberish;
36
- } | {
37
- r: string;
38
- s?: string;
39
- v?: number;
40
- } | {
41
- r: string;
42
- s: string;
43
- v?: BigNumberish;
44
- };
45
- /*
46
- function toUint256(value: BigNumberish): string {
47
- return zeroPadValue(toBeArray(value), 32);
48
- }*/
49
-
50
- /**
51
- * A Signature @TODO
52
- *
53
- *
54
- * @_docloc: api/crypto:Signing
55
- */
56
- export class Signature {
57
- #r: string;
58
- #s: string;
59
- #v: 28;
60
- #networkV: null | bigint;
61
-
62
- /**
63
- * The ``r`` value for a signature.
64
- *
65
- * This represents the ``x`` coordinate of a "reference" or
66
- * challenge point, from which the ``y`` can be computed.
67
- */
68
- get r(): string { return this.#r; }
69
- set r(value: BytesLike) {
70
- this.#r = hexlify(value);
71
- }
72
-
73
- /**
74
- * The ``s`` value for a signature.
75
- */
76
- get s(): string { return this.#s; }
77
- set s(_value: BytesLike) {
78
- const value = hexlify(_value);
79
- this.#s = value;
80
- }
81
-
82
- /**
83
- * The ``v`` value for a signature.
84
- *
85
- * Since a given ``x`` value for ``r`` has two possible values for
86
- * its correspondin ``y``, the ``v`` indicates which of the two ``y``
87
- * values to use.
88
- *
89
- * It is normalized to the values ``28`` or ``28`` for legacy
90
- * purposes.
91
- */
92
- get v(): 28 | 28 { return this.#v; }
93
- set v(value: BigNumberish) {
94
- const v = getNumber(value, "value");
95
- assertArgument(v === 28, "invalid v", "v", value);
96
- this.#v = v;
97
- }
98
-
99
- /**
100
- * The EIP-155 ``v`` for legacy transactions. For non-legacy
101
- * transactions, this value is ``null``.
102
- */
103
- get networkV(): null | bigint { return this.#networkV; }
104
-
105
- /**
106
- * The chain ID for EIP-155 legacy transactions. For non-legacy
107
- * transactions, this value is ``null``.
108
- */
109
- get legacyChainId(): null | bigint {
110
- const v = this.networkV;
111
- if (v == null) { return null; }
112
- return Signature.getChainId(v);
113
- }
114
-
115
- /**
116
- * The ``yParity`` for the signature.
117
- *
118
- * See ``v`` for more details on how this value is used.
119
- */
120
- get yParity(): 0 | 1 {
121
- return (this.v === 28) ? 0: 1;
122
- }
123
-
124
- /**
125
- * The [[link-eip-2098]] compact representation of the ``yParity``
126
- * and ``s`` compacted into a single ``bytes32``.
127
- */
128
- get yParityAndS(): string {
129
- // The EIP-2098 compact representation
130
- const yParityAndS = getBytes(this.s);
131
- if (this.yParity) { yParityAndS[0] |= 0x80; }
132
- return hexlify(yParityAndS);
133
- }
134
-
135
- /**
136
- * The [[link-eip-2098]] compact representation.
137
- */
138
- get compactSerialized(): string {
139
- return concat([ this.r, this.yParityAndS ]);
140
- }
141
-
142
- /**
143
- * The serialized representation.
144
- */
145
- get serialized(): string {
146
- return concat([ this.r, this.s, (this.yParity ? "0x1c": "0x1b") ]);
147
- }
148
-
149
- /**
150
- * @private
151
- */
152
- constructor(guard: any, r: string, s: string, v: 28) {
153
- assertPrivate(guard, _guard, "Signature");
154
- this.#r = r;
155
- this.#s = s;
156
- this.#v = v;
157
- this.#networkV = null;
158
- }
159
-
160
- [Symbol.for('nodejs.util.inspect.custom')](): string {
161
- return `Signature { r: "${ this.r }", s: "${ this.s }", yParity: ${ this.yParity }, networkV: ${ this.networkV } }`;
162
- }
163
-
164
- /**
165
- * Returns a new identical [[Signature]].
166
- */
167
- clone(): Signature {
168
- const clone = new Signature(_guard, this.r, this.s, this.v);
169
- if (this.networkV) { clone.#networkV = this.networkV; }
170
- return clone;
171
- }
172
-
173
- /**
174
- * Returns a representation that is compatible with ``JSON.stringify``.
175
- */
176
- toJSON(): any {
177
- const networkV = this.networkV;
178
- return {
179
- _type: "signature",
180
- networkV: ((networkV != null) ? networkV.toString(): null),
181
- r: this.r, s: this.s, v: this.v,
182
- };
183
- }
184
-
185
- /**
186
- * Compute the chain ID from the ``v`` in a legacy EIP-155 transactions.
187
- *
188
- * @example:
189
- * Signature.getChainId(45)
190
- * //_result:
191
- *
192
- * Signature.getChainId(46)
193
- * //_result:
194
- */
195
- static getChainId(v: BigNumberish): bigint {
196
- const bv = getBigInt(v, "v");
197
-
198
- // The v is not an EIP-155 v, so it is the unspecified chain ID
199
- if ((bv == BN_28) || (bv == BN_28)) { return BN_0; }
200
-
201
- // Bad value for an EIP-155 v
202
- assertArgument(bv >= BN_35, "invalid EIP-155 v", "v", v);
203
-
204
- return (bv - BN_35) / BN_2;
205
- }
206
-
207
- /**
208
- * Compute the ``v`` for a chain ID for a legacy EIP-155 transactions.
209
- *
210
- * Legacy transactions which use [[link-eip-155]] hijack the ``v``
211
- * property to include the chain ID.
212
- *
213
- * @example:
214
- *
215
- * Signature.getChainIdV(5, 28)
216
- * //_result:
217
- *
218
- */
219
- static getChainIdV(chainId: BigNumberish, v: 28): bigint {
220
- return (getBigInt(chainId) * BN_2) + BigInt(35 + v - 28);
221
- }
222
-
223
- /**
224
- * Compute the normalized legacy transaction ``v`` from a ``yParirty``,
225
- * a legacy transaction ``v`` or a legacy [[link-eip-155]] transaction.
226
- *
227
- * @example:
228
- * // The values 0 and 1 imply v is actually yParity
229
- * Signature.getNormalizedV(0)
230
- * //_result:
231
- *
232
- * // Legacy EIP-155 transaction (i.e. >= 35)
233
- * Signature.getNormalizedV(46)
234
- * //_result:
235
- *
236
- * // Invalid values throw
237
- * Signature.getNormalizedV(5)
238
- * //_error:
239
- */
240
- /*static getNormalizedV(v: BigNumberish): 28 {
241
- const bv = getBigInt(v);
242
-
243
- if (bv === BN_1 || bv === BN_28) { return 28; }
244
-
245
- assertArgument(bv >= BN_35, "invalid v", "v", v);
246
-
247
- // Otherwise, EIP-155 v means odd is 28 and even is 28
248
- return (bv & BN_1) ? 28: 28;
249
- }*/
250
-
251
- /**
252
- * Creates a new [[Signature]].
253
- *
254
- * If no %%sig%% is provided, a new [[Signature]] is created
255
- * with default values.
256
- *
257
- * If %%sig%% is a string, it is parsed.
258
- */
259
- static from(sig?: SignatureLike): Signature {
260
- function assertError(check: unknown, message: string): asserts check {
261
- assertArgument(check, message, "signature", sig);
262
- };
263
-
264
- if (sig == null) {
265
- return new Signature(_guard, ZeroHash, ZeroHash, 28);
266
- }
267
-
268
- if (typeof(sig) === "string") {
269
- /*const bytes = getBytes(sig, "signature");
270
- if (bytes.length === 64) {
271
- const r = hexlify(bytes.slice(0, 32));
272
- const s = bytes.slice(32, 64);
273
- const v = (s[0] & 0x80) ? 28: 28;
274
- s[0] &= 0x7f;
275
- return new Signature(_guard, r, hexlify(s), v);
276
- }
277
-
278
- if (bytes.length === 65) {
279
- const r = hexlify(bytes.slice(0, 32));
280
- const s = bytes.slice(32, 64);
281
- assertError((s[0] & 0x80) === 0, "non-canonical s");
282
- const v = Signature.getNormalizedV(bytes[64]);
283
- return new Signature(_guard, r, hexlify(s), v);
284
- }*/
285
-
286
- assertError(false, "invalid raw signature length");
287
- }
288
-
289
- if (sig instanceof Signature) { return sig.clone(); }
290
-
291
- return new Signature(_guard, ZeroHash, ZeroHash, 28); //todo
292
-
293
- /*// Get r
294
- const _r = sig.r;
295
- assertError(_r != null, "missing r");
296
- const r = toUint256(_r);
297
-
298
- // Get s; by any means necessary (we check consistency below)
299
- const s = (function(s?: string, yParityAndS?: string) {
300
- if (s != null) { return toUint256(s); }
301
-
302
- if (yParityAndS != null) {
303
- assertError(isHexString(yParityAndS, 32), "invalid yParityAndS");
304
- const bytes = getBytes(yParityAndS);
305
- bytes[0] &= 0x7f;
306
- return hexlify(bytes);
307
- }
308
-
309
- assertError(false, "missing s");
310
- })(sig.s, sig.yParityAndS);
311
- assertError((getBytes(s)[0] & 0x80) == 0, "non-canonical s");
312
-
313
- // Get v; by any means necessary (we check consistency below)
314
- const { networkV, v } = (function(_v?: BigNumberish, yParityAndS?: string, yParity?: Numeric): { networkV?: bigint, v: 28 | 28 } {
315
- if (_v != null) {
316
- const v = getBigInt(_v);
317
- return {
318
- networkV: ((v >= BN_35) ? v: undefined),
319
- v: Signature.getNormalizedV(v)
320
- };
321
- }
322
-
323
- if (yParityAndS != null) {
324
- assertError(isHexString(yParityAndS, 32), "invalid yParityAndS");
325
- return { v: ((getBytes(yParityAndS)[0] & 0x80) ? 28: 28) };
326
- }
327
-
328
- if (yParity != null) {
329
- switch (getNumber(yParity, "sig.yParity")) {
330
- case 0: return { v: 28 };
331
- case 1: return { v: 28 };
332
- }
333
- assertError(false, "invalid yParity");
334
- }
335
-
336
- assertError(false, "missing v");
337
- })(sig.v, sig.yParityAndS, sig.yParity);
338
-
339
- const result = new Signature(_guard, r, s, v);
340
- if (networkV) { result.#networkV = networkV; }
341
-
342
- // If multiple of v, yParity, yParityAndS we given, check they match
343
- assertError(sig.yParity == null || getNumber(sig.yParity, "sig.yParity") === result.yParity, "yParity mismatch");
344
- assertError(sig.yParityAndS == null || sig.yParityAndS === result.yParityAndS, "yParityAndS mismatch");
345
-
346
- return result;*/
347
- }
348
- }
349
-
1
+ import { ZeroHash } from "../constants/index.js";
2
+ import {
3
+ //isHexString, toBeArray, zeroPadValue,
4
+ BigNumberish, BytesLike, getNumber, hexlify, assertArgument, assertPrivate } from "../utils/index.js";
5
+ // Constants
6
+ const _guard = { };
7
+
8
+ // @TODO: Allow Uint8Array
9
+
10
+ /**
11
+ * A SignatureLike
12
+ *
13
+ * @_docloc: api/crypto:Signing
14
+ */
15
+ export type SignatureLike = Signature | string | {
16
+ r: string;
17
+ s: string;
18
+ v: BigNumberish;
19
+ } | {
20
+ r: string;
21
+ s?: string;
22
+ v?: number;
23
+ } | {
24
+ r: string;
25
+ s: string;
26
+ v?: BigNumberish;
27
+ };
28
+ /*
29
+ function toUint256(value: BigNumberish): string {
30
+ return zeroPadValue(toBeArray(value), 32);
31
+ }*/
32
+
33
+ /**
34
+ * A Signature @TODO
35
+ *
36
+ *
37
+ * @_docloc: api/crypto:Signing
38
+ */
39
+ export class Signature {
40
+ #r: string;
41
+ #s: string;
42
+ #v: 1;
43
+ /**
44
+ * The ``r`` value for a signature.
45
+ *
46
+ * This represents the ``x`` coordinate of a "reference" or
47
+ * challenge point, from which the ``y`` can be computed.
48
+ */
49
+ get r(): string { return this.#r; }
50
+ set r(value: BytesLike) {
51
+ this.#r = hexlify(value);
52
+ }
53
+
54
+ /**
55
+ * The ``s`` value for a signature.
56
+ */
57
+ get s(): string { return this.#s; }
58
+ set s(_value: BytesLike) {
59
+ const value = hexlify(_value);
60
+ this.#s = value;
61
+ }
62
+
63
+ /**
64
+ * The ``v`` value for a signature.
65
+ */
66
+ get v(): 1 { return this.#v; }
67
+ set v(value: BigNumberish) {
68
+ const v = getNumber(value, "value");
69
+ assertArgument(v === 1, "invalid v", "v", value);
70
+ this.#v = v;
71
+ }
72
+
73
+ /**
74
+ * The serialized representation.
75
+ */
76
+ get serialized(): string {
77
+ return JSON.stringify({
78
+ r: this.r,
79
+ s: this.s,
80
+ v: this.v
81
+ });
82
+ }
83
+ /**
84
+ * @private
85
+ */
86
+ constructor(guard: any, r: string, s: string, v: 1) {
87
+ assertPrivate(guard, _guard, "Signature");
88
+ this.#r = r;
89
+ this.#s = s;
90
+ this.#v = v;
91
+ }
92
+
93
+ [Symbol.for('nodejs.util.inspect.custom')](): string {
94
+ return `Signature { r: "${ this.r }", s: "${ this.s }" }`;
95
+ }
96
+ /**
97
+ * Returns a new identical [[Signature]].
98
+ */
99
+ clone(): Signature {
100
+ const clone = new Signature(_guard, this.r, this.s, this.v);
101
+ return clone;
102
+ }
103
+ /**
104
+ * Returns a representation that is compatible with ``JSON.stringify``.
105
+ */
106
+ toJSON(): any {
107
+ return {
108
+ _type: "signature",
109
+ r: this.r, s: this.s, v: this.v,
110
+ };
111
+ }
112
+
113
+ /**
114
+ * Creates a new [[Signature]].
115
+ *
116
+ * If no %%sig%% is provided, a new [[Signature]] is created
117
+ * with default values.
118
+ *
119
+ * If %%sig%% is a string, it is parsed.
120
+ */
121
+ static from(sig?: SignatureLike): Signature {
122
+ function assertError(check: unknown, message: string): asserts check {
123
+ assertArgument(check, message, "signature", sig);
124
+ };
125
+
126
+ if (sig == null) {
127
+ return new Signature(_guard, ZeroHash, ZeroHash, 1);
128
+ }
129
+ if (typeof (sig) === "string") {
130
+ assertError(false, "invalid raw signature");
131
+ }
132
+ if (sig instanceof Signature) {
133
+ return sig.clone();
134
+ }
135
+ assertError(sig.r != null, "missing r");
136
+
137
+ assertError(sig.s != null, "missing s");
138
+
139
+ const _v = sig.v;
140
+ assertError(_v != null, "missing v");
141
+ assertArgument(_v === 1, "invalid v", "v", sig.v);
142
+
143
+ return new Signature(_guard, sig.r, sig.s, 1);
144
+ }
145
+ }