meteor-node-stubs 1.2.17 → 1.2.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/node_modules/@meteorjs/browserify-sign/browser/sign.js +1 -1
- package/node_modules/@meteorjs/browserify-sign/browser/verify.js +1 -1
- package/node_modules/@meteorjs/browserify-sign/elliptic/benchmarks/deps/jodid.js +82 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/benchmarks/deps/secp256k1.js +41 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/benchmarks/index.js +153 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/benchmarks/package.json +21 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/dist/.gitkeep +0 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/dist/elliptic.js +8961 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/dist/elliptic.min.js +1 -0
- package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic.js +1 -1
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/api-test.js +20 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/curve-test.js +357 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/ecdh-test.js +43 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/ecdsa-test.js +547 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/ed25519-test.js +138 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/fixtures/derivation-fixtures.js +3842 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/fixtures/sign.input +1024 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/index.js +10 -0
- package/node_modules/@meteorjs/browserify-sign/elliptic/test/unittests.html +39 -0
- package/node_modules/@meteorjs/browserify-sign/package.json +22 -5
- package/node_modules/@meteorjs/create-ecdh/browser.js +1 -1
- package/node_modules/@meteorjs/create-ecdh/elliptic/README.md +238 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/benchmarks/deps/jodid.js +82 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/benchmarks/deps/secp256k1.js +41 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/benchmarks/index.js +153 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/benchmarks/package.json +21 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/dist/.gitkeep +0 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/dist/elliptic.js +8961 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/dist/elliptic.min.js +1 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/curve/base.js +381 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/curve/edwards.js +435 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/curve/index.js +8 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/curve/mont.js +178 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/curve/short.js +938 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/curves.js +206 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/ec/index.js +278 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/ec/key.js +121 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/ec/signature.js +176 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/eddsa/index.js +121 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/eddsa/key.js +95 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/eddsa/signature.js +66 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/precomputed/secp256k1.js +780 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic/utils.js +122 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/lib/elliptic.js +13 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/api-test.js +20 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/curve-test.js +357 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/ecdh-test.js +43 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/ecdsa-test.js +547 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/ed25519-test.js +138 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/fixtures/derivation-fixtures.js +3842 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/fixtures/sign.input +1024 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/index.js +10 -0
- package/node_modules/@meteorjs/create-ecdh/elliptic/test/unittests.html +39 -0
- package/node_modules/@meteorjs/create-ecdh/node_modules/bn.js/lib/bn.js +1 -0
- package/node_modules/@meteorjs/create-ecdh/node_modules/bn.js/package.json +1 -1
- package/node_modules/@meteorjs/create-ecdh/package.json +23 -5
- package/node_modules/asn1.js/node_modules/bn.js/lib/bn.js +6 -5
- package/node_modules/asn1.js/node_modules/bn.js/package.json +1 -1
- package/node_modules/asn1.js/node_modules/bn.js/util/genCombMulTo.js +65 -0
- package/node_modules/asn1.js/node_modules/bn.js/util/genCombMulTo10.js +65 -0
- package/node_modules/available-typed-arrays/.eslintrc +0 -4
- package/node_modules/available-typed-arrays/CHANGELOG.md +21 -0
- package/node_modules/available-typed-arrays/README.md +16 -13
- package/node_modules/available-typed-arrays/index.d.ts +8 -0
- package/node_modules/available-typed-arrays/index.js +4 -14
- package/node_modules/available-typed-arrays/package.json +26 -15
- package/node_modules/available-typed-arrays/tsconfig.json +49 -0
- package/node_modules/bn.js/README.md +11 -5
- package/node_modules/bn.js/lib/bn.js +6 -5
- package/node_modules/bn.js/package.json +1 -1
- package/node_modules/browserify-rsa/CHANGELOG.md +98 -0
- package/node_modules/browserify-rsa/README.md +0 -2
- package/node_modules/browserify-rsa/index.js +31 -28
- package/node_modules/browserify-rsa/package.json +64 -29
- package/node_modules/call-bind/CHANGELOG.md +13 -0
- package/node_modules/call-bind/index.js +6 -17
- package/node_modules/call-bind/package.json +14 -16
- package/node_modules/call-bind/test/index.js +4 -10
- package/node_modules/call-bind-apply-helpers/.eslintrc +17 -0
- package/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
- package/node_modules/call-bind-apply-helpers/.nycrc +9 -0
- package/node_modules/call-bind-apply-helpers/CHANGELOG.md +30 -0
- package/node_modules/{has-proto → call-bind-apply-helpers}/LICENSE +1 -1
- package/node_modules/call-bind-apply-helpers/README.md +62 -0
- package/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
- package/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
- package/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
- package/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
- package/node_modules/call-bind-apply-helpers/index.d.ts +64 -0
- package/node_modules/call-bind-apply-helpers/index.js +15 -0
- package/node_modules/call-bind-apply-helpers/package.json +85 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/test/index.js +63 -0
- package/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
- package/node_modules/call-bound/.eslintrc +13 -0
- package/node_modules/call-bound/.github/FUNDING.yml +12 -0
- package/node_modules/call-bound/.nycrc +9 -0
- package/node_modules/call-bound/CHANGELOG.md +42 -0
- package/node_modules/{@meteorjs/browserify-sign/node_modules/bn.js → call-bound}/LICENSE +3 -1
- package/node_modules/call-bound/README.md +53 -0
- package/node_modules/call-bound/index.d.ts +94 -0
- package/node_modules/call-bound/index.js +19 -0
- package/node_modules/call-bound/package.json +99 -0
- package/node_modules/call-bound/test/index.js +61 -0
- package/node_modules/call-bound/tsconfig.json +10 -0
- package/node_modules/cipher-base/.eslintrc +24 -1
- package/node_modules/cipher-base/.github/FUNDING.yml +12 -0
- package/node_modules/cipher-base/CHANGELOG.md +66 -0
- package/node_modules/cipher-base/index.js +145 -77
- package/node_modules/cipher-base/package.json +60 -30
- package/node_modules/cipher-base/test/index.js +221 -0
- package/node_modules/des.js/lib/des/cipher.js +1 -0
- package/node_modules/des.js/lib/des/des.js +8 -0
- package/node_modules/des.js/package.json +3 -4
- package/node_modules/des.js/test/cbc-test.js +5 -5
- package/node_modules/des.js/test/des-test.js +9 -9
- package/node_modules/des.js/test/ede-test.js +39 -6
- package/node_modules/diffie-hellman/node_modules/bn.js/lib/bn.js +6 -5
- package/node_modules/diffie-hellman/node_modules/bn.js/package.json +1 -1
- package/node_modules/diffie-hellman/node_modules/bn.js/util/genCombMulTo.js +65 -0
- package/node_modules/diffie-hellman/node_modules/bn.js/util/genCombMulTo10.js +65 -0
- package/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
- package/node_modules/dunder-proto/.nycrc +13 -0
- package/node_modules/dunder-proto/CHANGELOG.md +24 -0
- package/node_modules/{@meteorjs/crypto-browserify/node_modules/hash-base → dunder-proto}/LICENSE +6 -6
- package/node_modules/dunder-proto/README.md +54 -0
- package/node_modules/dunder-proto/get.d.ts +5 -0
- package/node_modules/dunder-proto/get.js +30 -0
- package/node_modules/dunder-proto/package.json +76 -0
- package/node_modules/dunder-proto/set.d.ts +5 -0
- package/node_modules/dunder-proto/set.js +35 -0
- package/node_modules/dunder-proto/test/get.js +34 -0
- package/node_modules/dunder-proto/test/index.js +4 -0
- package/node_modules/dunder-proto/test/set.js +50 -0
- package/node_modules/dunder-proto/tsconfig.json +9 -0
- package/node_modules/es-define-property/CHANGELOG.md +14 -0
- package/node_modules/es-define-property/index.js +1 -3
- package/node_modules/es-define-property/package.json +12 -12
- package/node_modules/es-define-property/test/index.js +1 -0
- package/node_modules/es-define-property/tsconfig.json +2 -42
- package/node_modules/es-object-atoms/.eslintrc +16 -0
- package/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
- package/node_modules/es-object-atoms/CHANGELOG.md +37 -0
- package/node_modules/{elliptic/node_modules/bn.js → es-object-atoms}/LICENSE +3 -1
- package/node_modules/es-object-atoms/README.md +63 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
- package/node_modules/es-object-atoms/ToObject.d.ts +7 -0
- package/node_modules/es-object-atoms/ToObject.js +10 -0
- package/node_modules/es-object-atoms/index.d.ts +3 -0
- package/node_modules/es-object-atoms/index.js +4 -0
- package/node_modules/es-object-atoms/isObject.d.ts +3 -0
- package/node_modules/es-object-atoms/isObject.js +6 -0
- package/node_modules/es-object-atoms/package.json +80 -0
- package/node_modules/es-object-atoms/test/index.js +38 -0
- package/node_modules/es-object-atoms/tsconfig.json +6 -0
- package/node_modules/for-each/.eslintrc +16 -2
- package/node_modules/{has-proto → for-each}/.github/FUNDING.yml +1 -1
- package/node_modules/for-each/.github/SECURITY.md +3 -0
- package/node_modules/for-each/.nycrc +8 -0
- package/node_modules/for-each/CHANGELOG.md +107 -0
- package/node_modules/for-each/README.md +0 -4
- package/node_modules/for-each/index.d.ts +35 -0
- package/node_modules/for-each/index.js +11 -4
- package/node_modules/for-each/package.json +47 -36
- package/node_modules/for-each/test/test.js +54 -12
- package/node_modules/for-each/tsconfig.json +8 -0
- package/node_modules/get-intrinsic/.eslintrc +4 -0
- package/node_modules/get-intrinsic/CHANGELOG.md +43 -0
- package/node_modules/get-intrinsic/index.js +40 -21
- package/node_modules/get-intrinsic/package.json +24 -20
- package/node_modules/get-intrinsic/test/GetIntrinsic.js +2 -2
- package/node_modules/get-proto/.eslintrc +10 -0
- package/node_modules/get-proto/.github/FUNDING.yml +12 -0
- package/node_modules/get-proto/.nycrc +9 -0
- package/node_modules/get-proto/CHANGELOG.md +21 -0
- package/node_modules/get-proto/LICENSE +21 -0
- package/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
- package/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
- package/node_modules/get-proto/README.md +50 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
- package/node_modules/get-proto/index.d.ts +5 -0
- package/node_modules/get-proto/index.js +27 -0
- package/node_modules/{has-proto → get-proto}/package.json +33 -26
- package/node_modules/get-proto/test/index.js +68 -0
- package/node_modules/get-proto/tsconfig.json +9 -0
- package/node_modules/gopd/CHANGELOG.md +20 -0
- package/node_modules/gopd/gOPD.d.ts +1 -0
- package/node_modules/gopd/gOPD.js +4 -0
- package/node_modules/gopd/index.d.ts +5 -0
- package/node_modules/gopd/index.js +2 -3
- package/node_modules/gopd/package.json +16 -10
- package/node_modules/gopd/test/index.js +2 -1
- package/node_modules/gopd/tsconfig.json +9 -0
- package/node_modules/has-symbols/CHANGELOG.md +16 -0
- package/node_modules/has-symbols/index.d.ts +3 -0
- package/node_modules/has-symbols/index.js +1 -0
- package/node_modules/has-symbols/package.json +19 -9
- package/node_modules/has-symbols/shams.d.ts +3 -0
- package/node_modules/has-symbols/shams.js +5 -2
- package/node_modules/has-symbols/test/shams/core-js.js +1 -0
- package/node_modules/has-symbols/test/shams/get-own-property-symbols.js +1 -0
- package/node_modules/has-symbols/test/tests.js +4 -2
- package/node_modules/has-symbols/tsconfig.json +10 -0
- package/node_modules/has-tostringtag/.eslintrc +0 -6
- package/node_modules/has-tostringtag/.nycrc +13 -0
- package/node_modules/has-tostringtag/CHANGELOG.md +22 -0
- package/node_modules/has-tostringtag/index.d.ts +3 -0
- package/node_modules/has-tostringtag/index.js +1 -0
- package/node_modules/has-tostringtag/package.json +37 -13
- package/node_modules/has-tostringtag/shams.d.ts +3 -0
- package/node_modules/has-tostringtag/shams.js +1 -0
- package/node_modules/has-tostringtag/test/shams/core-js.js +3 -0
- package/node_modules/has-tostringtag/test/shams/get-own-property-symbols.js +2 -0
- package/node_modules/has-tostringtag/test/tests.js +2 -1
- package/node_modules/has-tostringtag/tsconfig.json +49 -0
- package/node_modules/hash-base/README.md +15 -15
- package/node_modules/hash-base/index.js +52 -9
- package/node_modules/hash-base/package.json +40 -40
- package/node_modules/hasown/CHANGELOG.md +20 -0
- package/node_modules/hasown/index.d.ts +3 -3
- package/node_modules/hasown/index.js +1 -1
- package/node_modules/hasown/package.json +16 -15
- package/node_modules/hasown/tsconfig.json +3 -46
- package/node_modules/is-arguments/.eslintrc +0 -1
- package/node_modules/is-arguments/CHANGELOG.md +22 -0
- package/node_modules/is-arguments/README.md +11 -11
- package/node_modules/is-arguments/index.d.ts +6 -0
- package/node_modules/is-arguments/index.js +19 -8
- package/node_modules/is-arguments/package.json +25 -11
- package/node_modules/is-arguments/test/index.js +4 -1
- package/node_modules/is-arguments/tsconfig.json +9 -0
- package/node_modules/is-generator-function/.eslintrc +1 -1
- package/node_modules/is-generator-function/CHANGELOG.md +21 -0
- package/node_modules/is-generator-function/index.d.ts +3 -0
- package/node_modules/is-generator-function/index.js +16 -7
- package/node_modules/is-generator-function/package.json +30 -11
- package/node_modules/is-generator-function/test/corejs.js +1 -0
- package/node_modules/is-generator-function/test/index.js +4 -7
- package/node_modules/is-generator-function/test/uglified.js +1 -0
- package/node_modules/is-generator-function/tsconfig.json +9 -0
- package/node_modules/is-regex/.editorconfig +23 -0
- package/node_modules/is-regex/.eslintrc +10 -0
- package/node_modules/is-regex/.nycrc +10 -0
- package/node_modules/is-regex/CHANGELOG.md +233 -0
- package/node_modules/is-regex/LICENSE +20 -0
- package/node_modules/is-regex/README.md +52 -0
- package/node_modules/is-regex/index.d.ts +3 -0
- package/node_modules/is-regex/index.js +69 -0
- package/node_modules/is-regex/package.json +104 -0
- package/node_modules/is-regex/test/index.js +121 -0
- package/node_modules/is-regex/tsconfig.json +9 -0
- package/node_modules/is-typed-array/CHANGELOG.md +32 -0
- package/node_modules/is-typed-array/index.d.ts +9 -0
- package/node_modules/is-typed-array/index.js +1 -0
- package/node_modules/is-typed-array/package.json +23 -10
- package/node_modules/is-typed-array/test/index.js +9 -1
- package/node_modules/is-typed-array/tsconfig.json +6 -0
- package/node_modules/math-intrinsics/.eslintrc +16 -0
- package/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
- package/node_modules/math-intrinsics/CHANGELOG.md +24 -0
- package/node_modules/math-intrinsics/LICENSE +21 -0
- package/node_modules/math-intrinsics/README.md +50 -0
- package/node_modules/math-intrinsics/abs.d.ts +1 -0
- package/node_modules/math-intrinsics/abs.js +4 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
- package/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxValue.js +5 -0
- package/node_modules/math-intrinsics/floor.d.ts +1 -0
- package/node_modules/math-intrinsics/floor.js +4 -0
- package/node_modules/math-intrinsics/isFinite.d.ts +3 -0
- package/node_modules/math-intrinsics/isFinite.js +12 -0
- package/node_modules/math-intrinsics/isInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/isInteger.js +16 -0
- package/node_modules/math-intrinsics/isNaN.d.ts +1 -0
- package/node_modules/math-intrinsics/isNaN.js +6 -0
- package/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
- package/node_modules/math-intrinsics/isNegativeZero.js +6 -0
- package/node_modules/math-intrinsics/max.d.ts +1 -0
- package/node_modules/math-intrinsics/max.js +4 -0
- package/node_modules/math-intrinsics/min.d.ts +1 -0
- package/node_modules/math-intrinsics/min.js +4 -0
- package/node_modules/math-intrinsics/mod.d.ts +3 -0
- package/node_modules/math-intrinsics/mod.js +9 -0
- package/node_modules/math-intrinsics/package.json +86 -0
- package/node_modules/math-intrinsics/pow.d.ts +1 -0
- package/node_modules/math-intrinsics/pow.js +4 -0
- package/node_modules/math-intrinsics/round.d.ts +1 -0
- package/node_modules/math-intrinsics/round.js +4 -0
- package/node_modules/math-intrinsics/sign.d.ts +3 -0
- package/node_modules/math-intrinsics/sign.js +11 -0
- package/node_modules/math-intrinsics/test/index.js +192 -0
- package/node_modules/math-intrinsics/tsconfig.json +3 -0
- package/node_modules/miller-rabin/node_modules/bn.js/lib/bn.js +6 -5
- package/node_modules/miller-rabin/node_modules/bn.js/package.json +1 -1
- package/node_modules/miller-rabin/node_modules/bn.js/util/genCombMulTo.js +65 -0
- package/node_modules/miller-rabin/node_modules/bn.js/util/genCombMulTo10.js +65 -0
- package/node_modules/object-inspect/CHANGELOG.md +20 -0
- package/node_modules/object-inspect/index.js +27 -10
- package/node_modules/object-inspect/package.json +9 -8
- package/node_modules/object-inspect/test/quoteStyle.js +9 -0
- package/node_modules/object-inspect/test/values.js +50 -0
- package/node_modules/object-is/.eslintrc +1 -1
- package/node_modules/object-is/.nycrc +0 -4
- package/node_modules/object-is/CHANGELOG.md +25 -0
- package/node_modules/object-is/README.md +20 -20
- package/node_modules/object-is/package.json +23 -14
- package/node_modules/object.assign/CHANGELOG.md +21 -0
- package/node_modules/object.assign/dist/browser.js +495 -135
- package/node_modules/object.assign/implementation.js +6 -6
- package/node_modules/object.assign/package.json +14 -14
- package/node_modules/object.assign/test/tests.js +2 -2
- package/node_modules/possible-typed-array-names/.eslintrc +5 -0
- package/node_modules/possible-typed-array-names/.github/FUNDING.yml +12 -0
- package/node_modules/possible-typed-array-names/CHANGELOG.md +29 -0
- package/node_modules/possible-typed-array-names/LICENSE +21 -0
- package/node_modules/possible-typed-array-names/README.md +50 -0
- package/node_modules/possible-typed-array-names/index.d.ts +16 -0
- package/node_modules/possible-typed-array-names/index.js +17 -0
- package/node_modules/possible-typed-array-names/package.json +84 -0
- package/node_modules/possible-typed-array-names/test/index.js +19 -0
- package/node_modules/possible-typed-array-names/tsconfig.json +9 -0
- package/node_modules/public-encrypt/node_modules/bn.js/lib/bn.js +6 -5
- package/node_modules/public-encrypt/node_modules/bn.js/package.json +1 -1
- package/node_modules/public-encrypt/node_modules/bn.js/util/genCombMulTo.js +65 -0
- package/node_modules/public-encrypt/node_modules/bn.js/util/genCombMulTo10.js +65 -0
- package/node_modules/qs/.eslintrc +1 -0
- package/node_modules/qs/CHANGELOG.md +22 -0
- package/node_modules/qs/README.md +25 -1
- package/node_modules/qs/dist/qs.js +95 -44
- package/node_modules/qs/lib/parse.js +44 -12
- package/node_modules/qs/lib/stringify.js +11 -6
- package/node_modules/qs/lib/utils.js +7 -4
- package/node_modules/qs/package.json +9 -7
- package/node_modules/qs/test/parse.js +133 -27
- package/node_modules/qs/test/stringify.js +19 -11
- package/node_modules/qs/test/utils.js +126 -0
- package/node_modules/safe-regex-test/.eslintrc +9 -0
- package/node_modules/safe-regex-test/.github/FUNDING.yml +12 -0
- package/node_modules/safe-regex-test/.nycrc +13 -0
- package/node_modules/safe-regex-test/CHANGELOG.md +55 -0
- package/node_modules/safe-regex-test/LICENSE +21 -0
- package/node_modules/safe-regex-test/README.md +46 -0
- package/node_modules/safe-regex-test/index.d.ts +3 -0
- package/node_modules/safe-regex-test/index.js +17 -0
- package/node_modules/safe-regex-test/package.json +87 -0
- package/node_modules/safe-regex-test/test/index.js +41 -0
- package/node_modules/safe-regex-test/tsconfig.json +9 -0
- package/node_modules/side-channel/.eslintrc +1 -0
- package/node_modules/side-channel/CHANGELOG.md +15 -0
- package/node_modules/side-channel/README.md +60 -1
- package/node_modules/side-channel/index.d.ts +9 -22
- package/node_modules/side-channel/index.js +20 -106
- package/node_modules/side-channel/package.json +20 -19
- package/node_modules/side-channel/test/index.js +76 -55
- package/node_modules/side-channel/tsconfig.json +2 -43
- package/node_modules/side-channel-list/.editorconfig +9 -0
- package/node_modules/side-channel-list/.eslintrc +11 -0
- package/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-list/.nycrc +13 -0
- package/node_modules/side-channel-list/CHANGELOG.md +15 -0
- package/node_modules/side-channel-list/LICENSE +21 -0
- package/node_modules/side-channel-list/README.md +62 -0
- package/node_modules/side-channel-list/index.d.ts +13 -0
- package/node_modules/side-channel-list/index.js +113 -0
- package/node_modules/side-channel-list/list.d.ts +14 -0
- package/node_modules/side-channel-list/package.json +77 -0
- package/node_modules/side-channel-list/test/index.js +104 -0
- package/node_modules/side-channel-list/tsconfig.json +9 -0
- package/node_modules/side-channel-map/.editorconfig +9 -0
- package/node_modules/side-channel-map/.eslintrc +11 -0
- package/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-map/.nycrc +13 -0
- package/node_modules/side-channel-map/CHANGELOG.md +22 -0
- package/node_modules/side-channel-map/LICENSE +21 -0
- package/node_modules/side-channel-map/README.md +62 -0
- package/node_modules/side-channel-map/index.d.ts +15 -0
- package/node_modules/side-channel-map/index.js +68 -0
- package/node_modules/side-channel-map/package.json +80 -0
- package/node_modules/side-channel-map/test/index.js +114 -0
- package/node_modules/side-channel-map/tsconfig.json +9 -0
- package/node_modules/side-channel-weakmap/.editorconfig +9 -0
- package/node_modules/side-channel-weakmap/.eslintrc +12 -0
- package/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-weakmap/.nycrc +13 -0
- package/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
- package/node_modules/side-channel-weakmap/LICENSE +21 -0
- package/node_modules/side-channel-weakmap/README.md +62 -0
- package/node_modules/side-channel-weakmap/index.d.ts +15 -0
- package/node_modules/side-channel-weakmap/index.js +84 -0
- package/node_modules/side-channel-weakmap/package.json +87 -0
- package/node_modules/side-channel-weakmap/test/index.js +114 -0
- package/node_modules/side-channel-weakmap/tsconfig.json +9 -0
- package/node_modules/which-typed-array/.eslintrc +1 -0
- package/node_modules/which-typed-array/CHANGELOG.md +57 -0
- package/node_modules/which-typed-array/index.d.ts +62 -0
- package/node_modules/which-typed-array/index.js +50 -25
- package/node_modules/which-typed-array/package.json +28 -13
- package/node_modules/which-typed-array/test/index.js +7 -1
- package/node_modules/which-typed-array/tsconfig.json +9 -0
- package/package.json +2 -3
- package/node_modules/@meteorjs/browserify-sign/node_modules/bn.js/README.md +0 -214
- package/node_modules/@meteorjs/browserify-sign/node_modules/bn.js/lib/bn.js +0 -3547
- package/node_modules/@meteorjs/browserify-sign/node_modules/bn.js/package.json +0 -39
- package/node_modules/@meteorjs/browserify-sign/node_modules/hash-base/LICENSE +0 -21
- package/node_modules/@meteorjs/browserify-sign/node_modules/hash-base/README.md +0 -48
- package/node_modules/@meteorjs/browserify-sign/node_modules/hash-base/index.js +0 -138
- package/node_modules/@meteorjs/browserify-sign/node_modules/hash-base/package.json +0 -42
- package/node_modules/@meteorjs/crypto-browserify/node_modules/hash-base/README.md +0 -48
- package/node_modules/@meteorjs/crypto-browserify/node_modules/hash-base/index.js +0 -95
- package/node_modules/@meteorjs/crypto-browserify/node_modules/hash-base/package.json +0 -41
- package/node_modules/available-typed-arrays/.eslintignore +0 -1
- package/node_modules/bn.js/CHANGELOG.md +0 -51
- package/node_modules/cipher-base/.npmignore +0 -1
- package/node_modules/cipher-base/.travis.yml +0 -6
- package/node_modules/cipher-base/test.js +0 -111
- package/node_modules/elliptic/node_modules/bn.js/README.md +0 -200
- package/node_modules/elliptic/node_modules/bn.js/lib/bn.js +0 -3446
- package/node_modules/elliptic/node_modules/bn.js/package.json +0 -36
- package/node_modules/elliptic/package.json +0 -56
- package/node_modules/for-each/.travis.yml +0 -45
- package/node_modules/for-each/test/.eslintrc +0 -8
- package/node_modules/has-proto/CHANGELOG.md +0 -23
- package/node_modules/has-proto/README.md +0 -38
- package/node_modules/has-proto/index.js +0 -11
- package/node_modules/has-proto/test/index.js +0 -19
- package/node_modules/hasown/index.d.ts.map +0 -1
- package/node_modules/is-arguments/.eslintignore +0 -1
- package/node_modules/is-generator-function/.eslintignore +0 -1
- package/node_modules/object-is/.eslintignore +0 -1
- package/node_modules/object.assign/test.html +0 -18458
- package/node_modules/parse-asn1/node_modules/hash-base/LICENSE +0 -21
- package/node_modules/parse-asn1/node_modules/hash-base/README.md +0 -48
- package/node_modules/parse-asn1/node_modules/hash-base/index.js +0 -95
- package/node_modules/parse-asn1/node_modules/hash-base/package.json +0 -41
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/README.md +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/curve/base.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/curve/edwards.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/curve/index.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/curve/mont.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/curve/short.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/curves.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/ec/index.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/ec/key.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/ec/signature.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/eddsa/index.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/eddsa/key.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/eddsa/signature.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/precomputed/secp256k1.js +0 -0
- /package/node_modules/{elliptic → @meteorjs/browserify-sign/elliptic}/lib/elliptic/utils.js +0 -0
- /package/node_modules/{has-proto → dunder-proto}/.eslintrc +0 -0
|
@@ -0,0 +1,357 @@
|
|
|
1
|
+
/* eslint-env node, mocha */
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var assert = require('assert');
|
|
5
|
+
var BN = require('bn.js');
|
|
6
|
+
var elliptic = require('../');
|
|
7
|
+
|
|
8
|
+
describe('Curve', function() {
|
|
9
|
+
it('should work with example curve', function() {
|
|
10
|
+
var curve = new elliptic.curve.short({
|
|
11
|
+
p: '1d',
|
|
12
|
+
a: '4',
|
|
13
|
+
b: '14',
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
var p = curve.point('18', '16');
|
|
17
|
+
assert(p.validate());
|
|
18
|
+
assert(p.dbl().validate());
|
|
19
|
+
assert(p.dbl().add(p).validate());
|
|
20
|
+
assert(p.dbl().add(p.dbl()).validate());
|
|
21
|
+
assert(p.dbl().add(p.dbl()).eq(p.add(p).add(p).add(p)));
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it('should dbl points on edwards curve using proj coordinates', function() {
|
|
25
|
+
var curve = new elliptic.curve.edwards({
|
|
26
|
+
p: new BN('97ffffffffffffffffffffffffffffffffffffffffffffffffffffffffff' +
|
|
27
|
+
'ffffffffffffffffffffffffffffffffff3f', 16, 'le'),
|
|
28
|
+
q: new BN('19973cfd137ee273272d101b28695e7ce1ee951ef221fbd5ffffffffff' +
|
|
29
|
+
'ffffffffffffffffffffffffffffffffffff0f', 16, 'le'),
|
|
30
|
+
r: '8',
|
|
31
|
+
a: '1',
|
|
32
|
+
c: '1',
|
|
33
|
+
// -67254 mod p
|
|
34
|
+
d: new BN('e1f8feffffffffffffffffffffffffffffffffffffffffffffffffff' +
|
|
35
|
+
'ffffffffffffffffffffffffffffffffffffff3f', 16, 'le'),
|
|
36
|
+
g: [
|
|
37
|
+
new BN('0396f77094ccc0eb985310e8bc7d519311846453b8ba232935640b2b0' +
|
|
38
|
+
'340f868ae208d6ee95bf0e59103b2ead08d6f19', 16, 'le'),
|
|
39
|
+
new BN('11', 16, 'le'),
|
|
40
|
+
],
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
var point = [
|
|
44
|
+
'21fd21b36cbdbe0d77ad8692c25d918774f5d3bc179c4cb0ae3c364bf1bea981d0' +
|
|
45
|
+
'2e9f97cc62f20acacf0c553887e5fb',
|
|
46
|
+
'29f994329799dba72aa12ceb06312300167b6e18fbed607c63709826c57292cf29' +
|
|
47
|
+
'f5bab4f5c99c739cf107a3833bb553',
|
|
48
|
+
];
|
|
49
|
+
|
|
50
|
+
var double = [
|
|
51
|
+
'0561c8722cf82b2f0d7c36bc72e34539dcbf181e8d98f5244480e79f5b51a4a541' +
|
|
52
|
+
'457016c9c0509d49078eb5909a1121',
|
|
53
|
+
'05b7812fae9d164ee9249c56a16e29a1ad2cdc6353227074dd96d59df363a0bcb5' +
|
|
54
|
+
'bc67d50b44843ea833156bdc0ac6a2',
|
|
55
|
+
];
|
|
56
|
+
|
|
57
|
+
var p = curve.pointFromJSON(point);
|
|
58
|
+
var d = curve.pointFromJSON(double);
|
|
59
|
+
assert(p.dbl().eq(d));
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
it('should be able to find a point given y coordinate for all edwards curves',
|
|
63
|
+
function() {
|
|
64
|
+
var curve = new elliptic.curve.edwards({
|
|
65
|
+
p: new BN('f7' +
|
|
66
|
+
'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff07',
|
|
67
|
+
16, 'le'),
|
|
68
|
+
q: new BN('71' +
|
|
69
|
+
'c966d15fd444893407d3dfc46579f7ffffffffffffffffffffffffffffff01',
|
|
70
|
+
16, 'le'),
|
|
71
|
+
r: '4',
|
|
72
|
+
a: '1',
|
|
73
|
+
// -1174 mod p
|
|
74
|
+
d: new BN('61' +
|
|
75
|
+
'fbffffffffffffffffffffffffffffffffffffffffffffffffffffffffff07',
|
|
76
|
+
16, 'le'),
|
|
77
|
+
c: '1',
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
var target = curve.point(
|
|
81
|
+
'05d040ddaa645bf27d2d2f302c5697231425185fd9a410f220ac5c5c7fbeb8a1',
|
|
82
|
+
'02f8ca771306cd23e929775177f2c213843a017a6487b2ec5f9b2a3808108ef2',
|
|
83
|
+
);
|
|
84
|
+
|
|
85
|
+
var point = curve.pointFromY('02' +
|
|
86
|
+
'f8ca771306cd23e929775177f2c213843a017a6487b2ec5f9b2a3808108ef2');
|
|
87
|
+
assert(point.eq(target));
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
it('should find an odd point given a y coordinate', function() {
|
|
91
|
+
var curve = new elliptic.curve.edwards({
|
|
92
|
+
p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',
|
|
93
|
+
a: '-1',
|
|
94
|
+
c: '1',
|
|
95
|
+
// -121665 * (121666^(-1)) (mod P)
|
|
96
|
+
d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',
|
|
97
|
+
n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',
|
|
98
|
+
gRed: false,
|
|
99
|
+
g: [
|
|
100
|
+
'216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',
|
|
101
|
+
|
|
102
|
+
// 4/5
|
|
103
|
+
'6666666666666666666666666666666666666666666666666666666666666658',
|
|
104
|
+
],
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
var bytes = new Uint8Array([ 5, 69, 248, 173, 171, 254, 19, 253, 143, 140, 146, 174, 26, 128, 3, 52, 106, 55, 112, 245, 62, 127, 42, 93, 0, 81, 47, 177, 30, 25, 39, 70 ]);
|
|
108
|
+
var y = new BN(bytes, 16, 'le');
|
|
109
|
+
var point = curve.pointFromY(y, true);
|
|
110
|
+
var target = '2cd591ae3789fd62dc420a152002f79973a387eacecadc6a9a00c1a89488c15d';
|
|
111
|
+
assert.deepStrictEqual(point.getX().toString(16), target);
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
it('should work with secp112k1', function() {
|
|
115
|
+
var curve = new elliptic.curve.short({
|
|
116
|
+
p: 'db7c 2abf62e3 5e668076 bead208b',
|
|
117
|
+
a: 'db7c 2abf62e3 5e668076 bead2088',
|
|
118
|
+
b: '659e f8ba0439 16eede89 11702b22',
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
var p = curve.point(
|
|
122
|
+
'0948 7239995a 5ee76b55 f9c2f098',
|
|
123
|
+
'a89c e5af8724 c0a23e0e 0ff77500');
|
|
124
|
+
assert(p.validate());
|
|
125
|
+
assert(p.dbl().validate());
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it('should work with secp256k1', function() {
|
|
129
|
+
var curve = new elliptic.curve.short({
|
|
130
|
+
p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ' +
|
|
131
|
+
'fffffc2f',
|
|
132
|
+
a: '0',
|
|
133
|
+
b: '7',
|
|
134
|
+
n: 'ffffffff ffffffff ffffffff fffffffe ' +
|
|
135
|
+
'baaedce6 af48a03b bfd25e8c d0364141',
|
|
136
|
+
g: [
|
|
137
|
+
'79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',
|
|
138
|
+
'483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',
|
|
139
|
+
],
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
var p = curve.point(
|
|
143
|
+
'79be667e f9dcbbac 55a06295 ce870b07 029bfcdb 2dce28d9 59f2815b 16f81798',
|
|
144
|
+
'483ada77 26a3c465 5da4fbfc 0e1108a8 fd17b448 a6855419 9c47d08f fb10d4b8',
|
|
145
|
+
);
|
|
146
|
+
assert(p.validate());
|
|
147
|
+
assert(p.dbl().validate());
|
|
148
|
+
assert(p.toJ().dbl().toP().validate());
|
|
149
|
+
assert(p.mul(new BN('79be667e f9dcbbac 55a06295 ce870b07', 16)).validate());
|
|
150
|
+
|
|
151
|
+
var j = p.toJ();
|
|
152
|
+
assert(j.trpl().eq(j.dbl().add(j)));
|
|
153
|
+
|
|
154
|
+
// Endomorphism test
|
|
155
|
+
assert(curve.endo);
|
|
156
|
+
assert.equal(
|
|
157
|
+
curve.endo.beta.fromRed().toString(16),
|
|
158
|
+
'7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee');
|
|
159
|
+
assert.equal(
|
|
160
|
+
curve.endo.lambda.toString(16),
|
|
161
|
+
'5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72');
|
|
162
|
+
|
|
163
|
+
var k = new BN('1234567890123456789012345678901234', 16);
|
|
164
|
+
var split = curve._endoSplit(k);
|
|
165
|
+
|
|
166
|
+
var testK = split.k1.add(split.k2.mul(curve.endo.lambda)).umod(curve.n);
|
|
167
|
+
assert.equal(testK.toString(16), k.toString(16));
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
it('should compute this problematic secp256k1 multiplication', function() {
|
|
171
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
172
|
+
var g1 = curve.g; // precomputed g
|
|
173
|
+
assert(g1.precomputed);
|
|
174
|
+
var g2 = curve.point(g1.getX(), g1.getY()); // not precomputed g
|
|
175
|
+
assert(!g2.precomputed);
|
|
176
|
+
var a = new BN(
|
|
177
|
+
'6d1229a6b24c2e775c062870ad26bc261051e0198c67203167273c7c62538846', 16);
|
|
178
|
+
var p1 = g1.mul(a);
|
|
179
|
+
var p2 = g2.mul(a);
|
|
180
|
+
assert(p1.eq(p2));
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
it('should not use fixed NAF when k is too large', function() {
|
|
184
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
185
|
+
var g1 = curve.g; // precomputed g
|
|
186
|
+
assert(g1.precomputed);
|
|
187
|
+
var g2 = curve.point(g1.getX(), g1.getY()); // not precomputed g
|
|
188
|
+
assert(!g2.precomputed);
|
|
189
|
+
|
|
190
|
+
var a = new BN(
|
|
191
|
+
'6d1229a6b24c2e775c062870ad26bc26' +
|
|
192
|
+
'1051e0198c67203167273c7c6253884612345678',
|
|
193
|
+
16);
|
|
194
|
+
var p1 = g1.mul(a);
|
|
195
|
+
var p2 = g2.mul(a);
|
|
196
|
+
assert(p1.eq(p2));
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
it('should not fail on secp256k1 regression', function() {
|
|
200
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
201
|
+
var k1 = new BN(
|
|
202
|
+
'32efeba414cd0c830aed727749e816a01c471831536fd2fce28c56b54f5a3bb1', 16);
|
|
203
|
+
var k2 = new BN(
|
|
204
|
+
'5f2e49b5d64e53f9811545434706cde4de528af97bfd49fde1f6cf792ee37a8c', 16);
|
|
205
|
+
|
|
206
|
+
var p1 = curve.g.mul(k1);
|
|
207
|
+
var p2 = curve.g.mul(k2);
|
|
208
|
+
|
|
209
|
+
// 2 + 2 + 1 = 2 + 1 + 2
|
|
210
|
+
var two = p2.dbl();
|
|
211
|
+
var five = two.dbl().add(p2);
|
|
212
|
+
var three = two.add(p2);
|
|
213
|
+
var maybeFive = three.add(two);
|
|
214
|
+
|
|
215
|
+
assert(maybeFive.eq(five));
|
|
216
|
+
|
|
217
|
+
p1 = p1.mul(k2);
|
|
218
|
+
p2 = p2.mul(k1);
|
|
219
|
+
|
|
220
|
+
assert(p1.validate());
|
|
221
|
+
assert(p2.validate());
|
|
222
|
+
assert(p1.eq(p2));
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
it('should correctly double the affine point on secp256k1', function() {
|
|
226
|
+
var bad = {
|
|
227
|
+
x: '026a2073b1ef6fab47ace18e60e728a05180a82755bbcec9a0abc08ad9f7a3d4',
|
|
228
|
+
y: '9cd8cb48c3281596139f147c1364a3ede88d3f310fdb0eb98c924e599ca1b3c9',
|
|
229
|
+
z: 'd78587ad45e4102f48b54b5d85598296e069ce6085002e169c6bad78ddc6d9bd',
|
|
230
|
+
};
|
|
231
|
+
|
|
232
|
+
var good = {
|
|
233
|
+
x: 'e7789226739ac2eb3c7ccb2a9a910066beeed86cdb4e0f8a7fee8eeb29dc7016',
|
|
234
|
+
y: '4b76b191fd6d47d07828ea965e275b76d0e3e0196cd5056d38384fbb819f9fcb',
|
|
235
|
+
z: 'cbf8d99056618ba132d6145b904eee1ce566e0feedb9595139c45f84e90cfa7d',
|
|
236
|
+
};
|
|
237
|
+
|
|
238
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
239
|
+
bad = curve.jpoint(bad.x, bad.y, bad.z);
|
|
240
|
+
good = curve.jpoint(good.x, good.y, good.z);
|
|
241
|
+
|
|
242
|
+
// They are the same points
|
|
243
|
+
assert(bad.add(good.neg()).isInfinity());
|
|
244
|
+
|
|
245
|
+
// But doubling borks them out
|
|
246
|
+
assert(bad.dbl().add(good.dbl().neg()).isInfinity());
|
|
247
|
+
});
|
|
248
|
+
|
|
249
|
+
it('should store precomputed values correctly on negation', function() {
|
|
250
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
251
|
+
var p = curve.g.mul('2');
|
|
252
|
+
p.precompute();
|
|
253
|
+
var neg = p.neg(true);
|
|
254
|
+
var neg2 = neg.neg(true);
|
|
255
|
+
assert(p.eq(neg2));
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
it('should correctly handle scalar multiplication of zero', function() {
|
|
259
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
260
|
+
var p1 = curve.g.mul('0');
|
|
261
|
+
var p2 = p1.mul('2');
|
|
262
|
+
assert(p1.eq(p2));
|
|
263
|
+
});
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
describe('Point codec', function () {
|
|
267
|
+
function makeShortTest(definition) {
|
|
268
|
+
var curve = elliptic.curves.secp256k1.curve;
|
|
269
|
+
|
|
270
|
+
return function() {
|
|
271
|
+
var co = definition.coordinates;
|
|
272
|
+
var p = curve.point(co.x, co.y);
|
|
273
|
+
|
|
274
|
+
// Encodes as expected
|
|
275
|
+
assert.equal(p.encode('hex'), definition.encoded);
|
|
276
|
+
assert.equal(p.encodeCompressed('hex'), definition.compactEncoded);
|
|
277
|
+
|
|
278
|
+
// Decodes as expected
|
|
279
|
+
assert(curve.decodePoint(definition.encoded, 'hex').eq(p));
|
|
280
|
+
assert(curve.decodePoint(definition.compactEncoded, 'hex').eq(p));
|
|
281
|
+
assert(curve.decodePoint(definition.hybrid, 'hex').eq(p));
|
|
282
|
+
};
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
function makeMontTest(definition) {
|
|
286
|
+
var curve = elliptic.curves.curve25519.curve;
|
|
287
|
+
|
|
288
|
+
return function() {
|
|
289
|
+
var co = definition.coordinates;
|
|
290
|
+
var p = curve.point(co.x, co.z);
|
|
291
|
+
var encoded = p.encode('hex');
|
|
292
|
+
var decoded = curve.decodePoint(encoded, 'hex');
|
|
293
|
+
assert(decoded.eq(p));
|
|
294
|
+
assert.equal(encoded, definition.encoded);
|
|
295
|
+
};
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
var shortPointEvenY = {
|
|
299
|
+
coordinates: {
|
|
300
|
+
x: '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',
|
|
301
|
+
y: '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',
|
|
302
|
+
},
|
|
303
|
+
compactEncoded:
|
|
304
|
+
'02' +
|
|
305
|
+
'79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',
|
|
306
|
+
encoded:
|
|
307
|
+
'04' +
|
|
308
|
+
'79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798' +
|
|
309
|
+
'483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',
|
|
310
|
+
hybrid:
|
|
311
|
+
'06' +
|
|
312
|
+
'79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798' +
|
|
313
|
+
'483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',
|
|
314
|
+
};
|
|
315
|
+
|
|
316
|
+
var shortPointOddY = {
|
|
317
|
+
coordinates: {
|
|
318
|
+
x: 'fff97bd5755eeea420453a14355235d382f6472f8568a18b2f057a1460297556',
|
|
319
|
+
y: 'ae12777aacfbb620f3be96017f45c560de80f0f6518fe4a03c870c36b075f297',
|
|
320
|
+
},
|
|
321
|
+
compactEncoded:
|
|
322
|
+
'03' +
|
|
323
|
+
'fff97bd5755eeea420453a14355235d382f6472f8568a18b2f057a1460297556',
|
|
324
|
+
encoded:
|
|
325
|
+
'04' +
|
|
326
|
+
'fff97bd5755eeea420453a14355235d382f6472f8568a18b2f057a1460297556' +
|
|
327
|
+
'ae12777aacfbb620f3be96017f45c560de80f0f6518fe4a03c870c36b075f297',
|
|
328
|
+
hybrid:
|
|
329
|
+
'07' +
|
|
330
|
+
'fff97bd5755eeea420453a14355235d382f6472f8568a18b2f057a1460297556' +
|
|
331
|
+
'ae12777aacfbb620f3be96017f45c560de80f0f6518fe4a03c870c36b075f297',
|
|
332
|
+
};
|
|
333
|
+
|
|
334
|
+
it('should throw when trying to decode random bytes', function() {
|
|
335
|
+
assert.throws(function() {
|
|
336
|
+
elliptic.curves.secp256k1.curve.decodePoint(
|
|
337
|
+
'05' +
|
|
338
|
+
'79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798');
|
|
339
|
+
});
|
|
340
|
+
});
|
|
341
|
+
|
|
342
|
+
it('should be able to encode/decode a short curve point with even Y',
|
|
343
|
+
makeShortTest(shortPointEvenY));
|
|
344
|
+
|
|
345
|
+
it('should be able to encode/decode a short curve point with odd Y',
|
|
346
|
+
makeShortTest(shortPointOddY));
|
|
347
|
+
|
|
348
|
+
it('should be able to encode/decode a mont curve point', makeMontTest({
|
|
349
|
+
coordinates: {
|
|
350
|
+
// curve25519.curve.g.mul(new BN('6')).getX().toString(16, 2)
|
|
351
|
+
x: '26954ccdc99ebf34f8f1dde5e6bb080685fec73640494c28f9fe0bfa8c794531',
|
|
352
|
+
z: '1',
|
|
353
|
+
},
|
|
354
|
+
encoded:
|
|
355
|
+
'26954ccdc99ebf34f8f1dde5e6bb080685fec73640494c28f9fe0bfa8c794531',
|
|
356
|
+
}));
|
|
357
|
+
});
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/* eslint-env node, mocha */
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
var assert = require('assert');
|
|
5
|
+
var elliptic = require('../');
|
|
6
|
+
|
|
7
|
+
describe('ECDH', function() {
|
|
8
|
+
function test(name) {
|
|
9
|
+
it('should work with ' + name + ' curve', function() {
|
|
10
|
+
var ecdh = new elliptic.ec(name);
|
|
11
|
+
var s1 = ecdh.genKeyPair();
|
|
12
|
+
var s2 = ecdh.genKeyPair();
|
|
13
|
+
var sh1 = s1.derive(s2.getPublic());
|
|
14
|
+
var sh2 = s2.derive(s1.getPublic());
|
|
15
|
+
|
|
16
|
+
assert.equal(sh1.toString(16), sh2.toString(16));
|
|
17
|
+
|
|
18
|
+
sh1 = s1.derive(ecdh.keyFromPublic(s2.getPublic('hex'), 'hex')
|
|
19
|
+
.getPublic());
|
|
20
|
+
sh2 = s2.derive(ecdh.keyFromPublic(s1.getPublic('hex'), 'hex')
|
|
21
|
+
.getPublic());
|
|
22
|
+
assert.equal(sh1.toString(16), sh2.toString(16));
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
test('curve25519');
|
|
27
|
+
test('ed25519');
|
|
28
|
+
test('secp256k1');
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
describe('ECDH twist attack', () => {
|
|
32
|
+
it('should be able to prevent a twist attack for secp256k1', () => {
|
|
33
|
+
var bobEcdh = new elliptic.ec('secp256k1');
|
|
34
|
+
var malloryEcdh = new elliptic.ec('secp256k1');
|
|
35
|
+
var bob = bobEcdh.genKeyPair();
|
|
36
|
+
// This is a bad point that shouldn't be able to be passed to derive.
|
|
37
|
+
// If a bad point can be passed it's possible to perform a twist attack.
|
|
38
|
+
var mallory = malloryEcdh.keyFromPublic({ x: 14, y: 16 });
|
|
39
|
+
assert.throws(function () {
|
|
40
|
+
bob.derive(mallory.getPublic());
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
});
|