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,80 +1,80 @@
1
- import { keccak256 } from "../crypto/index.js";
2
- import {
3
- concat, dataSlice, getBigInt, getBytes, encodeRlp, assertArgument
4
- } from "../utils/index.js";
5
-
6
- import { getAddress } from "./address.js";
7
-
8
- import type { BigNumberish, BytesLike } from "../utils/index.js";
9
-
10
-
11
- // http://ethereum.stackexchange.com/questions/760/how-is-the-address-of-an-ethereum-contract-computed
12
-
13
- /**
14
- * Returns the address that would result from a ``CREATE`` for %%tx%%.
15
- *
16
- * This can be used to compute the address a contract will be
17
- * deployed to by an EOA when sending a deployment transaction (i.e.
18
- * when the ``to`` address is ``null``).
19
- *
20
- * This can also be used to compute the address a contract will be
21
- * deployed to by a contract, by using the contract's address as the
22
- * ``to`` and the contract's nonce.
23
- *
24
- * @example
25
- * from = "0x8ba1f109551bD432803012645Ac136ddd64DBA72";
26
- * nonce = 5;
27
- *
28
- * getCreateAddress({ from, nonce });
29
- * //_result:
30
- */
31
- export function getCreateAddress(tx: { from: string, nonce: BigNumberish }): string {
32
- const from = getAddress(tx.from);
33
- const nonce = getBigInt(tx.nonce, "tx.nonce");
34
-
35
- let nonceHex = nonce.toString(16);
36
- if (nonceHex === "0") {
37
- nonceHex = "0x";
38
- } else if (nonceHex.length % 2) {
39
- nonceHex = "0x0" + nonceHex;
40
- } else {
41
- nonceHex = "0x" + nonceHex;
42
- }
43
-
44
- return getAddress(dataSlice(keccak256(encodeRlp([ from, nonceHex ])), 12));
45
- }
46
-
47
- /**
48
- * Returns the address that would result from a ``CREATE2`` operation
49
- * with the given %%from%%, %%salt%% and %%initCodeHash%%.
50
- *
51
- * To compute the %%initCodeHash%% from a contract's init code, use
52
- * the [[keccak256]] function.
53
- *
54
- * For a quick overview and example of ``CREATE2``, see [[link-ricmoo-wisps]].
55
- *
56
- * @example
57
- * // The address of the contract
58
- * from = "0x8ba1f109551bD432803012645Ac136ddd64DBA72"
59
- *
60
- * // The salt
61
- * salt = id("HelloWorld")
62
- *
63
- * // The hash of the initCode
64
- * initCode = "0x6394198df16000526103ff60206004601c335afa6040516060f3";
65
- * initCodeHash = keccak256(initCode)
66
- *
67
- * getCreate2Address(from, salt, initCodeHash)
68
- * //_result:
69
- */
70
- export function getCreate2Address(_from: string, _salt: BytesLike, _initCodeHash: BytesLike): string {
71
- const from = getAddress(_from);
72
- const salt = getBytes(_salt, "salt");
73
- const initCodeHash = getBytes(_initCodeHash, "initCodeHash");
74
-
75
- assertArgument(salt.length === 32, "salt must be 32 bytes", "salt", _salt);
76
-
77
- assertArgument(initCodeHash.length === 32, "initCodeHash must be 32 bytes", "initCodeHash", _initCodeHash);
78
-
79
- return getAddress(dataSlice(keccak256(concat([ "0xff", from, salt, initCodeHash ])), 12))
80
- }
1
+ import { keccak256 } from "../crypto/index.js";
2
+ import {
3
+ concat, dataSlice, getBigInt, getBytes, encodeRlp, assertArgument
4
+ } from "../utils/index.js";
5
+
6
+ import { getAddress } from "./address.js";
7
+
8
+ import type { BigNumberish, BytesLike } from "../utils/index.js";
9
+
10
+
11
+ // http://ethereum.stackexchange.com/questions/760/how-is-the-address-of-an-ethereum-contract-computed
12
+
13
+ /**
14
+ * Returns the address that would result from a ``CREATE`` for %%tx%%.
15
+ *
16
+ * This can be used to compute the address a contract will be
17
+ * deployed to by an EOA when sending a deployment transaction (i.e.
18
+ * when the ``to`` address is ``null``).
19
+ *
20
+ * This can also be used to compute the address a contract will be
21
+ * deployed to by a contract, by using the contract's address as the
22
+ * ``to`` and the contract's nonce.
23
+ *
24
+ * @example
25
+ * from = "0x8ba1f109551bD432803012645Ac136ddd64DBA72";
26
+ * nonce = 5;
27
+ *
28
+ * getCreateAddress({ from, nonce });
29
+ * //_result:
30
+ */
31
+ export function getCreateAddress(tx: { from: string, nonce: BigNumberish }): string {
32
+ const from = getAddress(tx.from);
33
+ const nonce = getBigInt(tx.nonce, "tx.nonce");
34
+
35
+ let nonceHex = nonce.toString(16);
36
+ if (nonceHex === "0") {
37
+ nonceHex = "0x";
38
+ } else if (nonceHex.length % 2) {
39
+ nonceHex = "0x0" + nonceHex;
40
+ } else {
41
+ nonceHex = "0x" + nonceHex;
42
+ }
43
+
44
+ return getAddress(dataSlice(keccak256(encodeRlp([ from, nonceHex ])), 12));
45
+ }
46
+
47
+ /**
48
+ * Returns the address that would result from a ``CREATE2`` operation
49
+ * with the given %%from%%, %%salt%% and %%initCodeHash%%.
50
+ *
51
+ * To compute the %%initCodeHash%% from a contract's init code, use
52
+ * the [[keccak256]] function.
53
+ *
54
+ * For a quick overview and example of ``CREATE2``, see [[link-ricmoo-wisps]].
55
+ *
56
+ * @example
57
+ * // The address of the contract
58
+ * from = "0x8ba1f109551bD432803012645Ac136ddd64DBA72"
59
+ *
60
+ * // The salt
61
+ * salt = id("HelloWorld")
62
+ *
63
+ * // The hash of the initCode
64
+ * initCode = "0x6394198df16000526103ff60206004601c335afa6040516060f3";
65
+ * initCodeHash = keccak256(initCode)
66
+ *
67
+ * getCreate2Address(from, salt, initCodeHash)
68
+ * //_result:
69
+ */
70
+ export function getCreate2Address(_from: string, _salt: BytesLike, _initCodeHash: BytesLike): string {
71
+ const from = getAddress(_from);
72
+ const salt = getBytes(_salt, "salt");
73
+ const initCodeHash = getBytes(_initCodeHash, "initCodeHash");
74
+
75
+ assertArgument(salt.length === 32, "salt must be 32 bytes", "salt", _salt);
76
+
77
+ assertArgument(initCodeHash.length === 32, "initCodeHash must be 32 bytes", "initCodeHash", _initCodeHash);
78
+
79
+ return getAddress(dataSlice(keccak256(concat([ "0xff", from, salt, initCodeHash ])), 12))
80
+ }
@@ -1,57 +1,57 @@
1
- /**
2
- * Addresses are a fundamental part of interacting with Ethereum. They
3
- * represent the global identity of Externally Owned Accounts (accounts
4
- * backed by a private key) and contracts.
5
- *
6
- * The Ethereum Naming Service (ENS) provides an interconnected ecosystem
7
- * of contracts, standards and libraries which enable looking up an
8
- * address for an ENS name.
9
- *
10
- * These functions help convert between various formats, validate
11
- * addresses and safely resolve ENS names.
12
- *
13
- * @_section: api/address:Addresses [about-addresses]
14
- */
15
-
16
- null;
17
-
18
- /**
19
- * An interface for objects which have an address, and can
20
- * resolve it asyncronously.
21
- *
22
- * This allows objects such as [[Signer]] or [[Contract]] to
23
- * be used most places an address can be, for example getting
24
- * the [balance](Provider-getBalance).
25
- */
26
- export interface Addressable {
27
- /**
28
- * Get the object address.
29
- */
30
- getAddress(): Promise<string>;
31
- }
32
-
33
- /**
34
- * Anything that can be used to return or resolve an address.
35
- */
36
- export type AddressLike = string | Promise<string> | Addressable;
37
-
38
- /**
39
- * An interface for any object which can resolve an ENS name.
40
- */
41
- export interface NameResolver {
42
- /**
43
- * Resolve to the address for the ENS %%name%%.
44
- *
45
- * Resolves to ``null`` if the name is unconfigued. Use
46
- * [[resolveAddress]] (passing this object as %%resolver%%) to
47
- * throw for names that are unconfigured.
48
- */
49
- resolveName(name: string): Promise<null | string>;
50
- }
51
-
52
- export { getAddress } from "./address.js";
53
-
54
- export { getCreateAddress, getCreate2Address } from "./contract-address.js";
55
-
56
-
57
- export { isAddressable, isAddress, resolveAddress } from "./checks.js";
1
+ /**
2
+ * Addresses are a fundamental part of interacting with Ethereum. They
3
+ * represent the global identity of Externally Owned Accounts (accounts
4
+ * backed by a private key) and contracts.
5
+ *
6
+ * The Ethereum Naming Service (ENS) provides an interconnected ecosystem
7
+ * of contracts, standards and libraries which enable looking up an
8
+ * address for an ENS name.
9
+ *
10
+ * These functions help convert between various formats, validate
11
+ * addresses and safely resolve ENS names.
12
+ *
13
+ * @_section: api/address:Addresses [about-addresses]
14
+ */
15
+
16
+ null;
17
+
18
+ /**
19
+ * An interface for objects which have an address, and can
20
+ * resolve it asyncronously.
21
+ *
22
+ * This allows objects such as [[Signer]] or [[Contract]] to
23
+ * be used most places an address can be, for example getting
24
+ * the [balance](Provider-getBalance).
25
+ */
26
+ export interface Addressable {
27
+ /**
28
+ * Get the object address.
29
+ */
30
+ getAddress(): Promise<string>;
31
+ }
32
+
33
+ /**
34
+ * Anything that can be used to return or resolve an address.
35
+ */
36
+ export type AddressLike = string | Promise<string> | Addressable;
37
+
38
+ /**
39
+ * An interface for any object which can resolve an ENS name.
40
+ */
41
+ export interface NameResolver {
42
+ /**
43
+ * Resolve to the address for the ENS %%name%%.
44
+ *
45
+ * Resolves to ``null`` if the name is unconfigued. Use
46
+ * [[resolveAddress]] (passing this object as %%resolver%%) to
47
+ * throw for names that are unconfigured.
48
+ */
49
+ resolveName(name: string): Promise<null | string>;
50
+ }
51
+
52
+ export { getAddress } from "./address.js";
53
+
54
+ export { getCreateAddress, getCreate2Address } from "./contract-address.js";
55
+
56
+
57
+ export { isAddressable, isAddress, resolveAddress } from "./checks.js";
@@ -1,8 +1,8 @@
1
-
2
- /**
3
- * A constant for the zero address.
4
- *
5
- * (**i.e.** ``"0x0000000000000000000000000000000000000000"``)
6
- */
7
- export const ZeroAddress: string = "0x0000000000000000000000000000000000000000";
8
-
1
+
2
+ /**
3
+ * A constant for the zero address.
4
+ *
5
+ * (**i.e.** ``"0x0000000000000000000000000000000000000000"``)
6
+ */
7
+ export const ZeroAddress: string = "0x0000000000000000000000000000000000000000";
8
+
@@ -1,7 +1,7 @@
1
- /**
2
- * A constant for the zero hash.
3
- *
4
- * (**i.e.** ``"0x0000000000000000000000000000000000000000000000000000000000000000"``)
5
- */
6
- export const ZeroHash: string = "0x0000000000000000000000000000000000000000000000000000000000000000";
7
-
1
+ /**
2
+ * A constant for the zero hash.
3
+ *
4
+ * (**i.e.** ``"0x0000000000000000000000000000000000000000000000000000000000000000"``)
5
+ */
6
+ export const ZeroHash: string = "0x0000000000000000000000000000000000000000000000000000000000000000";
7
+
@@ -1,16 +1,16 @@
1
- /**
2
- * Some common constants useful for Ethereum.
3
- *
4
- * @_section: api/constants: Constants [about-constants]
5
- */
6
-
7
- export { ZeroAddress } from "./addresses.js";
8
- export { ZeroHash } from "./hashes.js";
9
- export {
10
- N,
11
- WeiPerEther,
12
- MaxUint256,
13
- MinInt256,
14
- MaxInt256
15
- } from "./numbers.js";
16
- export { EtherSymbol, MessagePrefix } from "./strings.js";
1
+ /**
2
+ * Some common constants useful for Ethereum.
3
+ *
4
+ * @_section: api/constants: Constants [about-constants]
5
+ */
6
+
7
+ export { ZeroAddress } from "./addresses.js";
8
+ export { ZeroHash } from "./hashes.js";
9
+ export {
10
+ N,
11
+ WeiPerEther,
12
+ MaxUint256,
13
+ MinInt256,
14
+ MaxInt256
15
+ } from "./numbers.js";
16
+ export { EtherSymbol, MessagePrefix } from "./strings.js";
@@ -1,35 +1,35 @@
1
-
2
- /**
3
- * A constant for the order N for the secp256k1 curve.
4
- *
5
- * (**i.e.** ``0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141n``)
6
- */
7
- export const N: bigint = BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141");
8
-
9
- /**
10
- * A constant for the number of wei in a single ether.
11
- *
12
- * (**i.e.** ``1000000000000000000n``)
13
- */
14
- export const WeiPerEther: bigint = BigInt("1000000000000000000");
15
-
16
- /**
17
- * A constant for the maximum value for a ``uint256``.
18
- *
19
- * (**i.e.** ``0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffn``)
20
- */
21
- export const MaxUint256: bigint = BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
22
-
23
- /**
24
- * A constant for the minimum value for an ``int256``.
25
- *
26
- * (**i.e.** ``-8000000000000000000000000000000000000000000000000000000000000000n``)
27
- */
28
- export const MinInt256: bigint = BigInt("0x8000000000000000000000000000000000000000000000000000000000000000") * BigInt(-1);
29
-
30
- /**
31
- * A constant for the maximum value for an ``int256``.
32
- *
33
- * (**i.e.** ``0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffn``)
34
- */
35
- export const MaxInt256: bigint = BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
1
+
2
+ /**
3
+ * A constant for the order N for the secp256k1 curve.
4
+ *
5
+ * (**i.e.** ``0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141n``)
6
+ */
7
+ export const N: bigint = BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141");
8
+
9
+ /**
10
+ * A constant for the number of wei in a single ether.
11
+ *
12
+ * (**i.e.** ``1000000000000000000n``)
13
+ */
14
+ export const WeiPerEther: bigint = BigInt("1000000000000000000");
15
+
16
+ /**
17
+ * A constant for the maximum value for a ``uint256``.
18
+ *
19
+ * (**i.e.** ``0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffn``)
20
+ */
21
+ export const MaxUint256: bigint = BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
22
+
23
+ /**
24
+ * A constant for the minimum value for an ``int256``.
25
+ *
26
+ * (**i.e.** ``-8000000000000000000000000000000000000000000000000000000000000000n``)
27
+ */
28
+ export const MinInt256: bigint = BigInt("0x8000000000000000000000000000000000000000000000000000000000000000") * BigInt(-1);
29
+
30
+ /**
31
+ * A constant for the maximum value for an ``int256``.
32
+ *
33
+ * (**i.e.** ``0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffn``)
34
+ */
35
+ export const MaxInt256: bigint = BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
@@ -1,16 +1,16 @@
1
- // NFKC (composed) // (decomposed)
2
-
3
- /**
4
- * A constant for the ether symbol (normalized using NFKC).
5
- *
6
- * (**i.e.** ``"\\u039e"``)
7
- */
8
- export const EtherSymbol: string = "\u039e"; // "\uD835\uDF63";
9
-
10
-
11
- /**
12
- * A constant for the [[link-eip-191]] personal message prefix.
13
- *
14
- * (**i.e.** ``"\\x19Ethereum Signed Message:\\n"``)
15
- */
16
- export const MessagePrefix: string = "\x19Ethereum Signed Message:\n";
1
+ // NFKC (composed) // (decomposed)
2
+
3
+ /**
4
+ * A constant for the ether symbol (normalized using NFKC).
5
+ *
6
+ * (**i.e.** ``"\\u039e"``)
7
+ */
8
+ export const EtherSymbol: string = "\u039e"; // "\uD835\uDF63";
9
+
10
+
11
+ /**
12
+ * A constant for the [[link-eip-191]] personal message prefix.
13
+ *
14
+ * (**i.e.** ``"\\x19Ethereum Signed Message:\\n"``)
15
+ */
16
+ export const MessagePrefix: string = "\x19Ethereum Signed Message:\n";