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.
- package/CHANGELOG.md +442 -442
- package/FUNDING.json +10 -10
- package/LICENSE.md +21 -21
- package/README.md +132 -142
- package/SECURITY.md +34 -34
- package/dist/README.md +22 -22
- package/dist/quantumcoin.js +1127 -1324
- package/dist/quantumcoin.js.map +1 -1
- package/dist/quantumcoin.min.js +1 -1
- package/dist/quantumcoin.umd.js +1128 -1327
- package/dist/quantumcoin.umd.js.map +1 -1
- package/dist/quantumcoin.umd.min.js +1 -1
- package/dist/wordlists-extra.js +1 -1
- package/dist/wordlists-extra.js.map +1 -1
- package/dist/wordlists-extra.min.js +1 -1
- package/lib.commonjs/README.md +16 -16
- package/lib.commonjs/_version.js +1 -1
- package/lib.commonjs/crypto/signature.d.ts +3 -76
- package/lib.commonjs/crypto/signature.d.ts.map +1 -1
- package/lib.commonjs/crypto/signature.js +15 -199
- package/lib.commonjs/crypto/signature.js.map +1 -1
- package/lib.commonjs/crypto/signing-key.d.ts +1 -1
- package/lib.commonjs/crypto/signing-key.d.ts.map +1 -1
- package/lib.commonjs/crypto/signing-key.js +19 -10
- package/lib.commonjs/crypto/signing-key.js.map +1 -1
- package/lib.commonjs/package.json +12 -12
- package/lib.commonjs/providers/provider-jsonrpc.d.ts +0 -1
- package/lib.commonjs/providers/provider-jsonrpc.d.ts.map +1 -1
- package/lib.commonjs/providers/provider-jsonrpc.js +0 -1
- package/lib.commonjs/providers/provider-jsonrpc.js.map +1 -1
- package/lib.commonjs/quantumcoin.d.ts +2 -0
- package/lib.commonjs/quantumcoin.d.ts.map +1 -1
- package/lib.commonjs/quantumcoin.js +11 -5
- package/lib.commonjs/quantumcoin.js.map +1 -1
- package/lib.commonjs/transaction/address.d.ts.map +1 -1
- package/lib.commonjs/transaction/address.js +8 -3
- package/lib.commonjs/transaction/address.js.map +1 -1
- package/lib.commonjs/transaction/transaction.d.ts.map +1 -1
- package/lib.commonjs/transaction/transaction.js +7 -40
- package/lib.commonjs/transaction/transaction.js.map +1 -1
- package/lib.commonjs/wallet/json-keystore.d.ts.map +1 -1
- package/lib.commonjs/wallet/json-keystore.js +7 -7
- package/lib.commonjs/wallet/json-keystore.js.map +1 -1
- package/lib.commonjs/wallet/wallet.d.ts.map +1 -1
- package/lib.commonjs/wallet/wallet.js +2 -2
- package/lib.commonjs/wallet/wallet.js.map +1 -1
- package/lib.esm/README.md +16 -16
- package/lib.esm/_version.js +1 -1
- package/lib.esm/crypto/signature.d.ts +3 -76
- package/lib.esm/crypto/signature.d.ts.map +1 -1
- package/lib.esm/crypto/signature.js +16 -202
- package/lib.esm/crypto/signature.js.map +1 -1
- package/lib.esm/crypto/signing-key.d.ts +1 -1
- package/lib.esm/crypto/signing-key.d.ts.map +1 -1
- package/lib.esm/crypto/signing-key.js +20 -9
- package/lib.esm/crypto/signing-key.js.map +1 -1
- package/lib.esm/package.json +12 -12
- package/lib.esm/providers/provider-jsonrpc.d.ts +0 -1
- package/lib.esm/providers/provider-jsonrpc.d.ts.map +1 -1
- package/lib.esm/providers/provider-jsonrpc.js +0 -1
- package/lib.esm/providers/provider-jsonrpc.js.map +1 -1
- package/lib.esm/quantumcoin.d.ts +2 -0
- package/lib.esm/quantumcoin.d.ts.map +1 -1
- package/lib.esm/quantumcoin.js +6 -0
- package/lib.esm/quantumcoin.js.map +1 -1
- package/lib.esm/transaction/address.d.ts.map +1 -1
- package/lib.esm/transaction/address.js +8 -2
- package/lib.esm/transaction/address.js.map +1 -1
- package/lib.esm/transaction/transaction.d.ts.map +1 -1
- package/lib.esm/transaction/transaction.js +7 -40
- package/lib.esm/transaction/transaction.js.map +1 -1
- package/lib.esm/wallet/json-keystore.d.ts.map +1 -1
- package/lib.esm/wallet/json-keystore.js +11 -5
- package/lib.esm/wallet/json-keystore.js.map +1 -1
- package/lib.esm/wallet/wallet.d.ts.map +1 -1
- package/lib.esm/wallet/wallet.js +3 -1
- package/lib.esm/wallet/wallet.js.map +1 -1
- package/package.json +6 -5
- package/rollup.config.mjs +50 -50
- package/src.ts/_version.ts +1 -1
- package/src.ts/abi/abi-coder.ts +237 -237
- package/src.ts/abi/bytes32.ts +45 -45
- package/src.ts/abi/coders/abstract-coder.ts +541 -541
- package/src.ts/abi/coders/address.ts +36 -36
- package/src.ts/abi/coders/anonymous.ts +29 -29
- package/src.ts/abi/coders/array.ts +199 -199
- package/src.ts/abi/coders/boolean.ts +27 -27
- package/src.ts/abi/coders/bytes.ts +43 -43
- package/src.ts/abi/coders/fixed-bytes.ts +37 -37
- package/src.ts/abi/coders/null.ts +28 -28
- package/src.ts/abi/coders/number.ts +63 -63
- package/src.ts/abi/coders/string.ts +29 -29
- package/src.ts/abi/coders/tuple.ts +69 -69
- package/src.ts/abi/fragments.ts +1617 -1617
- package/src.ts/abi/index.ts +41 -41
- package/src.ts/abi/interface.ts +1271 -1271
- package/src.ts/abi/typed.ts +796 -796
- package/src.ts/address/address.ts +148 -148
- package/src.ts/address/checks.ts +123 -123
- package/src.ts/address/contract-address.ts +80 -80
- package/src.ts/address/index.ts +57 -57
- package/src.ts/constants/addresses.ts +8 -8
- package/src.ts/constants/hashes.ts +7 -7
- package/src.ts/constants/index.ts +16 -16
- package/src.ts/constants/numbers.ts +35 -35
- package/src.ts/constants/strings.ts +16 -16
- package/src.ts/contract/contract.ts +1120 -1120
- package/src.ts/contract/factory.ts +143 -143
- package/src.ts/contract/index.ts +31 -31
- package/src.ts/contract/types.ts +236 -236
- package/src.ts/contract/wrappers.ts +225 -225
- package/src.ts/crypto/crypto-browser.ts +64 -64
- package/src.ts/crypto/crypto.ts +4 -4
- package/src.ts/crypto/hmac.ts +51 -51
- package/src.ts/crypto/index.ts +59 -59
- package/src.ts/crypto/keccak.ts +54 -54
- package/src.ts/crypto/pbkdf2.ts +55 -55
- package/src.ts/crypto/random.ts +36 -36
- package/src.ts/crypto/ripemd160.ts +43 -43
- package/src.ts/crypto/scrypt.ts +114 -114
- package/src.ts/crypto/sha2.ts +78 -78
- package/src.ts/crypto/signature.ts +145 -349
- package/src.ts/crypto/signing-key.ts +126 -118
- package/src.ts/hash/authorization.ts +38 -38
- package/src.ts/hash/id.ts +17 -17
- package/src.ts/hash/index.ts +18 -18
- package/src.ts/hash/message.ts +51 -51
- package/src.ts/hash/namehash.ts +101 -101
- package/src.ts/hash/solidity.ts +117 -117
- package/src.ts/hash/typed-data.ts +658 -658
- package/src.ts/index.ts +12 -12
- package/src.ts/providers/abstract-provider.ts +1761 -1761
- package/src.ts/providers/abstract-signer.ts +314 -314
- package/src.ts/providers/community.ts +49 -49
- package/src.ts/providers/contracts.ts +42 -42
- package/src.ts/providers/default-provider.ts +96 -96
- package/src.ts/providers/ens-resolver.ts +606 -606
- package/src.ts/providers/format.ts +320 -320
- package/src.ts/providers/formatting.ts +418 -418
- package/src.ts/providers/index.ts +125 -125
- package/src.ts/providers/network.ts +327 -327
- package/src.ts/providers/pagination.ts +8 -8
- package/src.ts/providers/plugin-fallback.ts +35 -35
- package/src.ts/providers/plugins-network.ts +281 -281
- package/src.ts/providers/provider-browser.ts +334 -334
- package/src.ts/providers/provider-fallback.ts +801 -801
- package/src.ts/providers/provider-ipcsocket-browser.ts +3 -3
- package/src.ts/providers/provider-ipcsocket.ts +81 -81
- package/src.ts/providers/provider-jsonrpc.ts +1334 -1335
- package/src.ts/providers/provider-socket.ts +352 -352
- package/src.ts/providers/provider-websocket.ts +103 -103
- package/src.ts/providers/provider.ts +2136 -2136
- package/src.ts/providers/signer-noncemanager.ts +98 -98
- package/src.ts/providers/signer.ts +166 -166
- package/src.ts/providers/subscriber-connection.ts +74 -74
- package/src.ts/providers/subscriber-filterid.ts +199 -199
- package/src.ts/providers/subscriber-polling.ts +321 -321
- package/src.ts/providers/ws-browser.ts +11 -11
- package/src.ts/providers/ws.ts +3 -3
- package/src.ts/quantumcoin.ts +219 -211
- package/src.ts/thirdparty.d.ts +16 -16
- package/src.ts/transaction/accesslist.ts +43 -43
- package/src.ts/transaction/address.ts +35 -31
- package/src.ts/transaction/authorization.ts +14 -14
- package/src.ts/transaction/index.ts +51 -51
- package/src.ts/transaction/transaction.ts +1349 -1379
- package/src.ts/utils/base58.ts +73 -73
- package/src.ts/utils/base64-browser.ts +25 -25
- package/src.ts/utils/base64.ts +56 -56
- package/src.ts/utils/data.ts +199 -199
- package/src.ts/utils/errors.ts +793 -793
- package/src.ts/utils/events.ts +105 -105
- package/src.ts/utils/fetch.ts +970 -970
- package/src.ts/utils/fixednumber.ts +643 -643
- package/src.ts/utils/geturl-browser.ts +81 -81
- package/src.ts/utils/geturl.ts +134 -134
- package/src.ts/utils/index.ts +95 -95
- package/src.ts/utils/maths.ts +240 -240
- package/src.ts/utils/properties.ts +60 -60
- package/src.ts/utils/rlp-decode.ts +104 -104
- package/src.ts/utils/rlp-encode.ts +64 -64
- package/src.ts/utils/rlp.ts +20 -20
- package/src.ts/utils/units.ts +91 -91
- package/src.ts/utils/utf8.ts +325 -325
- package/src.ts/utils/uuid.ts +36 -36
- package/src.ts/wallet/base-wallet.ts +160 -160
- package/src.ts/wallet/index.ts +32 -32
- package/src.ts/wallet/json-keystore.ts +108 -106
- package/src.ts/wallet/utils.ts +147 -147
- package/src.ts/wallet/wallet.ts +138 -139
- package/src.ts/wordlists/bit-reader.ts +35 -35
- package/src.ts/wordlists/decode-owl.ts +58 -58
- package/src.ts/wordlists/decode-owla.ts +33 -33
- package/src.ts/wordlists/generation/encode-latin.ts +370 -370
- package/src.ts/wordlists/index.ts +26 -26
- package/src.ts/wordlists/lang-cz.ts +33 -33
- package/src.ts/wordlists/lang-en.ts +33 -33
- package/src.ts/wordlists/lang-es.ts +35 -35
- package/src.ts/wordlists/lang-fr.ts +34 -34
- package/src.ts/wordlists/lang-it.ts +33 -33
- package/src.ts/wordlists/lang-ja.ts +181 -181
- package/src.ts/wordlists/lang-ko.ts +104 -104
- package/src.ts/wordlists/lang-pt.ts +34 -34
- package/src.ts/wordlists/lang-zh.ts +112 -112
- package/src.ts/wordlists/wordlist-owl.ts +77 -77
- package/src.ts/wordlists/wordlist-owla.ts +41 -41
- package/src.ts/wordlists/wordlist.ts +59 -59
- package/src.ts/wordlists/wordlists-browser.ts +8 -8
- package/src.ts/wordlists/wordlists-extra.ts +9 -9
- package/src.ts/wordlists/wordlists.ts +38 -38
- package/dist/quantumcoin.min.js'.gz' +0 -0
- package/dist/quantumcoin.umd.min.js'.gz' +0 -0
- package/dist/wordlists-extra.min.js'.gz' +0 -0
- package/lib.commonjs/providers/provider-alchemy.d.ts +0 -50
- package/lib.commonjs/providers/provider-alchemy.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-alchemy.js +0 -151
- package/lib.commonjs/providers/provider-alchemy.js.map +0 -1
- package/lib.commonjs/providers/provider-ankr.d.ts +0 -61
- package/lib.commonjs/providers/provider-ankr.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-ankr.js +0 -137
- package/lib.commonjs/providers/provider-ankr.js.map +0 -1
- package/lib.commonjs/providers/provider-blockscout.d.ts +0 -59
- package/lib.commonjs/providers/provider-blockscout.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-blockscout.js +0 -145
- package/lib.commonjs/providers/provider-blockscout.js.map +0 -1
- package/lib.commonjs/providers/provider-chainstack.d.ts +0 -46
- package/lib.commonjs/providers/provider-chainstack.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-chainstack.js +0 -102
- package/lib.commonjs/providers/provider-chainstack.js.map +0 -1
- package/lib.commonjs/providers/provider-cloudflare.d.ts +0 -14
- package/lib.commonjs/providers/provider-cloudflare.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-cloudflare.js +0 -26
- package/lib.commonjs/providers/provider-cloudflare.js.map +0 -1
- package/lib.commonjs/providers/provider-etherscan.d.ts +0 -147
- package/lib.commonjs/providers/provider-etherscan.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-etherscan.js +0 -587
- package/lib.commonjs/providers/provider-etherscan.js.map +0 -1
- package/lib.commonjs/providers/provider-infura.d.ts +0 -101
- package/lib.commonjs/providers/provider-infura.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-infura.js +0 -206
- package/lib.commonjs/providers/provider-infura.js.map +0 -1
- package/lib.commonjs/providers/provider-pocket.d.ts +0 -54
- package/lib.commonjs/providers/provider-pocket.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-pocket.js +0 -109
- package/lib.commonjs/providers/provider-pocket.js.map +0 -1
- package/lib.commonjs/providers/provider-quicknode.d.ts +0 -59
- package/lib.commonjs/providers/provider-quicknode.d.ts.map +0 -1
- package/lib.commonjs/providers/provider-quicknode.js +0 -163
- package/lib.commonjs/providers/provider-quicknode.js.map +0 -1
- package/lib.commonjs/wallet/hdwallet.d.ts +0 -248
- package/lib.commonjs/wallet/hdwallet.d.ts.map +0 -1
- package/lib.commonjs/wallet/hdwallet.js +0 -505
- package/lib.commonjs/wallet/hdwallet.js.map +0 -1
- package/lib.commonjs/wallet/json-crowdsale.d.ts +0 -27
- package/lib.commonjs/wallet/json-crowdsale.d.ts.map +0 -1
- package/lib.commonjs/wallet/json-crowdsale.js +0 -60
- package/lib.commonjs/wallet/json-crowdsale.js.map +0 -1
- package/lib.commonjs/wallet/mnemonic.d.ts +0 -65
- package/lib.commonjs/wallet/mnemonic.d.ts.map +0 -1
- package/lib.commonjs/wallet/mnemonic.js +0 -169
- package/lib.commonjs/wallet/mnemonic.js.map +0 -1
- package/lib.commonjs/wallet/seedwallet.d.ts +0 -4
- package/lib.commonjs/wallet/seedwallet.d.ts.map +0 -1
- package/lib.commonjs/wallet/seedwallet.js +0 -8
- package/lib.commonjs/wallet/seedwallet.js.map +0 -1
- package/lib.esm/providers/provider-alchemy.d.ts +0 -50
- package/lib.esm/providers/provider-alchemy.d.ts.map +0 -1
- package/lib.esm/providers/provider-alchemy.js +0 -147
- package/lib.esm/providers/provider-alchemy.js.map +0 -1
- package/lib.esm/providers/provider-ankr.d.ts +0 -61
- package/lib.esm/providers/provider-ankr.d.ts.map +0 -1
- package/lib.esm/providers/provider-ankr.js +0 -133
- package/lib.esm/providers/provider-ankr.js.map +0 -1
- package/lib.esm/providers/provider-blockscout.d.ts +0 -59
- package/lib.esm/providers/provider-blockscout.d.ts.map +0 -1
- package/lib.esm/providers/provider-blockscout.js +0 -141
- package/lib.esm/providers/provider-blockscout.js.map +0 -1
- package/lib.esm/providers/provider-chainstack.d.ts +0 -46
- package/lib.esm/providers/provider-chainstack.d.ts.map +0 -1
- package/lib.esm/providers/provider-chainstack.js +0 -98
- package/lib.esm/providers/provider-chainstack.js.map +0 -1
- package/lib.esm/providers/provider-cloudflare.d.ts +0 -14
- package/lib.esm/providers/provider-cloudflare.d.ts.map +0 -1
- package/lib.esm/providers/provider-cloudflare.js +0 -22
- package/lib.esm/providers/provider-cloudflare.js.map +0 -1
- package/lib.esm/providers/provider-etherscan.d.ts +0 -147
- package/lib.esm/providers/provider-etherscan.d.ts.map +0 -1
- package/lib.esm/providers/provider-etherscan.js +0 -584
- package/lib.esm/providers/provider-etherscan.js.map +0 -1
- package/lib.esm/providers/provider-infura.d.ts +0 -101
- package/lib.esm/providers/provider-infura.d.ts.map +0 -1
- package/lib.esm/providers/provider-infura.js +0 -201
- package/lib.esm/providers/provider-infura.js.map +0 -1
- package/lib.esm/providers/provider-pocket.d.ts +0 -54
- package/lib.esm/providers/provider-pocket.d.ts.map +0 -1
- package/lib.esm/providers/provider-pocket.js +0 -105
- package/lib.esm/providers/provider-pocket.js.map +0 -1
- package/lib.esm/providers/provider-quicknode.d.ts +0 -59
- package/lib.esm/providers/provider-quicknode.d.ts.map +0 -1
- package/lib.esm/providers/provider-quicknode.js +0 -159
- package/lib.esm/providers/provider-quicknode.js.map +0 -1
- package/lib.esm/wallet/hdwallet.d.ts +0 -248
- package/lib.esm/wallet/hdwallet.d.ts.map +0 -1
- package/lib.esm/wallet/hdwallet.js +0 -498
- package/lib.esm/wallet/hdwallet.js.map +0 -1
- package/lib.esm/wallet/json-crowdsale.d.ts +0 -27
- package/lib.esm/wallet/json-crowdsale.d.ts.map +0 -1
- package/lib.esm/wallet/json-crowdsale.js +0 -55
- package/lib.esm/wallet/json-crowdsale.js.map +0 -1
- package/lib.esm/wallet/mnemonic.d.ts +0 -65
- package/lib.esm/wallet/mnemonic.d.ts.map +0 -1
- package/lib.esm/wallet/mnemonic.js +0 -165
- package/lib.esm/wallet/mnemonic.js.map +0 -1
- package/lib.esm/wallet/seedwallet.d.ts +0 -4
- package/lib.esm/wallet/seedwallet.d.ts.map +0 -1
- package/lib.esm/wallet/seedwallet.js +0 -4
- 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
|
+
}
|
package/src.ts/address/index.ts
CHANGED
|
@@ -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";
|