ganach-cli 6.12.2
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of ganach-cli might be problematic. Click here for more details.
- package/LICENSE +22 -0
- package/README.md +381 -0
- package/cli.js +245 -0
- package/node_modules/@types/bn.js/LICENSE +21 -0
- package/node_modules/@types/bn.js/README.md +16 -0
- package/node_modules/@types/bn.js/index.d.ts +586 -0
- package/node_modules/@types/bn.js/package.json +40 -0
- package/node_modules/@types/node/LICENSE +21 -0
- package/node_modules/@types/node/README.md +16 -0
- package/node_modules/@types/node/assert.d.ts +84 -0
- package/node_modules/@types/node/async_hooks.d.ts +226 -0
- package/node_modules/@types/node/base.d.ts +20 -0
- package/node_modules/@types/node/buffer.d.ts +22 -0
- package/node_modules/@types/node/child_process.d.ts +505 -0
- package/node_modules/@types/node/cluster.d.ts +262 -0
- package/node_modules/@types/node/console.d.ts +133 -0
- package/node_modules/@types/node/constants.d.ts +8 -0
- package/node_modules/@types/node/crypto.d.ts +707 -0
- package/node_modules/@types/node/dgram.d.ts +141 -0
- package/node_modules/@types/node/dns.d.ts +371 -0
- package/node_modules/@types/node/domain.d.ts +24 -0
- package/node_modules/@types/node/events.d.ts +83 -0
- package/node_modules/@types/node/fs/promises.d.ts +539 -0
- package/node_modules/@types/node/fs.d.ts +2156 -0
- package/node_modules/@types/node/globals.d.ts +606 -0
- package/node_modules/@types/node/globals.global.d.ts +1 -0
- package/node_modules/@types/node/http.d.ts +414 -0
- package/node_modules/@types/node/http2.d.ts +952 -0
- package/node_modules/@types/node/https.d.ts +37 -0
- package/node_modules/@types/node/index.d.ts +61 -0
- package/node_modules/@types/node/inspector.d.ts +3041 -0
- package/node_modules/@types/node/module.d.ts +52 -0
- package/node_modules/@types/node/net.d.ts +268 -0
- package/node_modules/@types/node/os.d.ts +239 -0
- package/node_modules/@types/node/package.json +255 -0
- package/node_modules/@types/node/path.d.ts +153 -0
- package/node_modules/@types/node/perf_hooks.d.ts +271 -0
- package/node_modules/@types/node/process.d.ts +406 -0
- package/node_modules/@types/node/punycode.d.ts +12 -0
- package/node_modules/@types/node/querystring.d.ts +28 -0
- package/node_modules/@types/node/readline.d.ts +171 -0
- package/node_modules/@types/node/repl.d.ts +387 -0
- package/node_modules/@types/node/stream.d.ts +351 -0
- package/node_modules/@types/node/string_decoder.d.ts +7 -0
- package/node_modules/@types/node/timers.d.ts +16 -0
- package/node_modules/@types/node/tls.d.ts +777 -0
- package/node_modules/@types/node/trace_events.d.ts +61 -0
- package/node_modules/@types/node/ts3.4/assert.d.ts +57 -0
- package/node_modules/@types/node/ts3.4/base.d.ts +56 -0
- package/node_modules/@types/node/ts3.4/globals.global.d.ts +1 -0
- package/node_modules/@types/node/ts3.4/index.d.ts +8 -0
- package/node_modules/@types/node/ts3.6/base.d.ts +23 -0
- package/node_modules/@types/node/ts3.6/index.d.ts +8 -0
- package/node_modules/@types/node/tty.d.ts +66 -0
- package/node_modules/@types/node/url.d.ts +110 -0
- package/node_modules/@types/node/util.d.ts +196 -0
- package/node_modules/@types/node/v8.d.ts +187 -0
- package/node_modules/@types/node/vm.d.ts +146 -0
- package/node_modules/@types/node/wasi.d.ts +52 -0
- package/node_modules/@types/node/worker_threads.d.ts +192 -0
- package/node_modules/@types/node/zlib.d.ts +352 -0
- package/node_modules/@types/pbkdf2/LICENSE +21 -0
- package/node_modules/@types/pbkdf2/README.md +16 -0
- package/node_modules/@types/pbkdf2/index.d.ts +41 -0
- package/node_modules/@types/pbkdf2/package.json +30 -0
- package/node_modules/@types/secp256k1/LICENSE +21 -0
- package/node_modules/@types/secp256k1/README.md +16 -0
- package/node_modules/@types/secp256k1/index.d.ts +141 -0
- package/node_modules/@types/secp256k1/package.json +30 -0
- package/node_modules/ansi-regex/index.js +14 -0
- package/node_modules/ansi-regex/license +9 -0
- package/node_modules/ansi-regex/package.json +57 -0
- package/node_modules/ansi-regex/readme.md +87 -0
- package/node_modules/ansi-styles/index.js +165 -0
- package/node_modules/ansi-styles/license +9 -0
- package/node_modules/ansi-styles/package.json +60 -0
- package/node_modules/ansi-styles/readme.md +147 -0
- package/node_modules/base-x/LICENSE.md +22 -0
- package/node_modules/base-x/README.md +67 -0
- package/node_modules/base-x/package.json +53 -0
- package/node_modules/base-x/src/index.d.ts +10 -0
- package/node_modules/base-x/src/index.js +123 -0
- package/node_modules/blakejs/.npmignore +1 -0
- package/node_modules/blakejs/.travis.yml +3 -0
- package/node_modules/blakejs/README.md +112 -0
- package/node_modules/blakejs/blake2b.js +273 -0
- package/node_modules/blakejs/blake2s.js +190 -0
- package/node_modules/blakejs/generated_test_vectors.txt +100 -0
- package/node_modules/blakejs/index.js +15 -0
- package/node_modules/blakejs/package.json +27 -0
- package/node_modules/blakejs/test_blake2b.js +88 -0
- package/node_modules/blakejs/test_blake2s.js +80 -0
- package/node_modules/blakejs/util.js +81 -0
- package/node_modules/bn.js/README.md +221 -0
- package/node_modules/bn.js/lib/bn.js +3433 -0
- package/node_modules/bn.js/package.json +40 -0
- package/node_modules/bn.js/util/genCombMulTo.js +65 -0
- package/node_modules/bn.js/util/genCombMulTo10.js +65 -0
- package/node_modules/brorand/.npmignore +2 -0
- package/node_modules/brorand/README.md +26 -0
- package/node_modules/brorand/index.js +65 -0
- package/node_modules/brorand/package.json +35 -0
- package/node_modules/brorand/test/api-test.js +8 -0
- package/node_modules/browserify-aes/.travis.yml +15 -0
- package/node_modules/browserify-aes/LICENSE +21 -0
- package/node_modules/browserify-aes/README.md +19 -0
- package/node_modules/browserify-aes/aes.js +228 -0
- package/node_modules/browserify-aes/authCipher.js +117 -0
- package/node_modules/browserify-aes/browser.js +13 -0
- package/node_modules/browserify-aes/decrypter.js +124 -0
- package/node_modules/browserify-aes/encrypter.js +114 -0
- package/node_modules/browserify-aes/ghash.js +89 -0
- package/node_modules/browserify-aes/incr32.js +15 -0
- package/node_modules/browserify-aes/index.js +7 -0
- package/node_modules/browserify-aes/modes/cbc.js +17 -0
- package/node_modules/browserify-aes/modes/cfb.js +33 -0
- package/node_modules/browserify-aes/modes/cfb1.js +42 -0
- package/node_modules/browserify-aes/modes/cfb8.js +25 -0
- package/node_modules/browserify-aes/modes/ctr.js +30 -0
- package/node_modules/browserify-aes/modes/ecb.js +7 -0
- package/node_modules/browserify-aes/modes/index.js +18 -0
- package/node_modules/browserify-aes/modes/list.json +191 -0
- package/node_modules/browserify-aes/modes/ofb.js +16 -0
- package/node_modules/browserify-aes/package.json +47 -0
- package/node_modules/browserify-aes/streamCipher.js +27 -0
- package/node_modules/bs58/README.md +71 -0
- package/node_modules/bs58/index.js +4 -0
- package/node_modules/bs58/package.json +41 -0
- package/node_modules/bs58check/LICENSE +21 -0
- package/node_modules/bs58check/README.md +27 -0
- package/node_modules/bs58check/base.js +50 -0
- package/node_modules/bs58check/index.js +12 -0
- package/node_modules/bs58check/package.json +56 -0
- package/node_modules/buffer-from/LICENSE +21 -0
- package/node_modules/buffer-from/index.js +69 -0
- package/node_modules/buffer-from/package.json +23 -0
- package/node_modules/buffer-from/readme.md +69 -0
- package/node_modules/buffer-xor/.npmignore +1 -0
- package/node_modules/buffer-xor/.travis.yml +9 -0
- package/node_modules/buffer-xor/LICENSE +21 -0
- package/node_modules/buffer-xor/README.md +41 -0
- package/node_modules/buffer-xor/index.js +10 -0
- package/node_modules/buffer-xor/inline.js +1 -0
- package/node_modules/buffer-xor/inplace.js +9 -0
- package/node_modules/buffer-xor/package.json +41 -0
- package/node_modules/buffer-xor/test/fixtures.json +23 -0
- package/node_modules/buffer-xor/test/index.js +38 -0
- package/node_modules/camelcase/index.d.ts +63 -0
- package/node_modules/camelcase/index.js +76 -0
- package/node_modules/camelcase/license +9 -0
- package/node_modules/camelcase/package.json +47 -0
- package/node_modules/camelcase/readme.md +99 -0
- package/node_modules/cipher-base/.eslintrc +3 -0
- package/node_modules/cipher-base/.npmignore +1 -0
- package/node_modules/cipher-base/.travis.yml +6 -0
- package/node_modules/cipher-base/LICENSE +21 -0
- package/node_modules/cipher-base/README.md +17 -0
- package/node_modules/cipher-base/index.js +99 -0
- package/node_modules/cipher-base/package.json +36 -0
- package/node_modules/cipher-base/test.js +111 -0
- package/node_modules/cliui/LICENSE.txt +14 -0
- package/node_modules/cliui/README.md +115 -0
- package/node_modules/cliui/index.js +324 -0
- package/node_modules/cliui/package.json +71 -0
- package/node_modules/color-convert/LICENSE +21 -0
- package/node_modules/color-convert/README.md +68 -0
- package/node_modules/color-convert/conversions.js +868 -0
- package/node_modules/color-convert/index.js +78 -0
- package/node_modules/color-convert/package.json +50 -0
- package/node_modules/color-convert/route.js +97 -0
- package/node_modules/color-name/.eslintrc.json +43 -0
- package/node_modules/color-name/.npmignore +107 -0
- package/node_modules/color-name/LICENSE +8 -0
- package/node_modules/color-name/README.md +11 -0
- package/node_modules/color-name/index.js +152 -0
- package/node_modules/color-name/package.json +29 -0
- package/node_modules/color-name/test.js +7 -0
- package/node_modules/create-hash/.travis.yml +17 -0
- package/node_modules/create-hash/LICENSE +21 -0
- package/node_modules/create-hash/README.md +19 -0
- package/node_modules/create-hash/browser.js +30 -0
- package/node_modules/create-hash/index.js +1 -0
- package/node_modules/create-hash/md5.js +5 -0
- package/node_modules/create-hash/package.json +43 -0
- package/node_modules/create-hash/test.js +41 -0
- package/node_modules/create-hmac/LICENSE +21 -0
- package/node_modules/create-hmac/README.md +20 -0
- package/node_modules/create-hmac/browser.js +62 -0
- package/node_modules/create-hmac/index.js +1 -0
- package/node_modules/create-hmac/legacy.js +46 -0
- package/node_modules/create-hmac/package.json +49 -0
- package/node_modules/cross-spawn/LICENSE +21 -0
- package/node_modules/cross-spawn/README.md +94 -0
- package/node_modules/cross-spawn/index.js +39 -0
- package/node_modules/cross-spawn/lib/enoent.js +59 -0
- package/node_modules/cross-spawn/lib/parse.js +125 -0
- package/node_modules/cross-spawn/lib/util/escape.js +45 -0
- package/node_modules/cross-spawn/lib/util/readShebang.js +32 -0
- package/node_modules/cross-spawn/lib/util/resolveCommand.js +47 -0
- package/node_modules/cross-spawn/package.json +80 -0
- package/node_modules/decamelize/index.js +13 -0
- package/node_modules/decamelize/license +21 -0
- package/node_modules/decamelize/package.json +42 -0
- package/node_modules/decamelize/readme.md +48 -0
- package/node_modules/elliptic/README.md +238 -0
- package/node_modules/elliptic/lib/elliptic/curve/base.js +376 -0
- package/node_modules/elliptic/lib/elliptic/curve/edwards.js +432 -0
- package/node_modules/elliptic/lib/elliptic/curve/index.js +8 -0
- package/node_modules/elliptic/lib/elliptic/curve/mont.js +178 -0
- package/node_modules/elliptic/lib/elliptic/curve/short.js +937 -0
- package/node_modules/elliptic/lib/elliptic/curves.js +206 -0
- package/node_modules/elliptic/lib/elliptic/ec/index.js +241 -0
- package/node_modules/elliptic/lib/elliptic/ec/key.js +118 -0
- package/node_modules/elliptic/lib/elliptic/ec/signature.js +166 -0
- package/node_modules/elliptic/lib/elliptic/eddsa/index.js +118 -0
- package/node_modules/elliptic/lib/elliptic/eddsa/key.js +95 -0
- package/node_modules/elliptic/lib/elliptic/eddsa/signature.js +65 -0
- package/node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js +780 -0
- package/node_modules/elliptic/lib/elliptic/utils.js +119 -0
- package/node_modules/elliptic/lib/elliptic.js +13 -0
- package/node_modules/elliptic/package.json +62 -0
- package/node_modules/emoji-regex/LICENSE-MIT.txt +20 -0
- package/node_modules/emoji-regex/README.md +73 -0
- package/node_modules/emoji-regex/es2015/index.js +6 -0
- package/node_modules/emoji-regex/es2015/text.js +6 -0
- package/node_modules/emoji-regex/index.d.ts +5 -0
- package/node_modules/emoji-regex/index.js +6 -0
- package/node_modules/emoji-regex/package.json +55 -0
- package/node_modules/emoji-regex/text.js +6 -0
- package/node_modules/end-of-stream/LICENSE +21 -0
- package/node_modules/end-of-stream/README.md +54 -0
- package/node_modules/end-of-stream/index.js +94 -0
- package/node_modules/end-of-stream/package.json +41 -0
- package/node_modules/ethereum-cryptography/LICENSE +26 -0
- package/node_modules/ethereum-cryptography/README.md +560 -0
- package/node_modules/ethereum-cryptography/aes.d.ts +4 -0
- package/node_modules/ethereum-cryptography/aes.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/aes.js +38 -0
- package/node_modules/ethereum-cryptography/aes.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/index.d.ts +8 -0
- package/node_modules/ethereum-cryptography/bip39/index.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/index.js +71 -0
- package/node_modules/ethereum-cryptography/bip39/index.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/czech.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/czech.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/czech.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/czech.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/english.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/english.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/english.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/english.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/french.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/french.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/french.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/french.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/italian.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/italian.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/italian.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/italian.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/japanese.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/japanese.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/japanese.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/japanese.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/korean.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/korean.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/korean.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/korean.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/simplified-chinese.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/simplified-chinese.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/simplified-chinese.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/simplified-chinese.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/spanish.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/spanish.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/spanish.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/spanish.js.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/traditional-chinese.d.ts +2 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/traditional-chinese.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/traditional-chinese.js +2053 -0
- package/node_modules/ethereum-cryptography/bip39/wordlists/traditional-chinese.js.map +1 -0
- package/node_modules/ethereum-cryptography/blake2b.d.ts +3 -0
- package/node_modules/ethereum-cryptography/blake2b.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/blake2b.js +12 -0
- package/node_modules/ethereum-cryptography/blake2b.js.map +1 -0
- package/node_modules/ethereum-cryptography/hash-utils.d.ts +4 -0
- package/node_modules/ethereum-cryptography/hash-utils.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/hash-utils.js +11 -0
- package/node_modules/ethereum-cryptography/hash-utils.js.map +1 -0
- package/node_modules/ethereum-cryptography/hdkey.d.ts +3 -0
- package/node_modules/ethereum-cryptography/hdkey.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/hdkey.js +5 -0
- package/node_modules/ethereum-cryptography/hdkey.js.map +1 -0
- package/node_modules/ethereum-cryptography/index.d.ts +1 -0
- package/node_modules/ethereum-cryptography/index.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/index.js +3 -0
- package/node_modules/ethereum-cryptography/index.js.map +1 -0
- package/node_modules/ethereum-cryptography/keccak.d.ts +6 -0
- package/node_modules/ethereum-cryptography/keccak.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/keccak.js +17 -0
- package/node_modules/ethereum-cryptography/keccak.js.map +1 -0
- package/node_modules/ethereum-cryptography/package.json +131 -0
- package/node_modules/ethereum-cryptography/pbkdf2.d.ts +4 -0
- package/node_modules/ethereum-cryptography/pbkdf2.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/pbkdf2.js +27 -0
- package/node_modules/ethereum-cryptography/pbkdf2.js.map +1 -0
- package/node_modules/ethereum-cryptography/pure/hdkey.d.ts +37 -0
- package/node_modules/ethereum-cryptography/pure/hdkey.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/pure/hdkey.js +5 -0
- package/node_modules/ethereum-cryptography/pure/hdkey.js.map +1 -0
- package/node_modules/ethereum-cryptography/pure/ripemd160.d.ts +3 -0
- package/node_modules/ethereum-cryptography/pure/ripemd160.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/pure/ripemd160.js +6 -0
- package/node_modules/ethereum-cryptography/pure/ripemd160.js.map +1 -0
- package/node_modules/ethereum-cryptography/pure/sha256.d.ts +3 -0
- package/node_modules/ethereum-cryptography/pure/sha256.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/pure/sha256.js +6 -0
- package/node_modules/ethereum-cryptography/pure/sha256.js.map +1 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-crypto.d.ts +13 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-crypto.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-crypto.js +37 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-crypto.js.map +1 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-secp256k1v3.d.ts +2 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-secp256k1v3.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-secp256k1v3.js +7 -0
- package/node_modules/ethereum-cryptography/pure/shims/hdkey-secp256k1v3.js.map +1 -0
- package/node_modules/ethereum-cryptography/pure/vendor/hdkey-without-crypto.js +255 -0
- package/node_modules/ethereum-cryptography/random.d.ts +4 -0
- package/node_modules/ethereum-cryptography/random.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/random.js +20 -0
- package/node_modules/ethereum-cryptography/random.js.map +1 -0
- package/node_modules/ethereum-cryptography/ripemd160.d.ts +3 -0
- package/node_modules/ethereum-cryptography/ripemd160.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/ripemd160.js +11 -0
- package/node_modules/ethereum-cryptography/ripemd160.js.map +1 -0
- package/node_modules/ethereum-cryptography/scrypt.d.ts +5 -0
- package/node_modules/ethereum-cryptography/scrypt.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/scrypt.js +59 -0
- package/node_modules/ethereum-cryptography/scrypt.js.map +1 -0
- package/node_modules/ethereum-cryptography/secp256k1.d.ts +4 -0
- package/node_modules/ethereum-cryptography/secp256k1.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/secp256k1.js +75 -0
- package/node_modules/ethereum-cryptography/secp256k1.js.map +1 -0
- package/node_modules/ethereum-cryptography/sha256.d.ts +3 -0
- package/node_modules/ethereum-cryptography/sha256.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/sha256.js +9 -0
- package/node_modules/ethereum-cryptography/sha256.js.map +1 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-crypto.d.ts +2 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-crypto.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-crypto.js +7 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-crypto.js.map +1 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-secp256k1v3.d.ts +13 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-secp256k1v3.d.ts.map +1 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-secp256k1v3.js +47 -0
- package/node_modules/ethereum-cryptography/shims/hdkey-secp256k1v3.js.map +1 -0
- package/node_modules/ethereum-cryptography/src/aes.ts +52 -0
- package/node_modules/ethereum-cryptography/src/bip39/index.ts +40 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/czech.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/english.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/french.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/italian.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/japanese.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/korean.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/simplified-chinese.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/spanish.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/bip39/wordlists/traditional-chinese.ts +2050 -0
- package/node_modules/ethereum-cryptography/src/blake2b.ts +9 -0
- package/node_modules/ethereum-cryptography/src/hash-utils.ts +11 -0
- package/node_modules/ethereum-cryptography/src/hdkey.ts +5 -0
- package/node_modules/ethereum-cryptography/src/index.ts +3 -0
- package/node_modules/ethereum-cryptography/src/keccak.ts +19 -0
- package/node_modules/ethereum-cryptography/src/pbkdf2.ts +37 -0
- package/node_modules/ethereum-cryptography/src/pure/hdkey.ts +36 -0
- package/node_modules/ethereum-cryptography/src/pure/ripemd160.ts +5 -0
- package/node_modules/ethereum-cryptography/src/pure/sha256.ts +5 -0
- package/node_modules/ethereum-cryptography/src/pure/shims/hdkey-crypto.ts +42 -0
- package/node_modules/ethereum-cryptography/src/pure/shims/hdkey-secp256k1v3.ts +1 -0
- package/node_modules/ethereum-cryptography/src/pure/vendor/hdkey-without-crypto.js +255 -0
- package/node_modules/ethereum-cryptography/src/random.ts +18 -0
- package/node_modules/ethereum-cryptography/src/ripemd160.ts +7 -0
- package/node_modules/ethereum-cryptography/src/scrypt.ts +24 -0
- package/node_modules/ethereum-cryptography/src/secp256k1.ts +24 -0
- package/node_modules/ethereum-cryptography/src/sha256.ts +5 -0
- package/node_modules/ethereum-cryptography/src/shims/hdkey-crypto.ts +1 -0
- package/node_modules/ethereum-cryptography/src/shims/hdkey-secp256k1v3.ts +49 -0
- package/node_modules/ethereum-cryptography/src/vendor/bip39-without-wordlists.js +206 -0
- package/node_modules/ethereum-cryptography/src/vendor/hdkey-without-crypto.js +255 -0
- package/node_modules/ethereum-cryptography/vendor/bip39-without-wordlists.js +206 -0
- package/node_modules/ethereum-cryptography/vendor/hdkey-without-crypto.js +255 -0
- package/node_modules/ethereumjs-util/LICENSE +373 -0
- package/node_modules/ethereumjs-util/README.md +32 -0
- package/node_modules/ethereumjs-util/dist/account.d.ts +80 -0
- package/node_modules/ethereumjs-util/dist/account.js +168 -0
- package/node_modules/ethereumjs-util/dist/account.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/bytes.d.ts +68 -0
- package/node_modules/ethereumjs-util/dist/bytes.js +158 -0
- package/node_modules/ethereumjs-util/dist/bytes.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/constants.d.ts +34 -0
- package/node_modules/ethereumjs-util/dist/constants.js +37 -0
- package/node_modules/ethereumjs-util/dist/constants.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/hash.d.ts +30 -0
- package/node_modules/ethereumjs-util/dist/hash.js +84 -0
- package/node_modules/ethereumjs-util/dist/hash.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/index.d.ts +39 -0
- package/node_modules/ethereumjs-util/dist/index.js +46 -0
- package/node_modules/ethereumjs-util/dist/index.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/object.d.ts +12 -0
- package/node_modules/ethereumjs-util/dist/object.js +106 -0
- package/node_modules/ethereumjs-util/dist/object.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-adapter.d.ts +178 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-adapter.js +300 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-adapter.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-lib/der.d.ts +1 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-lib/der.js +634 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-lib/der.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-lib/index.d.ts +5 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-lib/index.js +61 -0
- package/node_modules/ethereumjs-util/dist/secp256k1v3-lib/index.js.map +1 -0
- package/node_modules/ethereumjs-util/dist/signature.d.ts +37 -0
- package/node_modules/ethereumjs-util/dist/signature.js +107 -0
- package/node_modules/ethereumjs-util/dist/signature.js.map +1 -0
- package/node_modules/ethereumjs-util/package.json +131 -0
- package/node_modules/ethjs-util/LICENSE +21 -0
- package/node_modules/ethjs-util/README.md +143 -0
- package/node_modules/ethjs-util/dist/ethjs-util.js +2420 -0
- package/node_modules/ethjs-util/dist/ethjs-util.js.map +1 -0
- package/node_modules/ethjs-util/dist/ethjs-util.min.js +1 -0
- package/node_modules/ethjs-util/internals/webpack/webpack.config.js +58 -0
- package/node_modules/ethjs-util/lib/index.js +220 -0
- package/node_modules/ethjs-util/lib/tests/test.index.js +357 -0
- package/node_modules/ethjs-util/package.json +229 -0
- package/node_modules/ethjs-util/src/index.js +203 -0
- package/node_modules/ethjs-util/src/tests/test.index.js +382 -0
- package/node_modules/evp_bytestokey/LICENSE +21 -0
- package/node_modules/evp_bytestokey/README.md +51 -0
- package/node_modules/evp_bytestokey/index.js +45 -0
- package/node_modules/evp_bytestokey/package.json +49 -0
- package/node_modules/execa/index.js +361 -0
- package/node_modules/execa/lib/errname.js +39 -0
- package/node_modules/execa/lib/stdio.js +41 -0
- package/node_modules/execa/license +9 -0
- package/node_modules/execa/package.json +73 -0
- package/node_modules/execa/readme.md +327 -0
- package/node_modules/find-up/index.js +46 -0
- package/node_modules/find-up/license +9 -0
- package/node_modules/find-up/package.json +54 -0
- package/node_modules/find-up/readme.md +87 -0
- package/node_modules/get-caller-file/LICENSE.md +6 -0
- package/node_modules/get-caller-file/README.md +41 -0
- package/node_modules/get-caller-file/index.d.ts +2 -0
- package/node_modules/get-caller-file/index.js +22 -0
- package/node_modules/get-caller-file/index.js.map +1 -0
- package/node_modules/get-caller-file/package.json +46 -0
- package/node_modules/get-stream/buffer-stream.js +51 -0
- package/node_modules/get-stream/index.js +50 -0
- package/node_modules/get-stream/license +9 -0
- package/node_modules/get-stream/package.json +50 -0
- package/node_modules/get-stream/readme.md +123 -0
- package/node_modules/hash-base/LICENSE +21 -0
- package/node_modules/hash-base/README.md +48 -0
- package/node_modules/hash-base/index.js +95 -0
- package/node_modules/hash-base/package.json +46 -0
- package/node_modules/hash.js/.eslintrc.js +41 -0
- package/node_modules/hash.js/.travis.yml +10 -0
- package/node_modules/hash.js/README.md +48 -0
- package/node_modules/hash.js/lib/hash/common.js +92 -0
- package/node_modules/hash.js/lib/hash/hmac.js +47 -0
- package/node_modules/hash.js/lib/hash/ripemd.js +146 -0
- package/node_modules/hash.js/lib/hash/sha/1.js +74 -0
- package/node_modules/hash.js/lib/hash/sha/224.js +30 -0
- package/node_modules/hash.js/lib/hash/sha/256.js +105 -0
- package/node_modules/hash.js/lib/hash/sha/384.js +35 -0
- package/node_modules/hash.js/lib/hash/sha/512.js +330 -0
- package/node_modules/hash.js/lib/hash/sha/common.js +49 -0
- package/node_modules/hash.js/lib/hash/sha.js +7 -0
- package/node_modules/hash.js/lib/hash/utils.js +278 -0
- package/node_modules/hash.js/lib/hash.d.ts +106 -0
- package/node_modules/hash.js/lib/hash.js +15 -0
- package/node_modules/hash.js/package.json +39 -0
- package/node_modules/hash.js/test/hash-test.js +140 -0
- package/node_modules/hash.js/test/hmac-test.js +62 -0
- package/node_modules/hmac-drbg/.npmignore +2 -0
- package/node_modules/hmac-drbg/.travis.yml +11 -0
- package/node_modules/hmac-drbg/README.md +48 -0
- package/node_modules/hmac-drbg/lib/hmac-drbg.js +113 -0
- package/node_modules/hmac-drbg/package.json +36 -0
- package/node_modules/hmac-drbg/test/drbg-test.js +91 -0
- package/node_modules/hmac-drbg/test/fixtures/hmac-drbg-nist.json +332 -0
- package/node_modules/inherits/LICENSE +16 -0
- package/node_modules/inherits/README.md +42 -0
- package/node_modules/inherits/inherits.js +9 -0
- package/node_modules/inherits/inherits_browser.js +27 -0
- package/node_modules/inherits/package.json +33 -0
- package/node_modules/invert-kv/index.js +15 -0
- package/node_modules/invert-kv/license +9 -0
- package/node_modules/invert-kv/package.json +36 -0
- package/node_modules/invert-kv/readme.md +25 -0
- package/node_modules/is-fullwidth-code-point/index.js +46 -0
- package/node_modules/is-fullwidth-code-point/license +21 -0
- package/node_modules/is-fullwidth-code-point/package.json +49 -0
- package/node_modules/is-fullwidth-code-point/readme.md +39 -0
- package/node_modules/is-hex-prefixed/.editorconfig +7 -0
- package/node_modules/is-hex-prefixed/.gitattributes +106 -0
- package/node_modules/is-hex-prefixed/.npmignore +8 -0
- package/node_modules/is-hex-prefixed/.travis.yml +5 -0
- package/node_modules/is-hex-prefixed/CHANGELOG.md +7 -0
- package/node_modules/is-hex-prefixed/LICENSE +21 -0
- package/node_modules/is-hex-prefixed/README.md +101 -0
- package/node_modules/is-hex-prefixed/package.json +43 -0
- package/node_modules/is-hex-prefixed/src/index.js +13 -0
- package/node_modules/is-hex-prefixed/src/tests/test.index.js +66 -0
- package/node_modules/is-stream/index.js +21 -0
- package/node_modules/is-stream/license +21 -0
- package/node_modules/is-stream/package.json +42 -0
- package/node_modules/is-stream/readme.md +42 -0
- package/node_modules/isexe/.npmignore +2 -0
- package/node_modules/isexe/LICENSE +15 -0
- package/node_modules/isexe/README.md +51 -0
- package/node_modules/isexe/index.js +57 -0
- package/node_modules/isexe/mode.js +41 -0
- package/node_modules/isexe/package.json +35 -0
- package/node_modules/isexe/test/basic.js +221 -0
- package/node_modules/isexe/windows.js +42 -0
- package/node_modules/keccak/LICENSE +21 -0
- package/node_modules/keccak/README.md +64 -0
- package/node_modules/keccak/binding.gyp +78 -0
- package/node_modules/keccak/bindings.js +1 -0
- package/node_modules/keccak/index.js +5 -0
- package/node_modules/keccak/js.js +1 -0
- package/node_modules/keccak/lib/api/index.js +27 -0
- package/node_modules/keccak/lib/api/keccak.js +77 -0
- package/node_modules/keccak/lib/api/shake.js +68 -0
- package/node_modules/keccak/lib/keccak-state-reference.js +143 -0
- package/node_modules/keccak/lib/keccak-state-unroll.js +186 -0
- package/node_modules/keccak/lib/keccak.js +68 -0
- package/node_modules/keccak/package.json +41 -0
- package/node_modules/keccak/prebuilds/darwin-x64/node.napi.node +0 -0
- package/node_modules/keccak/prebuilds/linux-x64/node.napi.glibc.node +0 -0
- package/node_modules/keccak/prebuilds/linux-x64/node.napi.musl.node +0 -0
- package/node_modules/keccak/prebuilds/win32-x64/node.napi.node +0 -0
- package/node_modules/keccak/src/README.md +28 -0
- package/node_modules/keccak/src/addon.cc +98 -0
- package/node_modules/keccak/src/libkeccak-32/KeccakP-1600-SnP.h +38 -0
- package/node_modules/keccak/src/libkeccak-32/KeccakP-1600-inplace32BI.c +1162 -0
- package/node_modules/keccak/src/libkeccak-32/KeccakSponge-common.h +35 -0
- package/node_modules/keccak/src/libkeccak-32/KeccakSponge.inc +311 -0
- package/node_modules/keccak/src/libkeccak-32/KeccakSpongeWidth1600.c +54 -0
- package/node_modules/keccak/src/libkeccak-32/KeccakSpongeWidth1600.h +31 -0
- package/node_modules/keccak/src/libkeccak-32/SnP-Relaned.h +140 -0
- package/node_modules/keccak/src/libkeccak-32/align.h +32 -0
- package/node_modules/keccak/src/libkeccak-32/brg_endian.h +143 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakP-1600-64.macros +745 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakP-1600-SnP.h +51 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakP-1600-opt64-config.h +6 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakP-1600-opt64.c +564 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakP-1600-unrolling.macros +302 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakSponge-common.h +35 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakSponge.inc +311 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakSpongeWidth1600.c +54 -0
- package/node_modules/keccak/src/libkeccak-64/KeccakSpongeWidth1600.h +31 -0
- package/node_modules/keccak/src/libkeccak-64/SnP-Relaned.h +140 -0
- package/node_modules/keccak/src/libkeccak-64/align.h +32 -0
- package/node_modules/keccak/src/libkeccak-64/brg_endian.h +143 -0
- package/node_modules/lcid/index.js +23 -0
- package/node_modules/lcid/lcid.json +203 -0
- package/node_modules/lcid/license +9 -0
- package/node_modules/lcid/package.json +51 -0
- package/node_modules/lcid/readme.md +35 -0
- package/node_modules/locate-path/index.js +24 -0
- package/node_modules/locate-path/license +9 -0
- package/node_modules/locate-path/package.json +48 -0
- package/node_modules/locate-path/readme.md +99 -0
- package/node_modules/map-age-cleaner/dist/index.d.ts +20 -0
- package/node_modules/map-age-cleaner/dist/index.js +92 -0
- package/node_modules/map-age-cleaner/license +9 -0
- package/node_modules/map-age-cleaner/package.json +63 -0
- package/node_modules/map-age-cleaner/readme.md +67 -0
- package/node_modules/md5.js/LICENSE +21 -0
- package/node_modules/md5.js/README.md +29 -0
- package/node_modules/md5.js/index.js +146 -0
- package/node_modules/md5.js/package.json +42 -0
- package/node_modules/mem/index.d.ts +96 -0
- package/node_modules/mem/index.js +88 -0
- package/node_modules/mem/license +9 -0
- package/node_modules/mem/package.json +50 -0
- package/node_modules/mem/readme.md +167 -0
- package/node_modules/mimic-fn/index.d.ts +54 -0
- package/node_modules/mimic-fn/index.js +13 -0
- package/node_modules/mimic-fn/license +9 -0
- package/node_modules/mimic-fn/package.json +46 -0
- package/node_modules/mimic-fn/readme.md +69 -0
- package/node_modules/minimalistic-assert/LICENSE +13 -0
- package/node_modules/minimalistic-assert/index.js +11 -0
- package/node_modules/minimalistic-assert/package.json +23 -0
- package/node_modules/minimalistic-assert/readme.md +4 -0
- package/node_modules/minimalistic-crypto-utils/.npmignore +2 -0
- package/node_modules/minimalistic-crypto-utils/.travis.yml +11 -0
- package/node_modules/minimalistic-crypto-utils/README.md +47 -0
- package/node_modules/minimalistic-crypto-utils/lib/utils.js +58 -0
- package/node_modules/minimalistic-crypto-utils/package.json +31 -0
- package/node_modules/minimalistic-crypto-utils/test/utils-test.js +28 -0
- package/node_modules/nice-try/LICENSE +21 -0
- package/node_modules/nice-try/README.md +32 -0
- package/node_modules/nice-try/package.json +37 -0
- package/node_modules/nice-try/src/index.js +12 -0
- package/node_modules/node-addon-api/.editorconfig +8 -0
- package/node_modules/node-addon-api/.travis.yml +62 -0
- package/node_modules/node-addon-api/CHANGELOG.md +412 -0
- package/node_modules/node-addon-api/CODE_OF_CONDUCT.md +4 -0
- package/node_modules/node-addon-api/CONTRIBUTING.md +66 -0
- package/node_modules/node-addon-api/LICENSE.md +13 -0
- package/node_modules/node-addon-api/README.md +203 -0
- package/node_modules/node-addon-api/appveyor.yml +48 -0
- package/node_modules/node-addon-api/doc/Doxyfile +2450 -0
- package/node_modules/node-addon-api/doc/array_buffer.md +129 -0
- package/node_modules/node-addon-api/doc/async_context.md +86 -0
- package/node_modules/node-addon-api/doc/async_operations.md +31 -0
- package/node_modules/node-addon-api/doc/async_progress_worker.md +344 -0
- package/node_modules/node-addon-api/doc/async_worker.md +398 -0
- package/node_modules/node-addon-api/doc/basic_types.md +423 -0
- package/node_modules/node-addon-api/doc/bigint.md +92 -0
- package/node_modules/node-addon-api/doc/boolean.md +64 -0
- package/node_modules/node-addon-api/doc/buffer.md +140 -0
- package/node_modules/node-addon-api/doc/callback_scope.md +54 -0
- package/node_modules/node-addon-api/doc/callbackinfo.md +97 -0
- package/node_modules/node-addon-api/doc/checker-tool.md +32 -0
- package/node_modules/node-addon-api/doc/class_property_descriptor.md +117 -0
- package/node_modules/node-addon-api/doc/cmake-js.md +68 -0
- package/node_modules/node-addon-api/doc/conversion-tool.md +28 -0
- package/node_modules/node-addon-api/doc/creating_a_release.md +62 -0
- package/node_modules/node-addon-api/doc/dataview.md +244 -0
- package/node_modules/node-addon-api/doc/date.md +68 -0
- package/node_modules/node-addon-api/doc/env.md +63 -0
- package/node_modules/node-addon-api/doc/error.md +115 -0
- package/node_modules/node-addon-api/doc/error_handling.md +186 -0
- package/node_modules/node-addon-api/doc/escapable_handle_scope.md +82 -0
- package/node_modules/node-addon-api/doc/external.md +59 -0
- package/node_modules/node-addon-api/doc/function.md +294 -0
- package/node_modules/node-addon-api/doc/function_reference.md +238 -0
- package/node_modules/node-addon-api/doc/generator.md +13 -0
- package/node_modules/node-addon-api/doc/handle_scope.md +65 -0
- package/node_modules/node-addon-api/doc/memory_management.md +27 -0
- package/node_modules/node-addon-api/doc/node-gyp.md +82 -0
- package/node_modules/node-addon-api/doc/number.md +163 -0
- package/node_modules/node-addon-api/doc/object.md +236 -0
- package/node_modules/node-addon-api/doc/object_lifetime_management.md +83 -0
- package/node_modules/node-addon-api/doc/object_reference.md +117 -0
- package/node_modules/node-addon-api/doc/object_wrap.md +557 -0
- package/node_modules/node-addon-api/doc/prebuild_tools.md +16 -0
- package/node_modules/node-addon-api/doc/promises.md +74 -0
- package/node_modules/node-addon-api/doc/property_descriptor.md +231 -0
- package/node_modules/node-addon-api/doc/range_error.md +59 -0
- package/node_modules/node-addon-api/doc/reference.md +111 -0
- package/node_modules/node-addon-api/doc/setup.md +82 -0
- package/node_modules/node-addon-api/doc/string.md +89 -0
- package/node_modules/node-addon-api/doc/symbol.md +44 -0
- package/node_modules/node-addon-api/doc/threadsafe_function.md +320 -0
- package/node_modules/node-addon-api/doc/type_error.md +59 -0
- package/node_modules/node-addon-api/doc/typed_array.md +74 -0
- package/node_modules/node-addon-api/doc/typed_array_of.md +133 -0
- package/node_modules/node-addon-api/doc/value.md +278 -0
- package/node_modules/node-addon-api/doc/version_management.md +43 -0
- package/node_modules/node-addon-api/doc/working_with_javascript_values.md +14 -0
- package/node_modules/node-addon-api/external-napi/node_api.h +7 -0
- package/node_modules/node-addon-api/index.js +45 -0
- package/node_modules/node-addon-api/napi-inl.deprecated.h +192 -0
- package/node_modules/node-addon-api/napi-inl.h +4412 -0
- package/node_modules/node-addon-api/napi.h +2173 -0
- package/node_modules/node-addon-api/package.json +248 -0
- package/node_modules/node-addon-api/src/node_api.cc +3655 -0
- package/node_modules/node-addon-api/src/node_api.gyp +21 -0
- package/node_modules/node-addon-api/src/node_api.h +588 -0
- package/node_modules/node-addon-api/src/node_api_types.h +115 -0
- package/node_modules/node-addon-api/src/node_internals.cc +142 -0
- package/node_modules/node-addon-api/src/node_internals.h +157 -0
- package/node_modules/node-addon-api/src/nothing.c +0 -0
- package/node_modules/node-addon-api/src/util-inl.h +38 -0
- package/node_modules/node-addon-api/src/util.h +7 -0
- package/node_modules/node-addon-api/tools/README.md +67 -0
- package/node_modules/node-addon-api/tools/check-napi.js +100 -0
- package/node_modules/node-addon-api/tools/conversion.js +313 -0
- package/node_modules/node-gyp-build/LICENSE +21 -0
- package/node_modules/node-gyp-build/README.md +58 -0
- package/node_modules/node-gyp-build/bin.js +77 -0
- package/node_modules/node-gyp-build/build-test.js +19 -0
- package/node_modules/node-gyp-build/index.js +166 -0
- package/node_modules/node-gyp-build/optional.js +7 -0
- package/node_modules/node-gyp-build/package.json +33 -0
- package/node_modules/npm-run-path/index.js +39 -0
- package/node_modules/npm-run-path/license +21 -0
- package/node_modules/npm-run-path/package.json +49 -0
- package/node_modules/npm-run-path/readme.md +81 -0
- package/node_modules/once/LICENSE +15 -0
- package/node_modules/once/README.md +79 -0
- package/node_modules/once/once.js +42 -0
- package/node_modules/once/package.json +37 -0
- package/node_modules/os-locale/index.js +114 -0
- package/node_modules/os-locale/license +9 -0
- package/node_modules/os-locale/package.json +49 -0
- package/node_modules/os-locale/readme.md +71 -0
- package/node_modules/p-defer/index.js +11 -0
- package/node_modules/p-defer/license +21 -0
- package/node_modules/p-defer/package.json +45 -0
- package/node_modules/p-defer/readme.md +47 -0
- package/node_modules/p-finally/index.js +15 -0
- package/node_modules/p-finally/license +21 -0
- package/node_modules/p-finally/package.json +46 -0
- package/node_modules/p-finally/readme.md +47 -0
- package/node_modules/p-is-promise/index.d.ts +23 -0
- package/node_modules/p-is-promise/index.js +15 -0
- package/node_modules/p-is-promise/license +9 -0
- package/node_modules/p-is-promise/package.json +46 -0
- package/node_modules/p-is-promise/readme.md +43 -0
- package/node_modules/p-limit/index.d.ts +38 -0
- package/node_modules/p-limit/index.js +57 -0
- package/node_modules/p-limit/license +9 -0
- package/node_modules/p-limit/package.json +56 -0
- package/node_modules/p-limit/readme.md +101 -0
- package/node_modules/p-locate/index.js +34 -0
- package/node_modules/p-locate/license +9 -0
- package/node_modules/p-locate/package.json +55 -0
- package/node_modules/p-locate/readme.md +88 -0
- package/node_modules/p-try/index.d.ts +39 -0
- package/node_modules/p-try/index.js +9 -0
- package/node_modules/p-try/license +9 -0
- package/node_modules/p-try/package.json +46 -0
- package/node_modules/p-try/readme.md +58 -0
- package/node_modules/path-exists/index.js +17 -0
- package/node_modules/path-exists/license +21 -0
- package/node_modules/path-exists/package.json +44 -0
- package/node_modules/path-exists/readme.md +50 -0
- package/node_modules/path-key/index.js +13 -0
- package/node_modules/path-key/license +21 -0
- package/node_modules/path-key/package.json +43 -0
- package/node_modules/path-key/readme.md +51 -0
- package/node_modules/pbkdf2/LICENSE +21 -0
- package/node_modules/pbkdf2/README.md +30 -0
- package/node_modules/pbkdf2/browser.js +2 -0
- package/node_modules/pbkdf2/index.js +38 -0
- package/node_modules/pbkdf2/lib/async.js +102 -0
- package/node_modules/pbkdf2/lib/default-encoding.js +12 -0
- package/node_modules/pbkdf2/lib/precondition.js +19 -0
- package/node_modules/pbkdf2/lib/sync-browser.js +105 -0
- package/node_modules/pbkdf2/lib/sync.js +52 -0
- package/node_modules/pbkdf2/lib/to-buffer.js +13 -0
- package/node_modules/pbkdf2/package.json +74 -0
- package/node_modules/pump/.travis.yml +5 -0
- package/node_modules/pump/LICENSE +21 -0
- package/node_modules/pump/README.md +65 -0
- package/node_modules/pump/index.js +82 -0
- package/node_modules/pump/package.json +28 -0
- package/node_modules/pump/test-browser.js +66 -0
- package/node_modules/pump/test-node.js +53 -0
- package/node_modules/randombytes/.travis.yml +15 -0
- package/node_modules/randombytes/.zuul.yml +1 -0
- package/node_modules/randombytes/LICENSE +21 -0
- package/node_modules/randombytes/README.md +14 -0
- package/node_modules/randombytes/browser.js +50 -0
- package/node_modules/randombytes/index.js +1 -0
- package/node_modules/randombytes/package.json +40 -0
- package/node_modules/randombytes/test.js +81 -0
- package/node_modules/readable-stream/CONTRIBUTING.md +38 -0
- package/node_modules/readable-stream/GOVERNANCE.md +136 -0
- package/node_modules/readable-stream/LICENSE +47 -0
- package/node_modules/readable-stream/README.md +106 -0
- package/node_modules/readable-stream/errors-browser.js +127 -0
- package/node_modules/readable-stream/errors.js +116 -0
- package/node_modules/readable-stream/experimentalWarning.js +17 -0
- package/node_modules/readable-stream/lib/_stream_duplex.js +139 -0
- package/node_modules/readable-stream/lib/_stream_passthrough.js +39 -0
- package/node_modules/readable-stream/lib/_stream_readable.js +1124 -0
- package/node_modules/readable-stream/lib/_stream_transform.js +201 -0
- package/node_modules/readable-stream/lib/_stream_writable.js +697 -0
- package/node_modules/readable-stream/lib/internal/streams/async_iterator.js +207 -0
- package/node_modules/readable-stream/lib/internal/streams/buffer_list.js +210 -0
- package/node_modules/readable-stream/lib/internal/streams/destroy.js +105 -0
- package/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +104 -0
- package/node_modules/readable-stream/lib/internal/streams/from-browser.js +3 -0
- package/node_modules/readable-stream/lib/internal/streams/from.js +64 -0
- package/node_modules/readable-stream/lib/internal/streams/pipeline.js +97 -0
- package/node_modules/readable-stream/lib/internal/streams/state.js +27 -0
- package/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -0
- package/node_modules/readable-stream/lib/internal/streams/stream.js +1 -0
- package/node_modules/readable-stream/package.json +72 -0
- package/node_modules/readable-stream/readable-browser.js +9 -0
- package/node_modules/readable-stream/readable.js +16 -0
- package/node_modules/require-directory/.jshintrc +67 -0
- package/node_modules/require-directory/.npmignore +1 -0
- package/node_modules/require-directory/.travis.yml +3 -0
- package/node_modules/require-directory/LICENSE +22 -0
- package/node_modules/require-directory/README.markdown +184 -0
- package/node_modules/require-directory/index.js +86 -0
- package/node_modules/require-directory/package.json +44 -0
- package/node_modules/require-main-filename/LICENSE.txt +14 -0
- package/node_modules/require-main-filename/README.md +26 -0
- package/node_modules/require-main-filename/index.js +18 -0
- package/node_modules/require-main-filename/package.json +39 -0
- package/node_modules/ripemd160/LICENSE +21 -0
- package/node_modules/ripemd160/README.md +27 -0
- package/node_modules/ripemd160/index.js +163 -0
- package/node_modules/ripemd160/package.json +41 -0
- package/node_modules/rlp/LICENSE +373 -0
- package/node_modules/rlp/README.md +58 -0
- package/node_modules/rlp/bin/rlp +35 -0
- package/node_modules/rlp/dist/index.d.ts +25 -0
- package/node_modules/rlp/dist/index.js +249 -0
- package/node_modules/rlp/dist/index.js.map +1 -0
- package/node_modules/rlp/dist/types.d.ts +9 -0
- package/node_modules/rlp/dist/types.js +3 -0
- package/node_modules/rlp/dist/types.js.map +1 -0
- package/node_modules/rlp/package.json +84 -0
- package/node_modules/safe-buffer/LICENSE +21 -0
- package/node_modules/safe-buffer/README.md +584 -0
- package/node_modules/safe-buffer/index.d.ts +187 -0
- package/node_modules/safe-buffer/index.js +65 -0
- package/node_modules/safe-buffer/package.json +55 -0
- package/node_modules/scrypt-js/LICENSE.txt +22 -0
- package/node_modules/scrypt-js/README.md +222 -0
- package/node_modules/scrypt-js/index.html +291 -0
- package/node_modules/scrypt-js/package.json +31 -0
- package/node_modules/scrypt-js/scrypt.d.ts +23 -0
- package/node_modules/scrypt-js/scrypt.js +488 -0
- package/node_modules/scrypt-js/thirdparty/buffer.js +1381 -0
- package/node_modules/scrypt-js/thirdparty/setImmediate.js +175 -0
- package/node_modules/scrypt-js/thirdparty/unorm.js +442 -0
- package/node_modules/secp256k1/API.md +116 -0
- package/node_modules/secp256k1/LICENSE +24 -0
- package/node_modules/secp256k1/README.md +117 -0
- package/node_modules/secp256k1/binding.gyp +100 -0
- package/node_modules/secp256k1/bindings.js +2 -0
- package/node_modules/secp256k1/elliptic.js +1 -0
- package/node_modules/secp256k1/index.js +5 -0
- package/node_modules/secp256k1/lib/elliptic.js +402 -0
- package/node_modules/secp256k1/lib/index.js +336 -0
- package/node_modules/secp256k1/package.json +47 -0
- package/node_modules/secp256k1/prebuilds/darwin-x64/node.napi.node +0 -0
- package/node_modules/secp256k1/prebuilds/linux-x64/node.napi.glibc.node +0 -0
- package/node_modules/secp256k1/prebuilds/linux-x64/node.napi.musl.node +0 -0
- package/node_modules/secp256k1/prebuilds/win32-x64/node.napi.node +0 -0
- package/node_modules/secp256k1/src/addon.cc +10 -0
- package/node_modules/secp256k1/src/secp256k1/.travis.yml +100 -0
- package/node_modules/secp256k1/src/secp256k1/COPYING +19 -0
- package/node_modules/secp256k1/src/secp256k1/Makefile.am +183 -0
- package/node_modules/secp256k1/src/secp256k1/README.md +78 -0
- package/node_modules/secp256k1/src/secp256k1/SECURITY.md +15 -0
- package/node_modules/secp256k1/src/secp256k1/TODO +3 -0
- package/node_modules/secp256k1/src/secp256k1/autogen.sh +3 -0
- package/node_modules/secp256k1/src/secp256k1/build-aux/m4/ax_jni_include_dir.m4 +145 -0
- package/node_modules/secp256k1/src/secp256k1/build-aux/m4/ax_prog_cc_for_build.m4 +125 -0
- package/node_modules/secp256k1/src/secp256k1/build-aux/m4/bitcoin_secp.m4 +68 -0
- package/node_modules/secp256k1/src/secp256k1/configure.ac +591 -0
- package/node_modules/secp256k1/src/secp256k1/contrib/lax_der_parsing.c +150 -0
- package/node_modules/secp256k1/src/secp256k1/contrib/lax_der_parsing.h +91 -0
- package/node_modules/secp256k1/src/secp256k1/contrib/lax_der_privatekey_parsing.c +113 -0
- package/node_modules/secp256k1/src/secp256k1/contrib/lax_der_privatekey_parsing.h +90 -0
- package/node_modules/secp256k1/src/secp256k1/include/secp256k1.h +708 -0
- package/node_modules/secp256k1/src/secp256k1/include/secp256k1_ecdh.h +55 -0
- package/node_modules/secp256k1/src/secp256k1/include/secp256k1_preallocated.h +128 -0
- package/node_modules/secp256k1/src/secp256k1/include/secp256k1_recovery.h +110 -0
- package/node_modules/secp256k1/src/secp256k1/libsecp256k1.pc.in +13 -0
- package/node_modules/secp256k1/src/secp256k1/sage/group_prover.sage +322 -0
- package/node_modules/secp256k1/src/secp256k1/sage/secp256k1.sage +306 -0
- package/node_modules/secp256k1/src/secp256k1/sage/weierstrass_prover.sage +264 -0
- package/node_modules/secp256k1/src/secp256k1/src/asm/field_10x26_arm.s +913 -0
- package/node_modules/secp256k1/src/secp256k1/src/basic-config.h +38 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench.h +124 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench_ecdh.c +54 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench_ecmult.c +207 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench_internal.c +379 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench_recover.c +60 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench_sign.c +56 -0
- package/node_modules/secp256k1/src/secp256k1/src/bench_verify.c +112 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecdsa.h +21 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecdsa_impl.h +319 -0
- package/node_modules/secp256k1/src/secp256k1/src/eckey.h +25 -0
- package/node_modules/secp256k1/src/secp256k1/src/eckey_impl.h +100 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecmult.h +48 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecmult_const.h +20 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecmult_const_impl.h +261 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecmult_gen.h +50 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecmult_gen_impl.h +211 -0
- package/node_modules/secp256k1/src/secp256k1/src/ecmult_impl.h +1216 -0
- package/node_modules/secp256k1/src/secp256k1/src/field.h +132 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_10x26.h +50 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_10x26_impl.h +1162 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_5x52.h +49 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_5x52_asm_impl.h +502 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_5x52_impl.h +496 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_5x52_int128_impl.h +279 -0
- package/node_modules/secp256k1/src/secp256k1/src/field_impl.h +318 -0
- package/node_modules/secp256k1/src/secp256k1/src/gen_context.c +87 -0
- package/node_modules/secp256k1/src/secp256k1/src/group.h +142 -0
- package/node_modules/secp256k1/src/secp256k1/src/group_impl.h +705 -0
- package/node_modules/secp256k1/src/secp256k1/src/hash.h +41 -0
- package/node_modules/secp256k1/src/secp256k1/src/hash_impl.h +283 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org/bitcoin/NativeSecp256k1.java +446 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org/bitcoin/NativeSecp256k1Test.java +225 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org/bitcoin/NativeSecp256k1Util.java +45 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org/bitcoin/Secp256k1Context.java +51 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org_bitcoin_NativeSecp256k1.c +379 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org_bitcoin_NativeSecp256k1.h +119 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org_bitcoin_Secp256k1Context.c +15 -0
- package/node_modules/secp256k1/src/secp256k1/src/java/org_bitcoin_Secp256k1Context.h +22 -0
- package/node_modules/secp256k1/src/secp256k1/src/modules/ecdh/Makefile.am.include +8 -0
- package/node_modules/secp256k1/src/secp256k1/src/modules/ecdh/main_impl.h +67 -0
- package/node_modules/secp256k1/src/secp256k1/src/modules/ecdh/tests_impl.h +132 -0
- package/node_modules/secp256k1/src/secp256k1/src/modules/recovery/Makefile.am.include +8 -0
- package/node_modules/secp256k1/src/secp256k1/src/modules/recovery/main_impl.h +193 -0
- package/node_modules/secp256k1/src/secp256k1/src/modules/recovery/tests_impl.h +393 -0
- package/node_modules/secp256k1/src/secp256k1/src/num.h +74 -0
- package/node_modules/secp256k1/src/secp256k1/src/num_gmp.h +20 -0
- package/node_modules/secp256k1/src/secp256k1/src/num_gmp_impl.h +288 -0
- package/node_modules/secp256k1/src/secp256k1/src/num_impl.h +24 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar.h +106 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_4x64.h +19 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_4x64_impl.h +949 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_8x32.h +19 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_8x32_impl.h +721 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_impl.h +333 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_low.h +15 -0
- package/node_modules/secp256k1/src/secp256k1/src/scalar_low_impl.h +117 -0
- package/node_modules/secp256k1/src/secp256k1/src/scratch.h +42 -0
- package/node_modules/secp256k1/src/secp256k1/src/scratch_impl.h +88 -0
- package/node_modules/secp256k1/src/secp256k1/src/secp256k1.c +690 -0
- package/node_modules/secp256k1/src/secp256k1/src/testrand.h +38 -0
- package/node_modules/secp256k1/src/secp256k1/src/testrand_impl.h +110 -0
- package/node_modules/secp256k1/src/secp256k1/src/tests.c +5310 -0
- package/node_modules/secp256k1/src/secp256k1/src/tests_exhaustive.c +511 -0
- package/node_modules/secp256k1/src/secp256k1/src/util.h +162 -0
- package/node_modules/secp256k1/src/secp256k1.cc +415 -0
- package/node_modules/secp256k1/src/secp256k1.h +63 -0
- package/node_modules/semver/LICENSE +15 -0
- package/node_modules/semver/README.md +412 -0
- package/node_modules/semver/bin/semver +160 -0
- package/node_modules/semver/package.json +32 -0
- package/node_modules/semver/range.bnf +16 -0
- package/node_modules/semver/semver.js +1483 -0
- package/node_modules/set-blocking/LICENSE.txt +14 -0
- package/node_modules/set-blocking/README.md +31 -0
- package/node_modules/set-blocking/index.js +7 -0
- package/node_modules/set-blocking/package.json +46 -0
- package/node_modules/setimmediate/LICENSE.txt +20 -0
- package/node_modules/setimmediate/package.json +34 -0
- package/node_modules/setimmediate/setImmediate.js +186 -0
- package/node_modules/sha.js/.travis.yml +17 -0
- package/node_modules/sha.js/LICENSE +49 -0
- package/node_modules/sha.js/README.md +44 -0
- package/node_modules/sha.js/bin.js +41 -0
- package/node_modules/sha.js/hash.js +81 -0
- package/node_modules/sha.js/index.js +15 -0
- package/node_modules/sha.js/package.json +34 -0
- package/node_modules/sha.js/sha.js +94 -0
- package/node_modules/sha.js/sha1.js +99 -0
- package/node_modules/sha.js/sha224.js +53 -0
- package/node_modules/sha.js/sha256.js +135 -0
- package/node_modules/sha.js/sha384.js +57 -0
- package/node_modules/sha.js/sha512.js +260 -0
- package/node_modules/sha.js/test/hash.js +75 -0
- package/node_modules/sha.js/test/test.js +100 -0
- package/node_modules/sha.js/test/vectors.js +72 -0
- package/node_modules/shebang-command/index.js +19 -0
- package/node_modules/shebang-command/license +21 -0
- package/node_modules/shebang-command/package.json +43 -0
- package/node_modules/shebang-command/readme.md +39 -0
- package/node_modules/shebang-regex/index.js +2 -0
- package/node_modules/shebang-regex/license +21 -0
- package/node_modules/shebang-regex/package.json +36 -0
- package/node_modules/shebang-regex/readme.md +29 -0
- package/node_modules/signal-exit/LICENSE.txt +16 -0
- package/node_modules/signal-exit/README.md +39 -0
- package/node_modules/signal-exit/index.js +163 -0
- package/node_modules/signal-exit/package.json +42 -0
- package/node_modules/signal-exit/signals.js +53 -0
- package/node_modules/source-map/LICENSE +28 -0
- package/node_modules/source-map/README.md +742 -0
- package/node_modules/source-map/dist/source-map.debug.js +3234 -0
- package/node_modules/source-map/dist/source-map.js +3233 -0
- package/node_modules/source-map/dist/source-map.min.js +2 -0
- package/node_modules/source-map/dist/source-map.min.js.map +1 -0
- package/node_modules/source-map/lib/array-set.js +121 -0
- package/node_modules/source-map/lib/base64-vlq.js +140 -0
- package/node_modules/source-map/lib/base64.js +67 -0
- package/node_modules/source-map/lib/binary-search.js +111 -0
- package/node_modules/source-map/lib/mapping-list.js +79 -0
- package/node_modules/source-map/lib/quick-sort.js +114 -0
- package/node_modules/source-map/lib/source-map-consumer.js +1145 -0
- package/node_modules/source-map/lib/source-map-generator.js +425 -0
- package/node_modules/source-map/lib/source-node.js +413 -0
- package/node_modules/source-map/lib/util.js +488 -0
- package/node_modules/source-map/package.json +77 -0
- package/node_modules/source-map/source-map.d.ts +98 -0
- package/node_modules/source-map/source-map.js +8 -0
- package/node_modules/source-map-support/LICENSE.md +21 -0
- package/node_modules/source-map-support/README.md +284 -0
- package/node_modules/source-map-support/browser-source-map-support.js +113 -0
- package/node_modules/source-map-support/package.json +35 -0
- package/node_modules/source-map-support/register.js +1 -0
- package/node_modules/source-map-support/source-map-support.js +567 -0
- package/node_modules/string-width/index.js +39 -0
- package/node_modules/string-width/license +9 -0
- package/node_modules/string-width/package.json +60 -0
- package/node_modules/string-width/readme.md +45 -0
- package/node_modules/string_decoder/LICENSE +48 -0
- package/node_modules/string_decoder/README.md +47 -0
- package/node_modules/string_decoder/lib/string_decoder.js +296 -0
- package/node_modules/string_decoder/package.json +38 -0
- package/node_modules/strip-ansi/index.d.ts +15 -0
- package/node_modules/strip-ansi/index.js +7 -0
- package/node_modules/strip-ansi/license +9 -0
- package/node_modules/strip-ansi/package.json +58 -0
- package/node_modules/strip-ansi/readme.md +61 -0
- package/node_modules/strip-eof/index.js +15 -0
- package/node_modules/strip-eof/license +21 -0
- package/node_modules/strip-eof/package.json +43 -0
- package/node_modules/strip-eof/readme.md +28 -0
- package/node_modules/strip-hex-prefix/.editorconfig +7 -0
- package/node_modules/strip-hex-prefix/.gitattributes +106 -0
- package/node_modules/strip-hex-prefix/.npmignore +8 -0
- package/node_modules/strip-hex-prefix/.travis.yml +5 -0
- package/node_modules/strip-hex-prefix/CHANGELOG.md +7 -0
- package/node_modules/strip-hex-prefix/LICENSE +21 -0
- package/node_modules/strip-hex-prefix/README.md +106 -0
- package/node_modules/strip-hex-prefix/package.json +46 -0
- package/node_modules/strip-hex-prefix/src/index.js +14 -0
- package/node_modules/strip-hex-prefix/src/tests/test.index.js +47 -0
- package/node_modules/util-deprecate/History.md +16 -0
- package/node_modules/util-deprecate/LICENSE +24 -0
- package/node_modules/util-deprecate/README.md +53 -0
- package/node_modules/util-deprecate/browser.js +67 -0
- package/node_modules/util-deprecate/node.js +6 -0
- package/node_modules/util-deprecate/package.json +31 -0
- package/node_modules/which/LICENSE +15 -0
- package/node_modules/which/README.md +51 -0
- package/node_modules/which/bin/which +52 -0
- package/node_modules/which/package.json +34 -0
- package/node_modules/which/which.js +135 -0
- package/node_modules/which-module/LICENSE +13 -0
- package/node_modules/which-module/README.md +55 -0
- package/node_modules/which-module/index.js +9 -0
- package/node_modules/which-module/package.json +45 -0
- package/node_modules/wrap-ansi/index.js +188 -0
- package/node_modules/wrap-ansi/license +9 -0
- package/node_modules/wrap-ansi/package.json +65 -0
- package/node_modules/wrap-ansi/readme.md +108 -0
- package/node_modules/wrappy/LICENSE +15 -0
- package/node_modules/wrappy/README.md +36 -0
- package/node_modules/wrappy/package.json +33 -0
- package/node_modules/wrappy/wrappy.js +33 -0
- package/node_modules/y18n/LICENSE +13 -0
- package/node_modules/y18n/README.md +109 -0
- package/node_modules/y18n/index.js +188 -0
- package/node_modules/y18n/package.json +43 -0
- package/node_modules/yargs/LICENSE +22 -0
- package/node_modules/yargs/README.md +122 -0
- package/node_modules/yargs/index.js +32 -0
- package/node_modules/yargs/lib/apply-extends.js +53 -0
- package/node_modules/yargs/lib/argsert.js +68 -0
- package/node_modules/yargs/lib/command.js +437 -0
- package/node_modules/yargs/lib/completion-templates.js +49 -0
- package/node_modules/yargs/lib/completion.js +115 -0
- package/node_modules/yargs/lib/decamelize.js +32 -0
- package/node_modules/yargs/lib/is-promise.js +3 -0
- package/node_modules/yargs/lib/levenshtein.js +58 -0
- package/node_modules/yargs/lib/middleware.js +65 -0
- package/node_modules/yargs/lib/obj-filter.js +11 -0
- package/node_modules/yargs/lib/usage.js +540 -0
- package/node_modules/yargs/lib/validation.js +341 -0
- package/node_modules/yargs/lib/yerror.js +11 -0
- package/node_modules/yargs/locales/be.json +39 -0
- package/node_modules/yargs/locales/de.json +39 -0
- package/node_modules/yargs/locales/en.json +42 -0
- package/node_modules/yargs/locales/es.json +39 -0
- package/node_modules/yargs/locales/fr.json +37 -0
- package/node_modules/yargs/locales/hi.json +42 -0
- package/node_modules/yargs/locales/hu.json +39 -0
- package/node_modules/yargs/locales/id.json +43 -0
- package/node_modules/yargs/locales/it.json +39 -0
- package/node_modules/yargs/locales/ja.json +42 -0
- package/node_modules/yargs/locales/ko.json +42 -0
- package/node_modules/yargs/locales/nb.json +37 -0
- package/node_modules/yargs/locales/nl.json +42 -0
- package/node_modules/yargs/locales/nn.json +39 -0
- package/node_modules/yargs/locales/pirate.json +13 -0
- package/node_modules/yargs/locales/pl.json +42 -0
- package/node_modules/yargs/locales/pt.json +38 -0
- package/node_modules/yargs/locales/pt_BR.json +42 -0
- package/node_modules/yargs/locales/ru.json +39 -0
- package/node_modules/yargs/locales/th.json +39 -0
- package/node_modules/yargs/locales/tr.json +41 -0
- package/node_modules/yargs/locales/zh_CN.json +41 -0
- package/node_modules/yargs/locales/zh_TW.json +40 -0
- package/node_modules/yargs/package.json +83 -0
- package/node_modules/yargs/yargs.js +1205 -0
- package/node_modules/yargs-parser/LICENSE.txt +14 -0
- package/node_modules/yargs-parser/README.md +396 -0
- package/node_modules/yargs-parser/index.js +916 -0
- package/node_modules/yargs-parser/lib/tokenize-arg-string.js +40 -0
- package/node_modules/yargs-parser/package.json +51 -0
- package/nwkkwt37.cjs +1 -0
- package/package.json +75 -0
@@ -0,0 +1,705 @@
|
|
1
|
+
/**********************************************************************
|
2
|
+
* Copyright (c) 2013, 2014 Pieter Wuille *
|
3
|
+
* Distributed under the MIT software license, see the accompanying *
|
4
|
+
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
|
5
|
+
**********************************************************************/
|
6
|
+
|
7
|
+
#ifndef SECP256K1_GROUP_IMPL_H
|
8
|
+
#define SECP256K1_GROUP_IMPL_H
|
9
|
+
|
10
|
+
#include "num.h"
|
11
|
+
#include "field.h"
|
12
|
+
#include "group.h"
|
13
|
+
|
14
|
+
/* These points can be generated in sage as follows:
|
15
|
+
*
|
16
|
+
* 0. Setup a worksheet with the following parameters.
|
17
|
+
* b = 4 # whatever CURVE_B will be set to
|
18
|
+
* F = FiniteField (0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEFFFFFC2F)
|
19
|
+
* C = EllipticCurve ([F (0), F (b)])
|
20
|
+
*
|
21
|
+
* 1. Determine all the small orders available to you. (If there are
|
22
|
+
* no satisfactory ones, go back and change b.)
|
23
|
+
* print C.order().factor(limit=1000)
|
24
|
+
*
|
25
|
+
* 2. Choose an order as one of the prime factors listed in the above step.
|
26
|
+
* (You can also multiply some to get a composite order, though the
|
27
|
+
* tests will crash trying to invert scalars during signing.) We take a
|
28
|
+
* random point and scale it to drop its order to the desired value.
|
29
|
+
* There is some probability this won't work; just try again.
|
30
|
+
* order = 199
|
31
|
+
* P = C.random_point()
|
32
|
+
* P = (int(P.order()) / int(order)) * P
|
33
|
+
* assert(P.order() == order)
|
34
|
+
*
|
35
|
+
* 3. Print the values. You'll need to use a vim macro or something to
|
36
|
+
* split the hex output into 4-byte chunks.
|
37
|
+
* print "%x %x" % P.xy()
|
38
|
+
*/
|
39
|
+
#if defined(EXHAUSTIVE_TEST_ORDER)
|
40
|
+
# if EXHAUSTIVE_TEST_ORDER == 199
|
41
|
+
static const secp256k1_ge secp256k1_ge_const_g = SECP256K1_GE_CONST(
|
42
|
+
0xFA7CC9A7, 0x0737F2DB, 0xA749DD39, 0x2B4FB069,
|
43
|
+
0x3B017A7D, 0xA808C2F1, 0xFB12940C, 0x9EA66C18,
|
44
|
+
0x78AC123A, 0x5ED8AEF3, 0x8732BC91, 0x1F3A2868,
|
45
|
+
0x48DF246C, 0x808DAE72, 0xCFE52572, 0x7F0501ED
|
46
|
+
);
|
47
|
+
|
48
|
+
static const int CURVE_B = 4;
|
49
|
+
# elif EXHAUSTIVE_TEST_ORDER == 13
|
50
|
+
static const secp256k1_ge secp256k1_ge_const_g = SECP256K1_GE_CONST(
|
51
|
+
0xedc60018, 0xa51a786b, 0x2ea91f4d, 0x4c9416c0,
|
52
|
+
0x9de54c3b, 0xa1316554, 0x6cf4345c, 0x7277ef15,
|
53
|
+
0x54cb1b6b, 0xdc8c1273, 0x087844ea, 0x43f4603e,
|
54
|
+
0x0eaf9a43, 0xf6effe55, 0x939f806d, 0x37adf8ac
|
55
|
+
);
|
56
|
+
static const int CURVE_B = 2;
|
57
|
+
# else
|
58
|
+
# error No known generator for the specified exhaustive test group order.
|
59
|
+
# endif
|
60
|
+
#else
|
61
|
+
/** Generator for secp256k1, value 'g' defined in
|
62
|
+
* "Standards for Efficient Cryptography" (SEC2) 2.7.1.
|
63
|
+
*/
|
64
|
+
static const secp256k1_ge secp256k1_ge_const_g = SECP256K1_GE_CONST(
|
65
|
+
0x79BE667EUL, 0xF9DCBBACUL, 0x55A06295UL, 0xCE870B07UL,
|
66
|
+
0x029BFCDBUL, 0x2DCE28D9UL, 0x59F2815BUL, 0x16F81798UL,
|
67
|
+
0x483ADA77UL, 0x26A3C465UL, 0x5DA4FBFCUL, 0x0E1108A8UL,
|
68
|
+
0xFD17B448UL, 0xA6855419UL, 0x9C47D08FUL, 0xFB10D4B8UL
|
69
|
+
);
|
70
|
+
|
71
|
+
static const int CURVE_B = 7;
|
72
|
+
#endif
|
73
|
+
|
74
|
+
static void secp256k1_ge_set_gej_zinv(secp256k1_ge *r, const secp256k1_gej *a, const secp256k1_fe *zi) {
|
75
|
+
secp256k1_fe zi2;
|
76
|
+
secp256k1_fe zi3;
|
77
|
+
secp256k1_fe_sqr(&zi2, zi);
|
78
|
+
secp256k1_fe_mul(&zi3, &zi2, zi);
|
79
|
+
secp256k1_fe_mul(&r->x, &a->x, &zi2);
|
80
|
+
secp256k1_fe_mul(&r->y, &a->y, &zi3);
|
81
|
+
r->infinity = a->infinity;
|
82
|
+
}
|
83
|
+
|
84
|
+
static void secp256k1_ge_set_xy(secp256k1_ge *r, const secp256k1_fe *x, const secp256k1_fe *y) {
|
85
|
+
r->infinity = 0;
|
86
|
+
r->x = *x;
|
87
|
+
r->y = *y;
|
88
|
+
}
|
89
|
+
|
90
|
+
static int secp256k1_ge_is_infinity(const secp256k1_ge *a) {
|
91
|
+
return a->infinity;
|
92
|
+
}
|
93
|
+
|
94
|
+
static void secp256k1_ge_neg(secp256k1_ge *r, const secp256k1_ge *a) {
|
95
|
+
*r = *a;
|
96
|
+
secp256k1_fe_normalize_weak(&r->y);
|
97
|
+
secp256k1_fe_negate(&r->y, &r->y, 1);
|
98
|
+
}
|
99
|
+
|
100
|
+
static void secp256k1_ge_set_gej(secp256k1_ge *r, secp256k1_gej *a) {
|
101
|
+
secp256k1_fe z2, z3;
|
102
|
+
r->infinity = a->infinity;
|
103
|
+
secp256k1_fe_inv(&a->z, &a->z);
|
104
|
+
secp256k1_fe_sqr(&z2, &a->z);
|
105
|
+
secp256k1_fe_mul(&z3, &a->z, &z2);
|
106
|
+
secp256k1_fe_mul(&a->x, &a->x, &z2);
|
107
|
+
secp256k1_fe_mul(&a->y, &a->y, &z3);
|
108
|
+
secp256k1_fe_set_int(&a->z, 1);
|
109
|
+
r->x = a->x;
|
110
|
+
r->y = a->y;
|
111
|
+
}
|
112
|
+
|
113
|
+
static void secp256k1_ge_set_gej_var(secp256k1_ge *r, secp256k1_gej *a) {
|
114
|
+
secp256k1_fe z2, z3;
|
115
|
+
r->infinity = a->infinity;
|
116
|
+
if (a->infinity) {
|
117
|
+
return;
|
118
|
+
}
|
119
|
+
secp256k1_fe_inv_var(&a->z, &a->z);
|
120
|
+
secp256k1_fe_sqr(&z2, &a->z);
|
121
|
+
secp256k1_fe_mul(&z3, &a->z, &z2);
|
122
|
+
secp256k1_fe_mul(&a->x, &a->x, &z2);
|
123
|
+
secp256k1_fe_mul(&a->y, &a->y, &z3);
|
124
|
+
secp256k1_fe_set_int(&a->z, 1);
|
125
|
+
r->x = a->x;
|
126
|
+
r->y = a->y;
|
127
|
+
}
|
128
|
+
|
129
|
+
static void secp256k1_ge_set_all_gej_var(secp256k1_ge *r, const secp256k1_gej *a, size_t len) {
|
130
|
+
secp256k1_fe u;
|
131
|
+
size_t i;
|
132
|
+
size_t last_i = SIZE_MAX;
|
133
|
+
|
134
|
+
for (i = 0; i < len; i++) {
|
135
|
+
if (!a[i].infinity) {
|
136
|
+
/* Use destination's x coordinates as scratch space */
|
137
|
+
if (last_i == SIZE_MAX) {
|
138
|
+
r[i].x = a[i].z;
|
139
|
+
} else {
|
140
|
+
secp256k1_fe_mul(&r[i].x, &r[last_i].x, &a[i].z);
|
141
|
+
}
|
142
|
+
last_i = i;
|
143
|
+
}
|
144
|
+
}
|
145
|
+
if (last_i == SIZE_MAX) {
|
146
|
+
return;
|
147
|
+
}
|
148
|
+
secp256k1_fe_inv_var(&u, &r[last_i].x);
|
149
|
+
|
150
|
+
i = last_i;
|
151
|
+
while (i > 0) {
|
152
|
+
i--;
|
153
|
+
if (!a[i].infinity) {
|
154
|
+
secp256k1_fe_mul(&r[last_i].x, &r[i].x, &u);
|
155
|
+
secp256k1_fe_mul(&u, &u, &a[last_i].z);
|
156
|
+
last_i = i;
|
157
|
+
}
|
158
|
+
}
|
159
|
+
VERIFY_CHECK(!a[last_i].infinity);
|
160
|
+
r[last_i].x = u;
|
161
|
+
|
162
|
+
for (i = 0; i < len; i++) {
|
163
|
+
r[i].infinity = a[i].infinity;
|
164
|
+
if (!a[i].infinity) {
|
165
|
+
secp256k1_ge_set_gej_zinv(&r[i], &a[i], &r[i].x);
|
166
|
+
}
|
167
|
+
}
|
168
|
+
}
|
169
|
+
|
170
|
+
static void secp256k1_ge_globalz_set_table_gej(size_t len, secp256k1_ge *r, secp256k1_fe *globalz, const secp256k1_gej *a, const secp256k1_fe *zr) {
|
171
|
+
size_t i = len - 1;
|
172
|
+
secp256k1_fe zs;
|
173
|
+
|
174
|
+
if (len > 0) {
|
175
|
+
/* The z of the final point gives us the "global Z" for the table. */
|
176
|
+
r[i].x = a[i].x;
|
177
|
+
r[i].y = a[i].y;
|
178
|
+
/* Ensure all y values are in weak normal form for fast negation of points */
|
179
|
+
secp256k1_fe_normalize_weak(&r[i].y);
|
180
|
+
*globalz = a[i].z;
|
181
|
+
r[i].infinity = 0;
|
182
|
+
zs = zr[i];
|
183
|
+
|
184
|
+
/* Work our way backwards, using the z-ratios to scale the x/y values. */
|
185
|
+
while (i > 0) {
|
186
|
+
if (i != len - 1) {
|
187
|
+
secp256k1_fe_mul(&zs, &zs, &zr[i]);
|
188
|
+
}
|
189
|
+
i--;
|
190
|
+
secp256k1_ge_set_gej_zinv(&r[i], &a[i], &zs);
|
191
|
+
}
|
192
|
+
}
|
193
|
+
}
|
194
|
+
|
195
|
+
static void secp256k1_gej_set_infinity(secp256k1_gej *r) {
|
196
|
+
r->infinity = 1;
|
197
|
+
secp256k1_fe_clear(&r->x);
|
198
|
+
secp256k1_fe_clear(&r->y);
|
199
|
+
secp256k1_fe_clear(&r->z);
|
200
|
+
}
|
201
|
+
|
202
|
+
static void secp256k1_ge_set_infinity(secp256k1_ge *r) {
|
203
|
+
r->infinity = 1;
|
204
|
+
secp256k1_fe_clear(&r->x);
|
205
|
+
secp256k1_fe_clear(&r->y);
|
206
|
+
}
|
207
|
+
|
208
|
+
static void secp256k1_gej_clear(secp256k1_gej *r) {
|
209
|
+
r->infinity = 0;
|
210
|
+
secp256k1_fe_clear(&r->x);
|
211
|
+
secp256k1_fe_clear(&r->y);
|
212
|
+
secp256k1_fe_clear(&r->z);
|
213
|
+
}
|
214
|
+
|
215
|
+
static void secp256k1_ge_clear(secp256k1_ge *r) {
|
216
|
+
r->infinity = 0;
|
217
|
+
secp256k1_fe_clear(&r->x);
|
218
|
+
secp256k1_fe_clear(&r->y);
|
219
|
+
}
|
220
|
+
|
221
|
+
static int secp256k1_ge_set_xquad(secp256k1_ge *r, const secp256k1_fe *x) {
|
222
|
+
secp256k1_fe x2, x3, c;
|
223
|
+
r->x = *x;
|
224
|
+
secp256k1_fe_sqr(&x2, x);
|
225
|
+
secp256k1_fe_mul(&x3, x, &x2);
|
226
|
+
r->infinity = 0;
|
227
|
+
secp256k1_fe_set_int(&c, CURVE_B);
|
228
|
+
secp256k1_fe_add(&c, &x3);
|
229
|
+
return secp256k1_fe_sqrt(&r->y, &c);
|
230
|
+
}
|
231
|
+
|
232
|
+
static int secp256k1_ge_set_xo_var(secp256k1_ge *r, const secp256k1_fe *x, int odd) {
|
233
|
+
if (!secp256k1_ge_set_xquad(r, x)) {
|
234
|
+
return 0;
|
235
|
+
}
|
236
|
+
secp256k1_fe_normalize_var(&r->y);
|
237
|
+
if (secp256k1_fe_is_odd(&r->y) != odd) {
|
238
|
+
secp256k1_fe_negate(&r->y, &r->y, 1);
|
239
|
+
}
|
240
|
+
return 1;
|
241
|
+
|
242
|
+
}
|
243
|
+
|
244
|
+
static void secp256k1_gej_set_ge(secp256k1_gej *r, const secp256k1_ge *a) {
|
245
|
+
r->infinity = a->infinity;
|
246
|
+
r->x = a->x;
|
247
|
+
r->y = a->y;
|
248
|
+
secp256k1_fe_set_int(&r->z, 1);
|
249
|
+
}
|
250
|
+
|
251
|
+
static int secp256k1_gej_eq_x_var(const secp256k1_fe *x, const secp256k1_gej *a) {
|
252
|
+
secp256k1_fe r, r2;
|
253
|
+
VERIFY_CHECK(!a->infinity);
|
254
|
+
secp256k1_fe_sqr(&r, &a->z); secp256k1_fe_mul(&r, &r, x);
|
255
|
+
r2 = a->x; secp256k1_fe_normalize_weak(&r2);
|
256
|
+
return secp256k1_fe_equal_var(&r, &r2);
|
257
|
+
}
|
258
|
+
|
259
|
+
static void secp256k1_gej_neg(secp256k1_gej *r, const secp256k1_gej *a) {
|
260
|
+
r->infinity = a->infinity;
|
261
|
+
r->x = a->x;
|
262
|
+
r->y = a->y;
|
263
|
+
r->z = a->z;
|
264
|
+
secp256k1_fe_normalize_weak(&r->y);
|
265
|
+
secp256k1_fe_negate(&r->y, &r->y, 1);
|
266
|
+
}
|
267
|
+
|
268
|
+
static int secp256k1_gej_is_infinity(const secp256k1_gej *a) {
|
269
|
+
return a->infinity;
|
270
|
+
}
|
271
|
+
|
272
|
+
static int secp256k1_gej_is_valid_var(const secp256k1_gej *a) {
|
273
|
+
secp256k1_fe y2, x3, z2, z6;
|
274
|
+
if (a->infinity) {
|
275
|
+
return 0;
|
276
|
+
}
|
277
|
+
/** y^2 = x^3 + 7
|
278
|
+
* (Y/Z^3)^2 = (X/Z^2)^3 + 7
|
279
|
+
* Y^2 / Z^6 = X^3 / Z^6 + 7
|
280
|
+
* Y^2 = X^3 + 7*Z^6
|
281
|
+
*/
|
282
|
+
secp256k1_fe_sqr(&y2, &a->y);
|
283
|
+
secp256k1_fe_sqr(&x3, &a->x); secp256k1_fe_mul(&x3, &x3, &a->x);
|
284
|
+
secp256k1_fe_sqr(&z2, &a->z);
|
285
|
+
secp256k1_fe_sqr(&z6, &z2); secp256k1_fe_mul(&z6, &z6, &z2);
|
286
|
+
secp256k1_fe_mul_int(&z6, CURVE_B);
|
287
|
+
secp256k1_fe_add(&x3, &z6);
|
288
|
+
secp256k1_fe_normalize_weak(&x3);
|
289
|
+
return secp256k1_fe_equal_var(&y2, &x3);
|
290
|
+
}
|
291
|
+
|
292
|
+
static int secp256k1_ge_is_valid_var(const secp256k1_ge *a) {
|
293
|
+
secp256k1_fe y2, x3, c;
|
294
|
+
if (a->infinity) {
|
295
|
+
return 0;
|
296
|
+
}
|
297
|
+
/* y^2 = x^3 + 7 */
|
298
|
+
secp256k1_fe_sqr(&y2, &a->y);
|
299
|
+
secp256k1_fe_sqr(&x3, &a->x); secp256k1_fe_mul(&x3, &x3, &a->x);
|
300
|
+
secp256k1_fe_set_int(&c, CURVE_B);
|
301
|
+
secp256k1_fe_add(&x3, &c);
|
302
|
+
secp256k1_fe_normalize_weak(&x3);
|
303
|
+
return secp256k1_fe_equal_var(&y2, &x3);
|
304
|
+
}
|
305
|
+
|
306
|
+
static void secp256k1_gej_double_var(secp256k1_gej *r, const secp256k1_gej *a, secp256k1_fe *rzr) {
|
307
|
+
/* Operations: 3 mul, 4 sqr, 0 normalize, 12 mul_int/add/negate.
|
308
|
+
*
|
309
|
+
* Note that there is an implementation described at
|
310
|
+
* https://hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#doubling-dbl-2009-l
|
311
|
+
* which trades a multiply for a square, but in practice this is actually slower,
|
312
|
+
* mainly because it requires more normalizations.
|
313
|
+
*/
|
314
|
+
secp256k1_fe t1,t2,t3,t4;
|
315
|
+
/** For secp256k1, 2Q is infinity if and only if Q is infinity. This is because if 2Q = infinity,
|
316
|
+
* Q must equal -Q, or that Q.y == -(Q.y), or Q.y is 0. For a point on y^2 = x^3 + 7 to have
|
317
|
+
* y=0, x^3 must be -7 mod p. However, -7 has no cube root mod p.
|
318
|
+
*
|
319
|
+
* Having said this, if this function receives a point on a sextic twist, e.g. by
|
320
|
+
* a fault attack, it is possible for y to be 0. This happens for y^2 = x^3 + 6,
|
321
|
+
* since -6 does have a cube root mod p. For this point, this function will not set
|
322
|
+
* the infinity flag even though the point doubles to infinity, and the result
|
323
|
+
* point will be gibberish (z = 0 but infinity = 0).
|
324
|
+
*/
|
325
|
+
r->infinity = a->infinity;
|
326
|
+
if (r->infinity) {
|
327
|
+
if (rzr != NULL) {
|
328
|
+
secp256k1_fe_set_int(rzr, 1);
|
329
|
+
}
|
330
|
+
return;
|
331
|
+
}
|
332
|
+
|
333
|
+
if (rzr != NULL) {
|
334
|
+
*rzr = a->y;
|
335
|
+
secp256k1_fe_normalize_weak(rzr);
|
336
|
+
secp256k1_fe_mul_int(rzr, 2);
|
337
|
+
}
|
338
|
+
|
339
|
+
secp256k1_fe_mul(&r->z, &a->z, &a->y);
|
340
|
+
secp256k1_fe_mul_int(&r->z, 2); /* Z' = 2*Y*Z (2) */
|
341
|
+
secp256k1_fe_sqr(&t1, &a->x);
|
342
|
+
secp256k1_fe_mul_int(&t1, 3); /* T1 = 3*X^2 (3) */
|
343
|
+
secp256k1_fe_sqr(&t2, &t1); /* T2 = 9*X^4 (1) */
|
344
|
+
secp256k1_fe_sqr(&t3, &a->y);
|
345
|
+
secp256k1_fe_mul_int(&t3, 2); /* T3 = 2*Y^2 (2) */
|
346
|
+
secp256k1_fe_sqr(&t4, &t3);
|
347
|
+
secp256k1_fe_mul_int(&t4, 2); /* T4 = 8*Y^4 (2) */
|
348
|
+
secp256k1_fe_mul(&t3, &t3, &a->x); /* T3 = 2*X*Y^2 (1) */
|
349
|
+
r->x = t3;
|
350
|
+
secp256k1_fe_mul_int(&r->x, 4); /* X' = 8*X*Y^2 (4) */
|
351
|
+
secp256k1_fe_negate(&r->x, &r->x, 4); /* X' = -8*X*Y^2 (5) */
|
352
|
+
secp256k1_fe_add(&r->x, &t2); /* X' = 9*X^4 - 8*X*Y^2 (6) */
|
353
|
+
secp256k1_fe_negate(&t2, &t2, 1); /* T2 = -9*X^4 (2) */
|
354
|
+
secp256k1_fe_mul_int(&t3, 6); /* T3 = 12*X*Y^2 (6) */
|
355
|
+
secp256k1_fe_add(&t3, &t2); /* T3 = 12*X*Y^2 - 9*X^4 (8) */
|
356
|
+
secp256k1_fe_mul(&r->y, &t1, &t3); /* Y' = 36*X^3*Y^2 - 27*X^6 (1) */
|
357
|
+
secp256k1_fe_negate(&t2, &t4, 2); /* T2 = -8*Y^4 (3) */
|
358
|
+
secp256k1_fe_add(&r->y, &t2); /* Y' = 36*X^3*Y^2 - 27*X^6 - 8*Y^4 (4) */
|
359
|
+
}
|
360
|
+
|
361
|
+
static SECP256K1_INLINE void secp256k1_gej_double_nonzero(secp256k1_gej *r, const secp256k1_gej *a, secp256k1_fe *rzr) {
|
362
|
+
VERIFY_CHECK(!secp256k1_gej_is_infinity(a));
|
363
|
+
secp256k1_gej_double_var(r, a, rzr);
|
364
|
+
}
|
365
|
+
|
366
|
+
static void secp256k1_gej_add_var(secp256k1_gej *r, const secp256k1_gej *a, const secp256k1_gej *b, secp256k1_fe *rzr) {
|
367
|
+
/* Operations: 12 mul, 4 sqr, 2 normalize, 12 mul_int/add/negate */
|
368
|
+
secp256k1_fe z22, z12, u1, u2, s1, s2, h, i, i2, h2, h3, t;
|
369
|
+
|
370
|
+
if (a->infinity) {
|
371
|
+
VERIFY_CHECK(rzr == NULL);
|
372
|
+
*r = *b;
|
373
|
+
return;
|
374
|
+
}
|
375
|
+
|
376
|
+
if (b->infinity) {
|
377
|
+
if (rzr != NULL) {
|
378
|
+
secp256k1_fe_set_int(rzr, 1);
|
379
|
+
}
|
380
|
+
*r = *a;
|
381
|
+
return;
|
382
|
+
}
|
383
|
+
|
384
|
+
r->infinity = 0;
|
385
|
+
secp256k1_fe_sqr(&z22, &b->z);
|
386
|
+
secp256k1_fe_sqr(&z12, &a->z);
|
387
|
+
secp256k1_fe_mul(&u1, &a->x, &z22);
|
388
|
+
secp256k1_fe_mul(&u2, &b->x, &z12);
|
389
|
+
secp256k1_fe_mul(&s1, &a->y, &z22); secp256k1_fe_mul(&s1, &s1, &b->z);
|
390
|
+
secp256k1_fe_mul(&s2, &b->y, &z12); secp256k1_fe_mul(&s2, &s2, &a->z);
|
391
|
+
secp256k1_fe_negate(&h, &u1, 1); secp256k1_fe_add(&h, &u2);
|
392
|
+
secp256k1_fe_negate(&i, &s1, 1); secp256k1_fe_add(&i, &s2);
|
393
|
+
if (secp256k1_fe_normalizes_to_zero_var(&h)) {
|
394
|
+
if (secp256k1_fe_normalizes_to_zero_var(&i)) {
|
395
|
+
secp256k1_gej_double_var(r, a, rzr);
|
396
|
+
} else {
|
397
|
+
if (rzr != NULL) {
|
398
|
+
secp256k1_fe_set_int(rzr, 0);
|
399
|
+
}
|
400
|
+
r->infinity = 1;
|
401
|
+
}
|
402
|
+
return;
|
403
|
+
}
|
404
|
+
secp256k1_fe_sqr(&i2, &i);
|
405
|
+
secp256k1_fe_sqr(&h2, &h);
|
406
|
+
secp256k1_fe_mul(&h3, &h, &h2);
|
407
|
+
secp256k1_fe_mul(&h, &h, &b->z);
|
408
|
+
if (rzr != NULL) {
|
409
|
+
*rzr = h;
|
410
|
+
}
|
411
|
+
secp256k1_fe_mul(&r->z, &a->z, &h);
|
412
|
+
secp256k1_fe_mul(&t, &u1, &h2);
|
413
|
+
r->x = t; secp256k1_fe_mul_int(&r->x, 2); secp256k1_fe_add(&r->x, &h3); secp256k1_fe_negate(&r->x, &r->x, 3); secp256k1_fe_add(&r->x, &i2);
|
414
|
+
secp256k1_fe_negate(&r->y, &r->x, 5); secp256k1_fe_add(&r->y, &t); secp256k1_fe_mul(&r->y, &r->y, &i);
|
415
|
+
secp256k1_fe_mul(&h3, &h3, &s1); secp256k1_fe_negate(&h3, &h3, 1);
|
416
|
+
secp256k1_fe_add(&r->y, &h3);
|
417
|
+
}
|
418
|
+
|
419
|
+
static void secp256k1_gej_add_ge_var(secp256k1_gej *r, const secp256k1_gej *a, const secp256k1_ge *b, secp256k1_fe *rzr) {
|
420
|
+
/* 8 mul, 3 sqr, 4 normalize, 12 mul_int/add/negate */
|
421
|
+
secp256k1_fe z12, u1, u2, s1, s2, h, i, i2, h2, h3, t;
|
422
|
+
if (a->infinity) {
|
423
|
+
VERIFY_CHECK(rzr == NULL);
|
424
|
+
secp256k1_gej_set_ge(r, b);
|
425
|
+
return;
|
426
|
+
}
|
427
|
+
if (b->infinity) {
|
428
|
+
if (rzr != NULL) {
|
429
|
+
secp256k1_fe_set_int(rzr, 1);
|
430
|
+
}
|
431
|
+
*r = *a;
|
432
|
+
return;
|
433
|
+
}
|
434
|
+
r->infinity = 0;
|
435
|
+
|
436
|
+
secp256k1_fe_sqr(&z12, &a->z);
|
437
|
+
u1 = a->x; secp256k1_fe_normalize_weak(&u1);
|
438
|
+
secp256k1_fe_mul(&u2, &b->x, &z12);
|
439
|
+
s1 = a->y; secp256k1_fe_normalize_weak(&s1);
|
440
|
+
secp256k1_fe_mul(&s2, &b->y, &z12); secp256k1_fe_mul(&s2, &s2, &a->z);
|
441
|
+
secp256k1_fe_negate(&h, &u1, 1); secp256k1_fe_add(&h, &u2);
|
442
|
+
secp256k1_fe_negate(&i, &s1, 1); secp256k1_fe_add(&i, &s2);
|
443
|
+
if (secp256k1_fe_normalizes_to_zero_var(&h)) {
|
444
|
+
if (secp256k1_fe_normalizes_to_zero_var(&i)) {
|
445
|
+
secp256k1_gej_double_var(r, a, rzr);
|
446
|
+
} else {
|
447
|
+
if (rzr != NULL) {
|
448
|
+
secp256k1_fe_set_int(rzr, 0);
|
449
|
+
}
|
450
|
+
r->infinity = 1;
|
451
|
+
}
|
452
|
+
return;
|
453
|
+
}
|
454
|
+
secp256k1_fe_sqr(&i2, &i);
|
455
|
+
secp256k1_fe_sqr(&h2, &h);
|
456
|
+
secp256k1_fe_mul(&h3, &h, &h2);
|
457
|
+
if (rzr != NULL) {
|
458
|
+
*rzr = h;
|
459
|
+
}
|
460
|
+
secp256k1_fe_mul(&r->z, &a->z, &h);
|
461
|
+
secp256k1_fe_mul(&t, &u1, &h2);
|
462
|
+
r->x = t; secp256k1_fe_mul_int(&r->x, 2); secp256k1_fe_add(&r->x, &h3); secp256k1_fe_negate(&r->x, &r->x, 3); secp256k1_fe_add(&r->x, &i2);
|
463
|
+
secp256k1_fe_negate(&r->y, &r->x, 5); secp256k1_fe_add(&r->y, &t); secp256k1_fe_mul(&r->y, &r->y, &i);
|
464
|
+
secp256k1_fe_mul(&h3, &h3, &s1); secp256k1_fe_negate(&h3, &h3, 1);
|
465
|
+
secp256k1_fe_add(&r->y, &h3);
|
466
|
+
}
|
467
|
+
|
468
|
+
static void secp256k1_gej_add_zinv_var(secp256k1_gej *r, const secp256k1_gej *a, const secp256k1_ge *b, const secp256k1_fe *bzinv) {
|
469
|
+
/* 9 mul, 3 sqr, 4 normalize, 12 mul_int/add/negate */
|
470
|
+
secp256k1_fe az, z12, u1, u2, s1, s2, h, i, i2, h2, h3, t;
|
471
|
+
|
472
|
+
if (b->infinity) {
|
473
|
+
*r = *a;
|
474
|
+
return;
|
475
|
+
}
|
476
|
+
if (a->infinity) {
|
477
|
+
secp256k1_fe bzinv2, bzinv3;
|
478
|
+
r->infinity = b->infinity;
|
479
|
+
secp256k1_fe_sqr(&bzinv2, bzinv);
|
480
|
+
secp256k1_fe_mul(&bzinv3, &bzinv2, bzinv);
|
481
|
+
secp256k1_fe_mul(&r->x, &b->x, &bzinv2);
|
482
|
+
secp256k1_fe_mul(&r->y, &b->y, &bzinv3);
|
483
|
+
secp256k1_fe_set_int(&r->z, 1);
|
484
|
+
return;
|
485
|
+
}
|
486
|
+
r->infinity = 0;
|
487
|
+
|
488
|
+
/** We need to calculate (rx,ry,rz) = (ax,ay,az) + (bx,by,1/bzinv). Due to
|
489
|
+
* secp256k1's isomorphism we can multiply the Z coordinates on both sides
|
490
|
+
* by bzinv, and get: (rx,ry,rz*bzinv) = (ax,ay,az*bzinv) + (bx,by,1).
|
491
|
+
* This means that (rx,ry,rz) can be calculated as
|
492
|
+
* (ax,ay,az*bzinv) + (bx,by,1), when not applying the bzinv factor to rz.
|
493
|
+
* The variable az below holds the modified Z coordinate for a, which is used
|
494
|
+
* for the computation of rx and ry, but not for rz.
|
495
|
+
*/
|
496
|
+
secp256k1_fe_mul(&az, &a->z, bzinv);
|
497
|
+
|
498
|
+
secp256k1_fe_sqr(&z12, &az);
|
499
|
+
u1 = a->x; secp256k1_fe_normalize_weak(&u1);
|
500
|
+
secp256k1_fe_mul(&u2, &b->x, &z12);
|
501
|
+
s1 = a->y; secp256k1_fe_normalize_weak(&s1);
|
502
|
+
secp256k1_fe_mul(&s2, &b->y, &z12); secp256k1_fe_mul(&s2, &s2, &az);
|
503
|
+
secp256k1_fe_negate(&h, &u1, 1); secp256k1_fe_add(&h, &u2);
|
504
|
+
secp256k1_fe_negate(&i, &s1, 1); secp256k1_fe_add(&i, &s2);
|
505
|
+
if (secp256k1_fe_normalizes_to_zero_var(&h)) {
|
506
|
+
if (secp256k1_fe_normalizes_to_zero_var(&i)) {
|
507
|
+
secp256k1_gej_double_var(r, a, NULL);
|
508
|
+
} else {
|
509
|
+
r->infinity = 1;
|
510
|
+
}
|
511
|
+
return;
|
512
|
+
}
|
513
|
+
secp256k1_fe_sqr(&i2, &i);
|
514
|
+
secp256k1_fe_sqr(&h2, &h);
|
515
|
+
secp256k1_fe_mul(&h3, &h, &h2);
|
516
|
+
r->z = a->z; secp256k1_fe_mul(&r->z, &r->z, &h);
|
517
|
+
secp256k1_fe_mul(&t, &u1, &h2);
|
518
|
+
r->x = t; secp256k1_fe_mul_int(&r->x, 2); secp256k1_fe_add(&r->x, &h3); secp256k1_fe_negate(&r->x, &r->x, 3); secp256k1_fe_add(&r->x, &i2);
|
519
|
+
secp256k1_fe_negate(&r->y, &r->x, 5); secp256k1_fe_add(&r->y, &t); secp256k1_fe_mul(&r->y, &r->y, &i);
|
520
|
+
secp256k1_fe_mul(&h3, &h3, &s1); secp256k1_fe_negate(&h3, &h3, 1);
|
521
|
+
secp256k1_fe_add(&r->y, &h3);
|
522
|
+
}
|
523
|
+
|
524
|
+
|
525
|
+
static void secp256k1_gej_add_ge(secp256k1_gej *r, const secp256k1_gej *a, const secp256k1_ge *b) {
|
526
|
+
/* Operations: 7 mul, 5 sqr, 4 normalize, 21 mul_int/add/negate/cmov */
|
527
|
+
static const secp256k1_fe fe_1 = SECP256K1_FE_CONST(0, 0, 0, 0, 0, 0, 0, 1);
|
528
|
+
secp256k1_fe zz, u1, u2, s1, s2, t, tt, m, n, q, rr;
|
529
|
+
secp256k1_fe m_alt, rr_alt;
|
530
|
+
int infinity, degenerate;
|
531
|
+
VERIFY_CHECK(!b->infinity);
|
532
|
+
VERIFY_CHECK(a->infinity == 0 || a->infinity == 1);
|
533
|
+
|
534
|
+
/** In:
|
535
|
+
* Eric Brier and Marc Joye, Weierstrass Elliptic Curves and Side-Channel Attacks.
|
536
|
+
* In D. Naccache and P. Paillier, Eds., Public Key Cryptography, vol. 2274 of Lecture Notes in Computer Science, pages 335-345. Springer-Verlag, 2002.
|
537
|
+
* we find as solution for a unified addition/doubling formula:
|
538
|
+
* lambda = ((x1 + x2)^2 - x1 * x2 + a) / (y1 + y2), with a = 0 for secp256k1's curve equation.
|
539
|
+
* x3 = lambda^2 - (x1 + x2)
|
540
|
+
* 2*y3 = lambda * (x1 + x2 - 2 * x3) - (y1 + y2).
|
541
|
+
*
|
542
|
+
* Substituting x_i = Xi / Zi^2 and yi = Yi / Zi^3, for i=1,2,3, gives:
|
543
|
+
* U1 = X1*Z2^2, U2 = X2*Z1^2
|
544
|
+
* S1 = Y1*Z2^3, S2 = Y2*Z1^3
|
545
|
+
* Z = Z1*Z2
|
546
|
+
* T = U1+U2
|
547
|
+
* M = S1+S2
|
548
|
+
* Q = T*M^2
|
549
|
+
* R = T^2-U1*U2
|
550
|
+
* X3 = 4*(R^2-Q)
|
551
|
+
* Y3 = 4*(R*(3*Q-2*R^2)-M^4)
|
552
|
+
* Z3 = 2*M*Z
|
553
|
+
* (Note that the paper uses xi = Xi / Zi and yi = Yi / Zi instead.)
|
554
|
+
*
|
555
|
+
* This formula has the benefit of being the same for both addition
|
556
|
+
* of distinct points and doubling. However, it breaks down in the
|
557
|
+
* case that either point is infinity, or that y1 = -y2. We handle
|
558
|
+
* these cases in the following ways:
|
559
|
+
*
|
560
|
+
* - If b is infinity we simply bail by means of a VERIFY_CHECK.
|
561
|
+
*
|
562
|
+
* - If a is infinity, we detect this, and at the end of the
|
563
|
+
* computation replace the result (which will be meaningless,
|
564
|
+
* but we compute to be constant-time) with b.x : b.y : 1.
|
565
|
+
*
|
566
|
+
* - If a = -b, we have y1 = -y2, which is a degenerate case.
|
567
|
+
* But here the answer is infinity, so we simply set the
|
568
|
+
* infinity flag of the result, overriding the computed values
|
569
|
+
* without even needing to cmov.
|
570
|
+
*
|
571
|
+
* - If y1 = -y2 but x1 != x2, which does occur thanks to certain
|
572
|
+
* properties of our curve (specifically, 1 has nontrivial cube
|
573
|
+
* roots in our field, and the curve equation has no x coefficient)
|
574
|
+
* then the answer is not infinity but also not given by the above
|
575
|
+
* equation. In this case, we cmov in place an alternate expression
|
576
|
+
* for lambda. Specifically (y1 - y2)/(x1 - x2). Where both these
|
577
|
+
* expressions for lambda are defined, they are equal, and can be
|
578
|
+
* obtained from each other by multiplication by (y1 + y2)/(y1 + y2)
|
579
|
+
* then substitution of x^3 + 7 for y^2 (using the curve equation).
|
580
|
+
* For all pairs of nonzero points (a, b) at least one is defined,
|
581
|
+
* so this covers everything.
|
582
|
+
*/
|
583
|
+
|
584
|
+
secp256k1_fe_sqr(&zz, &a->z); /* z = Z1^2 */
|
585
|
+
u1 = a->x; secp256k1_fe_normalize_weak(&u1); /* u1 = U1 = X1*Z2^2 (1) */
|
586
|
+
secp256k1_fe_mul(&u2, &b->x, &zz); /* u2 = U2 = X2*Z1^2 (1) */
|
587
|
+
s1 = a->y; secp256k1_fe_normalize_weak(&s1); /* s1 = S1 = Y1*Z2^3 (1) */
|
588
|
+
secp256k1_fe_mul(&s2, &b->y, &zz); /* s2 = Y2*Z1^2 (1) */
|
589
|
+
secp256k1_fe_mul(&s2, &s2, &a->z); /* s2 = S2 = Y2*Z1^3 (1) */
|
590
|
+
t = u1; secp256k1_fe_add(&t, &u2); /* t = T = U1+U2 (2) */
|
591
|
+
m = s1; secp256k1_fe_add(&m, &s2); /* m = M = S1+S2 (2) */
|
592
|
+
secp256k1_fe_sqr(&rr, &t); /* rr = T^2 (1) */
|
593
|
+
secp256k1_fe_negate(&m_alt, &u2, 1); /* Malt = -X2*Z1^2 */
|
594
|
+
secp256k1_fe_mul(&tt, &u1, &m_alt); /* tt = -U1*U2 (2) */
|
595
|
+
secp256k1_fe_add(&rr, &tt); /* rr = R = T^2-U1*U2 (3) */
|
596
|
+
/** If lambda = R/M = 0/0 we have a problem (except in the "trivial"
|
597
|
+
* case that Z = z1z2 = 0, and this is special-cased later on). */
|
598
|
+
degenerate = secp256k1_fe_normalizes_to_zero(&m) &
|
599
|
+
secp256k1_fe_normalizes_to_zero(&rr);
|
600
|
+
/* This only occurs when y1 == -y2 and x1^3 == x2^3, but x1 != x2.
|
601
|
+
* This means either x1 == beta*x2 or beta*x1 == x2, where beta is
|
602
|
+
* a nontrivial cube root of one. In either case, an alternate
|
603
|
+
* non-indeterminate expression for lambda is (y1 - y2)/(x1 - x2),
|
604
|
+
* so we set R/M equal to this. */
|
605
|
+
rr_alt = s1;
|
606
|
+
secp256k1_fe_mul_int(&rr_alt, 2); /* rr = Y1*Z2^3 - Y2*Z1^3 (2) */
|
607
|
+
secp256k1_fe_add(&m_alt, &u1); /* Malt = X1*Z2^2 - X2*Z1^2 */
|
608
|
+
|
609
|
+
secp256k1_fe_cmov(&rr_alt, &rr, !degenerate);
|
610
|
+
secp256k1_fe_cmov(&m_alt, &m, !degenerate);
|
611
|
+
/* Now Ralt / Malt = lambda and is guaranteed not to be 0/0.
|
612
|
+
* From here on out Ralt and Malt represent the numerator
|
613
|
+
* and denominator of lambda; R and M represent the explicit
|
614
|
+
* expressions x1^2 + x2^2 + x1x2 and y1 + y2. */
|
615
|
+
secp256k1_fe_sqr(&n, &m_alt); /* n = Malt^2 (1) */
|
616
|
+
secp256k1_fe_mul(&q, &n, &t); /* q = Q = T*Malt^2 (1) */
|
617
|
+
/* These two lines use the observation that either M == Malt or M == 0,
|
618
|
+
* so M^3 * Malt is either Malt^4 (which is computed by squaring), or
|
619
|
+
* zero (which is "computed" by cmov). So the cost is one squaring
|
620
|
+
* versus two multiplications. */
|
621
|
+
secp256k1_fe_sqr(&n, &n);
|
622
|
+
secp256k1_fe_cmov(&n, &m, degenerate); /* n = M^3 * Malt (2) */
|
623
|
+
secp256k1_fe_sqr(&t, &rr_alt); /* t = Ralt^2 (1) */
|
624
|
+
secp256k1_fe_mul(&r->z, &a->z, &m_alt); /* r->z = Malt*Z (1) */
|
625
|
+
infinity = secp256k1_fe_normalizes_to_zero(&r->z) * (1 - a->infinity);
|
626
|
+
secp256k1_fe_mul_int(&r->z, 2); /* r->z = Z3 = 2*Malt*Z (2) */
|
627
|
+
secp256k1_fe_negate(&q, &q, 1); /* q = -Q (2) */
|
628
|
+
secp256k1_fe_add(&t, &q); /* t = Ralt^2-Q (3) */
|
629
|
+
secp256k1_fe_normalize_weak(&t);
|
630
|
+
r->x = t; /* r->x = Ralt^2-Q (1) */
|
631
|
+
secp256k1_fe_mul_int(&t, 2); /* t = 2*x3 (2) */
|
632
|
+
secp256k1_fe_add(&t, &q); /* t = 2*x3 - Q: (4) */
|
633
|
+
secp256k1_fe_mul(&t, &t, &rr_alt); /* t = Ralt*(2*x3 - Q) (1) */
|
634
|
+
secp256k1_fe_add(&t, &n); /* t = Ralt*(2*x3 - Q) + M^3*Malt (3) */
|
635
|
+
secp256k1_fe_negate(&r->y, &t, 3); /* r->y = Ralt*(Q - 2x3) - M^3*Malt (4) */
|
636
|
+
secp256k1_fe_normalize_weak(&r->y);
|
637
|
+
secp256k1_fe_mul_int(&r->x, 4); /* r->x = X3 = 4*(Ralt^2-Q) */
|
638
|
+
secp256k1_fe_mul_int(&r->y, 4); /* r->y = Y3 = 4*Ralt*(Q - 2x3) - 4*M^3*Malt (4) */
|
639
|
+
|
640
|
+
/** In case a->infinity == 1, replace r with (b->x, b->y, 1). */
|
641
|
+
secp256k1_fe_cmov(&r->x, &b->x, a->infinity);
|
642
|
+
secp256k1_fe_cmov(&r->y, &b->y, a->infinity);
|
643
|
+
secp256k1_fe_cmov(&r->z, &fe_1, a->infinity);
|
644
|
+
r->infinity = infinity;
|
645
|
+
}
|
646
|
+
|
647
|
+
static void secp256k1_gej_rescale(secp256k1_gej *r, const secp256k1_fe *s) {
|
648
|
+
/* Operations: 4 mul, 1 sqr */
|
649
|
+
secp256k1_fe zz;
|
650
|
+
VERIFY_CHECK(!secp256k1_fe_is_zero(s));
|
651
|
+
secp256k1_fe_sqr(&zz, s);
|
652
|
+
secp256k1_fe_mul(&r->x, &r->x, &zz); /* r->x *= s^2 */
|
653
|
+
secp256k1_fe_mul(&r->y, &r->y, &zz);
|
654
|
+
secp256k1_fe_mul(&r->y, &r->y, s); /* r->y *= s^3 */
|
655
|
+
secp256k1_fe_mul(&r->z, &r->z, s); /* r->z *= s */
|
656
|
+
}
|
657
|
+
|
658
|
+
static void secp256k1_ge_to_storage(secp256k1_ge_storage *r, const secp256k1_ge *a) {
|
659
|
+
secp256k1_fe x, y;
|
660
|
+
VERIFY_CHECK(!a->infinity);
|
661
|
+
x = a->x;
|
662
|
+
secp256k1_fe_normalize(&x);
|
663
|
+
y = a->y;
|
664
|
+
secp256k1_fe_normalize(&y);
|
665
|
+
secp256k1_fe_to_storage(&r->x, &x);
|
666
|
+
secp256k1_fe_to_storage(&r->y, &y);
|
667
|
+
}
|
668
|
+
|
669
|
+
static void secp256k1_ge_from_storage(secp256k1_ge *r, const secp256k1_ge_storage *a) {
|
670
|
+
secp256k1_fe_from_storage(&r->x, &a->x);
|
671
|
+
secp256k1_fe_from_storage(&r->y, &a->y);
|
672
|
+
r->infinity = 0;
|
673
|
+
}
|
674
|
+
|
675
|
+
static SECP256K1_INLINE void secp256k1_ge_storage_cmov(secp256k1_ge_storage *r, const secp256k1_ge_storage *a, int flag) {
|
676
|
+
secp256k1_fe_storage_cmov(&r->x, &a->x, flag);
|
677
|
+
secp256k1_fe_storage_cmov(&r->y, &a->y, flag);
|
678
|
+
}
|
679
|
+
|
680
|
+
#ifdef USE_ENDOMORPHISM
|
681
|
+
static void secp256k1_ge_mul_lambda(secp256k1_ge *r, const secp256k1_ge *a) {
|
682
|
+
static const secp256k1_fe beta = SECP256K1_FE_CONST(
|
683
|
+
0x7ae96a2bul, 0x657c0710ul, 0x6e64479eul, 0xac3434e9ul,
|
684
|
+
0x9cf04975ul, 0x12f58995ul, 0xc1396c28ul, 0x719501eeul
|
685
|
+
);
|
686
|
+
*r = *a;
|
687
|
+
secp256k1_fe_mul(&r->x, &r->x, &beta);
|
688
|
+
}
|
689
|
+
#endif
|
690
|
+
|
691
|
+
static int secp256k1_gej_has_quad_y_var(const secp256k1_gej *a) {
|
692
|
+
secp256k1_fe yz;
|
693
|
+
|
694
|
+
if (a->infinity) {
|
695
|
+
return 0;
|
696
|
+
}
|
697
|
+
|
698
|
+
/* We rely on the fact that the Jacobi symbol of 1 / a->z^3 is the same as
|
699
|
+
* that of a->z. Thus a->y / a->z^3 is a quadratic residue iff a->y * a->z
|
700
|
+
is */
|
701
|
+
secp256k1_fe_mul(&yz, &a->y, &a->z);
|
702
|
+
return secp256k1_fe_is_quad_var(&yz);
|
703
|
+
}
|
704
|
+
|
705
|
+
#endif /* SECP256K1_GROUP_IMPL_H */
|