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
package/src.ts/hash/namehash.ts
CHANGED
|
@@ -1,101 +1,101 @@
|
|
|
1
|
-
|
|
2
|
-
import { keccak256 } from "../crypto/index.js";
|
|
3
|
-
import {
|
|
4
|
-
concat, hexlify, assertArgument, toUtf8Bytes
|
|
5
|
-
} from "../utils/index.js";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
import { ens_normalize } from "@adraffy/ens-normalize";
|
|
9
|
-
|
|
10
|
-
const Zeros = new Uint8Array(32);
|
|
11
|
-
Zeros.fill(0);
|
|
12
|
-
|
|
13
|
-
function checkComponent(comp: Uint8Array): Uint8Array {
|
|
14
|
-
assertArgument(comp.length !== 0, "invalid ENS name; empty component", "comp", comp)
|
|
15
|
-
return comp;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function ensNameSplit(name: string): Array<Uint8Array> {
|
|
19
|
-
const bytes = toUtf8Bytes(ensNormalize(name));
|
|
20
|
-
const comps: Array<Uint8Array> = [ ];
|
|
21
|
-
|
|
22
|
-
if (name.length === 0) { return comps; }
|
|
23
|
-
|
|
24
|
-
let last = 0;
|
|
25
|
-
for (let i = 0; i < bytes.length; i++) {
|
|
26
|
-
const d = bytes[i];
|
|
27
|
-
|
|
28
|
-
// A separator (i.e. "."); copy this component
|
|
29
|
-
if (d === 0x2e) {
|
|
30
|
-
comps.push(checkComponent(bytes.slice(last, i)));
|
|
31
|
-
last = i + 1;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
// There was a stray separator at the end of the name
|
|
36
|
-
assertArgument(last < bytes.length, "invalid ENS name; empty component", "name", name);
|
|
37
|
-
|
|
38
|
-
comps.push(checkComponent(bytes.slice(last)));
|
|
39
|
-
return comps;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
* Returns the ENS %%name%% normalized.
|
|
44
|
-
*/
|
|
45
|
-
export function ensNormalize(name: string): string {
|
|
46
|
-
try {
|
|
47
|
-
if (name.length === 0) { throw new Error("empty label"); }
|
|
48
|
-
return ens_normalize(name);
|
|
49
|
-
} catch (error: any) {
|
|
50
|
-
assertArgument(false, `invalid ENS name (${ error.message })`, "name", name);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Returns ``true`` if %%name%% is a valid ENS name.
|
|
56
|
-
*/
|
|
57
|
-
export function isValidName(name: string): name is string {
|
|
58
|
-
try {
|
|
59
|
-
return (ensNameSplit(name).length !== 0);
|
|
60
|
-
} catch (error) { }
|
|
61
|
-
return false;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
* Returns the [[link-namehash]] for %%name%%.
|
|
66
|
-
*/
|
|
67
|
-
export function namehash(name: string): string {
|
|
68
|
-
assertArgument(typeof(name) === "string", "invalid ENS name; not a string", "name", name);
|
|
69
|
-
|
|
70
|
-
assertArgument(name.length, `invalid ENS name (empty label)`, "name", name);
|
|
71
|
-
|
|
72
|
-
let result: string | Uint8Array = Zeros;
|
|
73
|
-
|
|
74
|
-
const comps = ensNameSplit(name);
|
|
75
|
-
while (comps.length) {
|
|
76
|
-
result = keccak256(concat([ result, keccak256(<Uint8Array>(comps.pop()))] ));
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
return hexlify(result);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Returns the DNS encoded %%name%%.
|
|
84
|
-
*
|
|
85
|
-
* This is used for various parts of ENS name resolution, such
|
|
86
|
-
* as the wildcard resolution.
|
|
87
|
-
*/
|
|
88
|
-
export function dnsEncode(name: string, _maxLength?: number): string {
|
|
89
|
-
const length = (_maxLength != null) ? _maxLength: 63;
|
|
90
|
-
|
|
91
|
-
assertArgument(length <= 255, "DNS encoded label cannot exceed 255", "length", length);
|
|
92
|
-
|
|
93
|
-
return hexlify(concat(ensNameSplit(name).map((comp) => {
|
|
94
|
-
assertArgument(comp.length <= length, `label ${ JSON.stringify(name) } exceeds ${ length } bytes`, "name", name);
|
|
95
|
-
|
|
96
|
-
const bytes = new Uint8Array(comp.length + 1);
|
|
97
|
-
bytes.set(comp, 1);
|
|
98
|
-
bytes[0] = bytes.length - 1;
|
|
99
|
-
return bytes;
|
|
100
|
-
}))) + "00";
|
|
101
|
-
}
|
|
1
|
+
|
|
2
|
+
import { keccak256 } from "../crypto/index.js";
|
|
3
|
+
import {
|
|
4
|
+
concat, hexlify, assertArgument, toUtf8Bytes
|
|
5
|
+
} from "../utils/index.js";
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
import { ens_normalize } from "@adraffy/ens-normalize";
|
|
9
|
+
|
|
10
|
+
const Zeros = new Uint8Array(32);
|
|
11
|
+
Zeros.fill(0);
|
|
12
|
+
|
|
13
|
+
function checkComponent(comp: Uint8Array): Uint8Array {
|
|
14
|
+
assertArgument(comp.length !== 0, "invalid ENS name; empty component", "comp", comp)
|
|
15
|
+
return comp;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function ensNameSplit(name: string): Array<Uint8Array> {
|
|
19
|
+
const bytes = toUtf8Bytes(ensNormalize(name));
|
|
20
|
+
const comps: Array<Uint8Array> = [ ];
|
|
21
|
+
|
|
22
|
+
if (name.length === 0) { return comps; }
|
|
23
|
+
|
|
24
|
+
let last = 0;
|
|
25
|
+
for (let i = 0; i < bytes.length; i++) {
|
|
26
|
+
const d = bytes[i];
|
|
27
|
+
|
|
28
|
+
// A separator (i.e. "."); copy this component
|
|
29
|
+
if (d === 0x2e) {
|
|
30
|
+
comps.push(checkComponent(bytes.slice(last, i)));
|
|
31
|
+
last = i + 1;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
// There was a stray separator at the end of the name
|
|
36
|
+
assertArgument(last < bytes.length, "invalid ENS name; empty component", "name", name);
|
|
37
|
+
|
|
38
|
+
comps.push(checkComponent(bytes.slice(last)));
|
|
39
|
+
return comps;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Returns the ENS %%name%% normalized.
|
|
44
|
+
*/
|
|
45
|
+
export function ensNormalize(name: string): string {
|
|
46
|
+
try {
|
|
47
|
+
if (name.length === 0) { throw new Error("empty label"); }
|
|
48
|
+
return ens_normalize(name);
|
|
49
|
+
} catch (error: any) {
|
|
50
|
+
assertArgument(false, `invalid ENS name (${ error.message })`, "name", name);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Returns ``true`` if %%name%% is a valid ENS name.
|
|
56
|
+
*/
|
|
57
|
+
export function isValidName(name: string): name is string {
|
|
58
|
+
try {
|
|
59
|
+
return (ensNameSplit(name).length !== 0);
|
|
60
|
+
} catch (error) { }
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Returns the [[link-namehash]] for %%name%%.
|
|
66
|
+
*/
|
|
67
|
+
export function namehash(name: string): string {
|
|
68
|
+
assertArgument(typeof(name) === "string", "invalid ENS name; not a string", "name", name);
|
|
69
|
+
|
|
70
|
+
assertArgument(name.length, `invalid ENS name (empty label)`, "name", name);
|
|
71
|
+
|
|
72
|
+
let result: string | Uint8Array = Zeros;
|
|
73
|
+
|
|
74
|
+
const comps = ensNameSplit(name);
|
|
75
|
+
while (comps.length) {
|
|
76
|
+
result = keccak256(concat([ result, keccak256(<Uint8Array>(comps.pop()))] ));
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return hexlify(result);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Returns the DNS encoded %%name%%.
|
|
84
|
+
*
|
|
85
|
+
* This is used for various parts of ENS name resolution, such
|
|
86
|
+
* as the wildcard resolution.
|
|
87
|
+
*/
|
|
88
|
+
export function dnsEncode(name: string, _maxLength?: number): string {
|
|
89
|
+
const length = (_maxLength != null) ? _maxLength: 63;
|
|
90
|
+
|
|
91
|
+
assertArgument(length <= 255, "DNS encoded label cannot exceed 255", "length", length);
|
|
92
|
+
|
|
93
|
+
return hexlify(concat(ensNameSplit(name).map((comp) => {
|
|
94
|
+
assertArgument(comp.length <= length, `label ${ JSON.stringify(name) } exceeds ${ length } bytes`, "name", name);
|
|
95
|
+
|
|
96
|
+
const bytes = new Uint8Array(comp.length + 1);
|
|
97
|
+
bytes.set(comp, 1);
|
|
98
|
+
bytes[0] = bytes.length - 1;
|
|
99
|
+
return bytes;
|
|
100
|
+
}))) + "00";
|
|
101
|
+
}
|
package/src.ts/hash/solidity.ts
CHANGED
|
@@ -1,117 +1,117 @@
|
|
|
1
|
-
import { getAddress } from "../address/index.js";
|
|
2
|
-
import {
|
|
3
|
-
keccak256 as _keccak256, sha256 as _sha256
|
|
4
|
-
} from "../crypto/index.js";
|
|
5
|
-
import {
|
|
6
|
-
concat, dataLength, getBytes, hexlify, toBeArray, toTwos, toUtf8Bytes, zeroPadBytes, zeroPadValue,
|
|
7
|
-
assertArgument
|
|
8
|
-
} from "../utils/index.js";
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
const regexBytes = new RegExp("^bytes([0-9]+)$");
|
|
12
|
-
const regexNumber = new RegExp("^(u?int)([0-9]*)$");
|
|
13
|
-
const regexArray = new RegExp("^(.*)\\[([0-9]*)\\]$");
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
function _pack(type: string, value: any, isArray?: boolean): Uint8Array {
|
|
17
|
-
switch(type) {
|
|
18
|
-
case "address":
|
|
19
|
-
if (isArray) { return getBytes(zeroPadValue(value, 32)); }
|
|
20
|
-
return getBytes(getAddress(value));
|
|
21
|
-
case "string":
|
|
22
|
-
return toUtf8Bytes(value);
|
|
23
|
-
case "bytes":
|
|
24
|
-
return getBytes(value);
|
|
25
|
-
case "bool":
|
|
26
|
-
value = (!!value ? "0x01": "0x00");
|
|
27
|
-
if (isArray) { return getBytes(zeroPadValue(value, 32)); }
|
|
28
|
-
return getBytes(value);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
let match = type.match(regexNumber);
|
|
32
|
-
if (match) {
|
|
33
|
-
let signed = (match[1] === "int");
|
|
34
|
-
let size = parseInt(match[2] || "256")
|
|
35
|
-
|
|
36
|
-
assertArgument((!match[2] || match[2] === String(size)) && (size % 8 === 0) && size !== 0 && size <= 256, "invalid number type", "type", type);
|
|
37
|
-
|
|
38
|
-
if (isArray) { size = 256; }
|
|
39
|
-
|
|
40
|
-
if (signed) { value = toTwos(value, size); }
|
|
41
|
-
|
|
42
|
-
return getBytes(zeroPadValue(toBeArray(value), size / 8));
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
match = type.match(regexBytes);
|
|
46
|
-
if (match) {
|
|
47
|
-
const size = parseInt(match[1]);
|
|
48
|
-
|
|
49
|
-
assertArgument(String(size) === match[1] && size !== 0 && size <= 32, "invalid bytes type", "type", type);
|
|
50
|
-
assertArgument(dataLength(value) === size, `invalid value for ${ type }`, "value", value);
|
|
51
|
-
|
|
52
|
-
if (isArray) { return getBytes(zeroPadBytes(value, 32)); }
|
|
53
|
-
return value;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
match = type.match(regexArray);
|
|
57
|
-
if (match && Array.isArray(value)) {
|
|
58
|
-
const baseType = match[1];
|
|
59
|
-
const count = parseInt(match[2] || String(value.length));
|
|
60
|
-
assertArgument(count === value.length, `invalid array length for ${ type }`, "value", value);
|
|
61
|
-
|
|
62
|
-
const result: Array<Uint8Array> = [];
|
|
63
|
-
value.forEach(function(value) {
|
|
64
|
-
result.push(_pack(baseType, value, true));
|
|
65
|
-
});
|
|
66
|
-
return getBytes(concat(result));
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
assertArgument(false, "invalid type", "type", type)
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
// @TODO: Array Enum
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* Computes the [[link-solc-packed]] representation of %%values%%
|
|
76
|
-
* respectively to their %%types%%.
|
|
77
|
-
*
|
|
78
|
-
* @example:
|
|
79
|
-
* addr = "0x8ba1f109551bd432803012645ac136ddd64dba72"
|
|
80
|
-
* solidityPacked([ "address", "uint" ], [ addr, 45 ]);
|
|
81
|
-
* //_result:
|
|
82
|
-
*/
|
|
83
|
-
export function solidityPacked(types: ReadonlyArray<string>, values: ReadonlyArray<any>): string {
|
|
84
|
-
assertArgument(types.length === values.length, "wrong number of values; expected ${ types.length }", "values", values);
|
|
85
|
-
|
|
86
|
-
const tight: Array<Uint8Array> = [];
|
|
87
|
-
types.forEach(function(type, index) {
|
|
88
|
-
tight.push(_pack(type, values[index]));
|
|
89
|
-
});
|
|
90
|
-
return hexlify(concat(tight));
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
/**
|
|
94
|
-
* Computes the [[link-solc-packed]] [[keccak256]] hash of %%values%%
|
|
95
|
-
* respectively to their %%types%%.
|
|
96
|
-
*
|
|
97
|
-
* @example:
|
|
98
|
-
* addr = "0x8ba1f109551bd432803012645ac136ddd64dba72"
|
|
99
|
-
* solidityPackedKeccak256([ "address", "uint" ], [ addr, 45 ]);
|
|
100
|
-
* //_result:
|
|
101
|
-
*/
|
|
102
|
-
export function solidityPackedKeccak256(types: ReadonlyArray<string>, values: ReadonlyArray<any>): string {
|
|
103
|
-
return _keccak256(solidityPacked(types, values));
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* Computes the [[link-solc-packed]] [[sha256]] hash of %%values%%
|
|
108
|
-
* respectively to their %%types%%.
|
|
109
|
-
*
|
|
110
|
-
* @example:
|
|
111
|
-
* addr = "0x8ba1f109551bd432803012645ac136ddd64dba72"
|
|
112
|
-
* solidityPackedSha256([ "address", "uint" ], [ addr, 45 ]);
|
|
113
|
-
* //_result:
|
|
114
|
-
*/
|
|
115
|
-
export function solidityPackedSha256(types: ReadonlyArray<string>, values: ReadonlyArray<any>): string {
|
|
116
|
-
return _sha256(solidityPacked(types, values));
|
|
117
|
-
}
|
|
1
|
+
import { getAddress } from "../address/index.js";
|
|
2
|
+
import {
|
|
3
|
+
keccak256 as _keccak256, sha256 as _sha256
|
|
4
|
+
} from "../crypto/index.js";
|
|
5
|
+
import {
|
|
6
|
+
concat, dataLength, getBytes, hexlify, toBeArray, toTwos, toUtf8Bytes, zeroPadBytes, zeroPadValue,
|
|
7
|
+
assertArgument
|
|
8
|
+
} from "../utils/index.js";
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
const regexBytes = new RegExp("^bytes([0-9]+)$");
|
|
12
|
+
const regexNumber = new RegExp("^(u?int)([0-9]*)$");
|
|
13
|
+
const regexArray = new RegExp("^(.*)\\[([0-9]*)\\]$");
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
function _pack(type: string, value: any, isArray?: boolean): Uint8Array {
|
|
17
|
+
switch(type) {
|
|
18
|
+
case "address":
|
|
19
|
+
if (isArray) { return getBytes(zeroPadValue(value, 32)); }
|
|
20
|
+
return getBytes(getAddress(value));
|
|
21
|
+
case "string":
|
|
22
|
+
return toUtf8Bytes(value);
|
|
23
|
+
case "bytes":
|
|
24
|
+
return getBytes(value);
|
|
25
|
+
case "bool":
|
|
26
|
+
value = (!!value ? "0x01": "0x00");
|
|
27
|
+
if (isArray) { return getBytes(zeroPadValue(value, 32)); }
|
|
28
|
+
return getBytes(value);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
let match = type.match(regexNumber);
|
|
32
|
+
if (match) {
|
|
33
|
+
let signed = (match[1] === "int");
|
|
34
|
+
let size = parseInt(match[2] || "256")
|
|
35
|
+
|
|
36
|
+
assertArgument((!match[2] || match[2] === String(size)) && (size % 8 === 0) && size !== 0 && size <= 256, "invalid number type", "type", type);
|
|
37
|
+
|
|
38
|
+
if (isArray) { size = 256; }
|
|
39
|
+
|
|
40
|
+
if (signed) { value = toTwos(value, size); }
|
|
41
|
+
|
|
42
|
+
return getBytes(zeroPadValue(toBeArray(value), size / 8));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
match = type.match(regexBytes);
|
|
46
|
+
if (match) {
|
|
47
|
+
const size = parseInt(match[1]);
|
|
48
|
+
|
|
49
|
+
assertArgument(String(size) === match[1] && size !== 0 && size <= 32, "invalid bytes type", "type", type);
|
|
50
|
+
assertArgument(dataLength(value) === size, `invalid value for ${ type }`, "value", value);
|
|
51
|
+
|
|
52
|
+
if (isArray) { return getBytes(zeroPadBytes(value, 32)); }
|
|
53
|
+
return value;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
match = type.match(regexArray);
|
|
57
|
+
if (match && Array.isArray(value)) {
|
|
58
|
+
const baseType = match[1];
|
|
59
|
+
const count = parseInt(match[2] || String(value.length));
|
|
60
|
+
assertArgument(count === value.length, `invalid array length for ${ type }`, "value", value);
|
|
61
|
+
|
|
62
|
+
const result: Array<Uint8Array> = [];
|
|
63
|
+
value.forEach(function(value) {
|
|
64
|
+
result.push(_pack(baseType, value, true));
|
|
65
|
+
});
|
|
66
|
+
return getBytes(concat(result));
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
assertArgument(false, "invalid type", "type", type)
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// @TODO: Array Enum
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Computes the [[link-solc-packed]] representation of %%values%%
|
|
76
|
+
* respectively to their %%types%%.
|
|
77
|
+
*
|
|
78
|
+
* @example:
|
|
79
|
+
* addr = "0x8ba1f109551bd432803012645ac136ddd64dba72"
|
|
80
|
+
* solidityPacked([ "address", "uint" ], [ addr, 45 ]);
|
|
81
|
+
* //_result:
|
|
82
|
+
*/
|
|
83
|
+
export function solidityPacked(types: ReadonlyArray<string>, values: ReadonlyArray<any>): string {
|
|
84
|
+
assertArgument(types.length === values.length, "wrong number of values; expected ${ types.length }", "values", values);
|
|
85
|
+
|
|
86
|
+
const tight: Array<Uint8Array> = [];
|
|
87
|
+
types.forEach(function(type, index) {
|
|
88
|
+
tight.push(_pack(type, values[index]));
|
|
89
|
+
});
|
|
90
|
+
return hexlify(concat(tight));
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* Computes the [[link-solc-packed]] [[keccak256]] hash of %%values%%
|
|
95
|
+
* respectively to their %%types%%.
|
|
96
|
+
*
|
|
97
|
+
* @example:
|
|
98
|
+
* addr = "0x8ba1f109551bd432803012645ac136ddd64dba72"
|
|
99
|
+
* solidityPackedKeccak256([ "address", "uint" ], [ addr, 45 ]);
|
|
100
|
+
* //_result:
|
|
101
|
+
*/
|
|
102
|
+
export function solidityPackedKeccak256(types: ReadonlyArray<string>, values: ReadonlyArray<any>): string {
|
|
103
|
+
return _keccak256(solidityPacked(types, values));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Computes the [[link-solc-packed]] [[sha256]] hash of %%values%%
|
|
108
|
+
* respectively to their %%types%%.
|
|
109
|
+
*
|
|
110
|
+
* @example:
|
|
111
|
+
* addr = "0x8ba1f109551bd432803012645ac136ddd64dba72"
|
|
112
|
+
* solidityPackedSha256([ "address", "uint" ], [ addr, 45 ]);
|
|
113
|
+
* //_result:
|
|
114
|
+
*/
|
|
115
|
+
export function solidityPackedSha256(types: ReadonlyArray<string>, values: ReadonlyArray<any>): string {
|
|
116
|
+
return _sha256(solidityPacked(types, values));
|
|
117
|
+
}
|