fsevents 1.0.5 → 1.0.6
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.
Potentially problematic release.
This version of fsevents might be problematic. Click here for more details.
- package/Readme.md +12 -13
- package/node_modules/ansi/package.json +1 -2
- package/node_modules/are-we-there-yet/package.json +1 -2
- package/node_modules/asn1/.travis.yml +4 -0
- package/node_modules/asn1/lib/ber/reader.js +27 -33
- package/node_modules/asn1/lib/ber/writer.js +10 -11
- package/node_modules/asn1/package.json +21 -19
- package/node_modules/asn1/tst/ber/reader.test.js +36 -0
- package/node_modules/asn1/tst/ber/writer.test.js +74 -0
- package/node_modules/assert-plus/package.json +1 -0
- package/node_modules/{ctype → bl/node_modules/readable-stream/node_modules/core-util-is}/LICENSE +1 -6
- package/node_modules/bl/node_modules/readable-stream/node_modules/core-util-is/lib/util.js +11 -11
- package/node_modules/bl/node_modules/readable-stream/node_modules/core-util-is/package.json +17 -12
- package/node_modules/bl/node_modules/readable-stream/node_modules/core-util-is/test.js +68 -0
- package/node_modules/boom/package.json +1 -1
- package/node_modules/commander/package.json +1 -1
- package/node_modules/core-util-is/LICENSE +19 -0
- package/node_modules/core-util-is/lib/util.js +11 -11
- package/node_modules/core-util-is/package.json +17 -12
- package/node_modules/core-util-is/test.js +68 -0
- package/node_modules/dashdash/README.md +508 -0
- package/node_modules/dashdash/lib/dashdash.js +813 -0
- package/node_modules/dashdash/package.json +87 -0
- package/node_modules/deep-extend/LICENSE +1 -1
- package/node_modules/deep-extend/README.md +89 -52
- package/node_modules/deep-extend/index.js +1 -90
- package/node_modules/deep-extend/lib/deep-extend.js +144 -0
- package/node_modules/deep-extend/package.json +47 -16
- package/node_modules/deep-extend/test/index.spec.js +168 -5
- package/node_modules/delegates/package.json +1 -2
- package/node_modules/ecc-jsbn/.npmignore +15 -0
- package/node_modules/ecc-jsbn/LICENSE +21 -0
- package/node_modules/ecc-jsbn/README.md +8 -0
- package/node_modules/ecc-jsbn/index.js +57 -0
- package/node_modules/ecc-jsbn/lib/LICENSE-jsbn +40 -0
- package/node_modules/ecc-jsbn/lib/ec.js +561 -0
- package/node_modules/ecc-jsbn/lib/sec.js +170 -0
- package/node_modules/ecc-jsbn/package.json +63 -0
- package/node_modules/ecc-jsbn/test.js +14 -0
- package/node_modules/extsprintf/.gitmodules +6 -0
- package/node_modules/{path-is-absolute/license → extsprintf/LICENSE} +2 -4
- package/node_modules/extsprintf/Makefile +23 -0
- package/node_modules/extsprintf/Makefile.deps +39 -0
- package/node_modules/extsprintf/Makefile.targ +285 -0
- package/node_modules/extsprintf/README.md +39 -0
- package/node_modules/extsprintf/examples/simple.js +2 -0
- package/node_modules/{ctype/tools/jsl.conf → extsprintf/jsl.node.conf} +71 -63
- package/node_modules/extsprintf/lib/extsprintf.js +166 -0
- package/node_modules/extsprintf/package.json +48 -0
- package/node_modules/fstream/package.json +1 -2
- package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/package.json +4 -22
- package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/package.json +3 -21
- package/node_modules/{brace-expansion → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion}/package.json +4 -23
- package/node_modules/fstream-ignore/node_modules/minimatch/package.json +4 -24
- package/node_modules/fstream-ignore/package.json +1 -2
- package/node_modules/gauge/package.json +1 -2
- package/node_modules/har-validator/package.json +15 -15
- package/node_modules/has-unicode/package.json +1 -2
- package/node_modules/hawk/dist/client.js +340 -0
- package/node_modules/hawk/lib/browser.js +14 -20
- package/node_modules/hawk/package.json +10 -10
- package/node_modules/hawk/test/browser.js +134 -101
- package/node_modules/hawk/test/index.js +61 -61
- package/node_modules/hawk/test/server.js +72 -84
- package/node_modules/hawk/test/uri.js +52 -63
- package/node_modules/http-signature/CHANGES.md +39 -0
- package/node_modules/http-signature/http_signing.md +16 -17
- package/node_modules/http-signature/lib/index.js +6 -4
- package/node_modules/http-signature/lib/parser.js +43 -29
- package/node_modules/http-signature/lib/signer.js +290 -74
- package/node_modules/http-signature/lib/utils.js +112 -0
- package/node_modules/http-signature/lib/verify.js +47 -15
- package/node_modules/http-signature/package.json +20 -14
- package/node_modules/is-my-json-valid/index.js +16 -14
- package/node_modules/is-my-json-valid/package.json +16 -12
- package/node_modules/is-typedarray/LICENSE.md +18 -0
- package/node_modules/is-typedarray/README.md +16 -0
- package/node_modules/is-typedarray/index.js +41 -0
- package/node_modules/is-typedarray/package.json +63 -0
- package/node_modules/is-typedarray/test.js +34 -0
- package/node_modules/jodid25519/.npmignore +11 -0
- package/node_modules/jodid25519/.travis.yml +7 -0
- package/node_modules/jodid25519/AUTHORS.md +3 -0
- package/node_modules/jodid25519/LICENSE +23 -0
- package/node_modules/jodid25519/README.md +51 -0
- package/node_modules/jodid25519/almond.0 +42 -0
- package/node_modules/jodid25519/almond.1 +13 -0
- package/node_modules/jodid25519/index.js +35 -0
- package/node_modules/jodid25519/jsdoc.json +19 -0
- package/node_modules/jodid25519/lib/core.js +481 -0
- package/node_modules/jodid25519/lib/curve255.js +221 -0
- package/node_modules/jodid25519/lib/dh.js +111 -0
- package/node_modules/jodid25519/lib/eddsa.js +573 -0
- package/node_modules/jodid25519/lib/utils.js +198 -0
- package/node_modules/jodid25519/package.json +77 -0
- package/node_modules/jsbn/.npmignore +2 -0
- package/node_modules/jsbn/LICENSE +40 -0
- package/node_modules/jsbn/README.md +175 -0
- package/node_modules/jsbn/example.html +12 -0
- package/node_modules/jsbn/example.js +3 -0
- package/node_modules/jsbn/index.js +1358 -0
- package/node_modules/jsbn/package.json +60 -0
- package/node_modules/json-schema/README.md +5 -0
- package/node_modules/json-schema/draft-00/hyper-schema +68 -0
- package/node_modules/json-schema/draft-00/json-ref +26 -0
- package/node_modules/json-schema/draft-00/links +33 -0
- package/node_modules/json-schema/draft-00/schema +155 -0
- package/node_modules/json-schema/draft-01/hyper-schema +68 -0
- package/node_modules/json-schema/draft-01/json-ref +26 -0
- package/node_modules/json-schema/draft-01/links +33 -0
- package/node_modules/json-schema/draft-01/schema +155 -0
- package/node_modules/json-schema/draft-02/hyper-schema +68 -0
- package/node_modules/json-schema/draft-02/json-ref +26 -0
- package/node_modules/json-schema/draft-02/links +35 -0
- package/node_modules/json-schema/draft-02/schema +166 -0
- package/node_modules/json-schema/draft-03/examples/address +20 -0
- package/node_modules/json-schema/draft-03/examples/calendar +53 -0
- package/node_modules/json-schema/draft-03/examples/card +105 -0
- package/node_modules/json-schema/draft-03/examples/geo +8 -0
- package/node_modules/json-schema/draft-03/examples/interfaces +23 -0
- package/node_modules/json-schema/draft-03/hyper-schema +60 -0
- package/node_modules/json-schema/draft-03/json-ref +26 -0
- package/node_modules/json-schema/draft-03/links +35 -0
- package/node_modules/json-schema/draft-03/schema +174 -0
- package/node_modules/json-schema/draft-04/hyper-schema +60 -0
- package/node_modules/json-schema/draft-04/links +41 -0
- package/node_modules/json-schema/draft-04/schema +189 -0
- package/node_modules/json-schema/draft-zyp-json-schema-03.xml +1120 -0
- package/node_modules/json-schema/draft-zyp-json-schema-04.xml +1072 -0
- package/node_modules/json-schema/lib/links.js +52 -0
- package/node_modules/json-schema/lib/validate.js +260 -0
- package/node_modules/json-schema/package.json +67 -0
- package/node_modules/json-schema/test/tests.js +95 -0
- package/node_modules/jsprim/CHANGES.md +30 -0
- package/node_modules/jsprim/LICENSE +19 -0
- package/node_modules/jsprim/README.md +228 -0
- package/node_modules/jsprim/lib/jsprim.js +478 -0
- package/node_modules/jsprim/package.json +54 -0
- package/node_modules/lodash._basetostring/package.json +1 -2
- package/node_modules/lodash._createpadding/package.json +1 -2
- package/node_modules/lodash.pad/package.json +1 -2
- package/node_modules/lodash.padleft/package.json +1 -2
- package/node_modules/lodash.padright/package.json +1 -2
- package/node_modules/lodash.repeat/package.json +1 -2
- package/node_modules/node-pre-gyp/CHANGELOG.md +8 -0
- package/node_modules/node-pre-gyp/README.md +570 -0
- package/node_modules/node-pre-gyp/lib/util/abi_crosswalk.json +4 -0
- package/node_modules/node-pre-gyp/node_modules/nopt/lib/nopt.js +2 -1
- package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/package.json +30 -37
- package/node_modules/node-pre-gyp/node_modules/nopt/package.json +37 -57
- package/node_modules/node-pre-gyp/node_modules/nopt/test/basic.js +22 -0
- package/node_modules/node-pre-gyp/package.json +17 -17
- package/node_modules/node-uuid/.npmignore +2 -0
- package/node_modules/node-uuid/README.md +12 -1
- package/node_modules/node-uuid/bower.json +1 -1
- package/node_modules/node-uuid/component.json +11 -4
- package/node_modules/node-uuid/package.json +25 -12
- package/node_modules/node-uuid/test/test.js +3 -0
- package/node_modules/node-uuid/uuid.js +70 -45
- package/node_modules/npmlog/.travis.yml +14 -0
- package/node_modules/npmlog/log.js +3 -0
- package/node_modules/npmlog/package.json +23 -20
- package/node_modules/npmlog/test/basic.js +8 -1
- package/node_modules/once/package.json +2 -3
- package/node_modules/pinkie/index.js +23 -7
- package/node_modules/pinkie/package.json +22 -15
- package/node_modules/pinkie/readme.md +17 -9
- package/node_modules/pinkie-promise/package.json +16 -14
- package/node_modules/pinkie-promise/readme.md +5 -3
- package/node_modules/rc/README.md +1 -1
- package/node_modules/rc/index.js +1 -1
- package/node_modules/rc/node_modules/minimist/package.json +1 -1
- package/node_modules/rc/package.json +12 -12
- package/node_modules/request/.eslintrc +1 -1
- package/node_modules/request/.travis.yml +4 -4
- package/node_modules/request/CHANGELOG.md +25 -0
- package/node_modules/request/README.md +12 -13
- package/node_modules/request/lib/har.js +84 -75
- package/node_modules/request/lib/redirect.js +2 -3
- package/node_modules/request/lib/tunnel.js +13 -18
- package/node_modules/request/package.json +17 -16
- package/node_modules/request/request.js +16 -59
- package/node_modules/rimraf/README.md +7 -2
- package/node_modules/{wrappy → rimraf/node_modules/glob/node_modules/inflight/node_modules/wrappy}/package.json +5 -25
- package/node_modules/{inflight → rimraf/node_modules/glob/node_modules/inflight}/package.json +5 -25
- package/node_modules/rimraf/node_modules/glob/node_modules/inherits/LICENSE +16 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/inherits/README.md +42 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/inherits/inherits.js +1 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/inherits/inherits_browser.js +23 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/inherits/package.json +58 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/inherits/test.js +25 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/.npmignore +3 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/README.md +122 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/example.js +8 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/index.js +191 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/.npmignore +2 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/.travis.yml +3 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/LICENSE.md +21 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/Makefile +6 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/README.md +80 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/example.js +5 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/index.js +38 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/package.json +79 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match/test/balanced.js +56 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/.travis.yml +4 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/LICENSE +18 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/README.markdown +62 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/example/map.js +6 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/index.js +13 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/package.json +90 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map/test/map.js +39 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/minimatch/node_modules/brace-expansion/package.json +81 -0
- package/node_modules/rimraf/node_modules/{minimatch → glob/node_modules/minimatch}/package.json +3 -21
- package/node_modules/rimraf/node_modules/glob/node_modules/once/node_modules/wrappy/README.md +36 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/once/node_modules/wrappy/package.json +58 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/once/node_modules/wrappy/test/basic.js +51 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/once/node_modules/wrappy/wrappy.js +33 -0
- package/node_modules/rimraf/node_modules/glob/node_modules/once/package.json +70 -0
- package/node_modules/{path-is-absolute → rimraf/node_modules/glob/node_modules/path-is-absolute}/package.json +4 -22
- package/node_modules/rimraf/node_modules/glob/package.json +2 -20
- package/node_modules/rimraf/package.json +10 -10
- package/node_modules/semver/README.md +25 -1
- package/node_modules/semver/package.json +10 -10
- package/node_modules/semver/range.bnf +16 -0
- package/node_modules/semver/semver.js +0 -12
- package/node_modules/sshpk/.npmignore +8 -0
- package/node_modules/sshpk/.travis.yml +11 -0
- package/node_modules/sshpk/LICENSE +18 -0
- package/node_modules/sshpk/README.md +436 -0
- package/node_modules/sshpk/bin/sshpk-conv +183 -0
- package/node_modules/sshpk/lib/algs.js +168 -0
- package/node_modules/sshpk/lib/dhe.js +312 -0
- package/node_modules/sshpk/lib/ed-compat.js +94 -0
- package/node_modules/sshpk/lib/errors.js +58 -0
- package/node_modules/sshpk/lib/fingerprint.js +140 -0
- package/node_modules/sshpk/lib/formats/auto.js +73 -0
- package/node_modules/sshpk/lib/formats/pem.js +152 -0
- package/node_modules/sshpk/lib/formats/pkcs1.js +320 -0
- package/node_modules/sshpk/lib/formats/pkcs8.js +510 -0
- package/node_modules/sshpk/lib/formats/rfc4253.js +145 -0
- package/node_modules/sshpk/lib/formats/ssh-private.js +138 -0
- package/node_modules/sshpk/lib/formats/ssh.js +114 -0
- package/node_modules/sshpk/lib/index.js +25 -0
- package/node_modules/sshpk/lib/key.js +260 -0
- package/node_modules/sshpk/lib/private-key.js +224 -0
- package/node_modules/sshpk/lib/signature.js +237 -0
- package/node_modules/sshpk/lib/ssh-buffer.js +123 -0
- package/node_modules/sshpk/lib/utils.js +207 -0
- package/node_modules/sshpk/node_modules/assert-plus/AUTHORS +6 -0
- package/node_modules/sshpk/node_modules/assert-plus/CHANGES.md +8 -0
- package/node_modules/sshpk/node_modules/assert-plus/README.md +155 -0
- package/node_modules/sshpk/node_modules/assert-plus/assert.js +206 -0
- package/node_modules/sshpk/node_modules/assert-plus/package.json +88 -0
- package/node_modules/sshpk/package.json +92 -0
- package/node_modules/strip-json-comments/cli.js +2 -2
- package/node_modules/strip-json-comments/package.json +13 -12
- package/node_modules/strip-json-comments/readme.md +11 -5
- package/node_modules/strip-json-comments/strip-json-comments.js +16 -7
- package/node_modules/tar/package.json +1 -2
- package/node_modules/tar-pack/node_modules/readable-stream/node_modules/core-util-is/LICENSE +19 -0
- package/node_modules/tar-pack/node_modules/readable-stream/node_modules/core-util-is/lib/util.js +11 -11
- package/node_modules/tar-pack/node_modules/readable-stream/node_modules/core-util-is/package.json +17 -12
- package/node_modules/tar-pack/node_modules/readable-stream/node_modules/core-util-is/test.js +68 -0
- package/node_modules/tar-pack/node_modules/readable-stream/node_modules/inherits/package.json +1 -1
- package/node_modules/tar-pack/node_modules/rimraf/package.json +1 -2
- package/node_modules/tar-pack/package.json +1 -2
- package/node_modules/tough-cookie/lib/cookie.js +1 -1
- package/node_modules/tough-cookie/package.json +7 -7
- package/node_modules/tweetnacl/.npmignore +4 -0
- package/node_modules/tweetnacl/CHANGELOG.md +128 -0
- package/node_modules/tweetnacl/README.md +463 -0
- package/node_modules/tweetnacl/nacl-fast.js +2418 -0
- package/node_modules/tweetnacl/nacl-fast.min.js +2 -0
- package/node_modules/tweetnacl/nacl.js +1205 -0
- package/node_modules/tweetnacl/nacl.min.js +1 -0
- package/node_modules/tweetnacl/package.json +101 -0
- package/node_modules/uid-number/package.json +2 -3
- package/node_modules/verror/.gitmodules +0 -0
- package/node_modules/verror/LICENSE +19 -0
- package/node_modules/verror/Makefile +35 -0
- package/node_modules/verror/Makefile.targ +285 -0
- package/node_modules/verror/README.md +120 -0
- package/node_modules/verror/examples/levels-verror.js +36 -0
- package/node_modules/verror/examples/levels-werror.js +34 -0
- package/node_modules/verror/examples/varargs.js +6 -0
- package/node_modules/verror/examples/verror.js +13 -0
- package/node_modules/verror/examples/werror.js +14 -0
- package/node_modules/verror/jsl.node.conf +139 -0
- package/node_modules/verror/lib/verror.js +157 -0
- package/node_modules/verror/package.json +51 -0
- package/node_modules/verror/tests/tst.inherit.js +100 -0
- package/node_modules/verror/tests/tst.verror.js +156 -0
- package/node_modules/verror/tests/tst.werror.js +179 -0
- package/package.json +3 -3
- package/node_modules/bl/node_modules/readable-stream/node_modules/core-util-is/util.js +0 -106
- package/node_modules/core-util-is/util.js +0 -106
- package/node_modules/ctype/.npmignore +0 -1
- package/node_modules/ctype/CHANGELOG +0 -78
- package/node_modules/ctype/README +0 -82
- package/node_modules/ctype/README.old +0 -298
- package/node_modules/ctype/ctf.js +0 -245
- package/node_modules/ctype/ctio.js +0 -1485
- package/node_modules/ctype/ctype.js +0 -944
- package/node_modules/ctype/man/man3ctype/ctio.3ctype +0 -241
- package/node_modules/ctype/package.json +0 -51
- package/node_modules/ctype/tools/jsstyle +0 -839
- package/node_modules/http-signature/lib/util.js +0 -306
- package/node_modules/inflight/node_modules/once/package.json +0 -86
- package/node_modules/inflight/node_modules/once/test/once.js +0 -23
- package/node_modules/rimraf/node_modules/glob/LICENSE +0 -15
- package/node_modules/rimraf/node_modules/minimatch/LICENSE +0 -15
- package/node_modules/rimraf/node_modules/once/LICENSE +0 -15
- package/node_modules/rimraf/node_modules/once/README.md +0 -51
- package/node_modules/rimraf/node_modules/once/once.js +0 -21
- package/node_modules/rimraf/node_modules/once/package.json +0 -84
- package/node_modules/rimraf/node_modules/once/test/once.js +0 -23
- package/node_modules/tar-pack/node_modules/readable-stream/node_modules/core-util-is/util.js +0 -106
- package/node_modules/wrappy/LICENSE +0 -15
- /package/node_modules/{brace-expansion → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion}/.npmignore +0 -0
- /package/node_modules/{brace-expansion → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion}/README.md +0 -0
- /package/node_modules/{brace-expansion → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion}/example.js +0 -0
- /package/node_modules/{brace-expansion → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion}/index.js +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/.npmignore +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/.travis.yml +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/LICENSE.md +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/Makefile +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/README.md +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/example.js +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/index.js +0 -0
- /package/node_modules/{balanced-match → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/balanced-match}/test/balanced.js +0 -0
- /package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/.travis.yml +0 -0
- /package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/LICENSE +0 -0
- /package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/README.markdown +0 -0
- /package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/example/map.js +0 -0
- /package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/index.js +0 -0
- /package/node_modules/{concat-map → fstream-ignore/node_modules/minimatch/node_modules/brace-expansion/node_modules/concat-map}/test/map.js +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/.npmignore +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/.travis.yml +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/CONTRIBUTING.md +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/LICENSE +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/README.md +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/abbrev.js +0 -0
- /package/node_modules/{abbrev → node-pre-gyp/node_modules/nopt/node_modules/abbrev}/test.js +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob/node_modules/inflight}/.eslintrc +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob/node_modules/inflight}/LICENSE +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob/node_modules/inflight}/README.md +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob/node_modules/inflight}/inflight.js +0 -0
- /package/node_modules/{fstream-ignore/node_modules/minimatch → rimraf/node_modules/glob/node_modules/inflight/node_modules/wrappy}/LICENSE +0 -0
- /package/node_modules/{wrappy → rimraf/node_modules/glob/node_modules/inflight/node_modules/wrappy}/README.md +0 -0
- /package/node_modules/{wrappy → rimraf/node_modules/glob/node_modules/inflight/node_modules/wrappy}/test/basic.js +0 -0
- /package/node_modules/{wrappy → rimraf/node_modules/glob/node_modules/inflight/node_modules/wrappy}/wrappy.js +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob/node_modules/inflight}/test.js +0 -0
- /package/node_modules/rimraf/node_modules/{minimatch → glob/node_modules/minimatch}/README.md +0 -0
- /package/node_modules/rimraf/node_modules/{minimatch → glob/node_modules/minimatch}/minimatch.js +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob}/node_modules/once/README.md +0 -0
- /package/node_modules/{inflight/node_modules/once → rimraf/node_modules/glob/node_modules/once/node_modules/wrappy}/LICENSE +0 -0
- /package/node_modules/{inflight → rimraf/node_modules/glob}/node_modules/once/once.js +0 -0
- /package/node_modules/{path-is-absolute → rimraf/node_modules/glob/node_modules/path-is-absolute}/index.js +0 -0
- /package/node_modules/{path-is-absolute → rimraf/node_modules/glob/node_modules/path-is-absolute}/readme.md +0 -0
- /package/node_modules/{deep-extend → verror}/.npmignore +0 -0
@@ -0,0 +1,168 @@
|
|
1
|
+
// Copyright 2015 Joyent, Inc.
|
2
|
+
|
3
|
+
var algInfo = {
|
4
|
+
'dsa': {
|
5
|
+
parts: ['p', 'q', 'g', 'y'],
|
6
|
+
sizePart: 'p'
|
7
|
+
},
|
8
|
+
'rsa': {
|
9
|
+
parts: ['e', 'n'],
|
10
|
+
sizePart: 'n'
|
11
|
+
},
|
12
|
+
'ecdsa': {
|
13
|
+
parts: ['curve', 'Q'],
|
14
|
+
sizePart: 'Q'
|
15
|
+
},
|
16
|
+
'ed25519': {
|
17
|
+
parts: ['R'],
|
18
|
+
normalize: false,
|
19
|
+
sizePart: 'R'
|
20
|
+
}
|
21
|
+
};
|
22
|
+
algInfo['curve25519'] = algInfo['ed25519'];
|
23
|
+
|
24
|
+
var algPrivInfo = {
|
25
|
+
'dsa': {
|
26
|
+
parts: ['p', 'q', 'g', 'y', 'x']
|
27
|
+
},
|
28
|
+
'rsa': {
|
29
|
+
parts: ['n', 'e', 'd', 'iqmp', 'p', 'q']
|
30
|
+
},
|
31
|
+
'ecdsa': {
|
32
|
+
parts: ['curve', 'Q', 'd']
|
33
|
+
},
|
34
|
+
'ed25519': {
|
35
|
+
parts: ['R', 'r'],
|
36
|
+
normalize: false
|
37
|
+
}
|
38
|
+
};
|
39
|
+
algPrivInfo['curve25519'] = algPrivInfo['ed25519'];
|
40
|
+
|
41
|
+
var hashAlgs = {
|
42
|
+
'md5': true,
|
43
|
+
'sha1': true,
|
44
|
+
'sha256': true,
|
45
|
+
'sha384': true,
|
46
|
+
'sha512': true
|
47
|
+
};
|
48
|
+
|
49
|
+
/*
|
50
|
+
* Taken from
|
51
|
+
* http://csrc.nist.gov/groups/ST/toolkit/documents/dss/NISTReCur.pdf
|
52
|
+
*/
|
53
|
+
var curves = {
|
54
|
+
'nistp256': {
|
55
|
+
size: 256,
|
56
|
+
pkcs8oid: '1.2.840.10045.3.1.7',
|
57
|
+
p: new Buffer(('00' +
|
58
|
+
'ffffffff 00000001 00000000 00000000' +
|
59
|
+
'00000000 ffffffff ffffffff ffffffff').
|
60
|
+
replace(/ /g, ''), 'hex'),
|
61
|
+
a: new Buffer(('00' +
|
62
|
+
'FFFFFFFF 00000001 00000000 00000000' +
|
63
|
+
'00000000 FFFFFFFF FFFFFFFF FFFFFFFC').
|
64
|
+
replace(/ /g, ''), 'hex'),
|
65
|
+
b: new Buffer((
|
66
|
+
'5ac635d8 aa3a93e7 b3ebbd55 769886bc' +
|
67
|
+
'651d06b0 cc53b0f6 3bce3c3e 27d2604b').
|
68
|
+
replace(/ /g, ''), 'hex'),
|
69
|
+
s: new Buffer(('00' +
|
70
|
+
'c49d3608 86e70493 6a6678e1 139d26b7' +
|
71
|
+
'819f7e90').
|
72
|
+
replace(/ /g, ''), 'hex'),
|
73
|
+
n: new Buffer(('00' +
|
74
|
+
'ffffffff 00000000 ffffffff ffffffff' +
|
75
|
+
'bce6faad a7179e84 f3b9cac2 fc632551').
|
76
|
+
replace(/ /g, ''), 'hex'),
|
77
|
+
G: new Buffer(('04' +
|
78
|
+
'6b17d1f2 e12c4247 f8bce6e5 63a440f2' +
|
79
|
+
'77037d81 2deb33a0 f4a13945 d898c296' +
|
80
|
+
'4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16' +
|
81
|
+
'2bce3357 6b315ece cbb64068 37bf51f5').
|
82
|
+
replace(/ /g, ''), 'hex')
|
83
|
+
},
|
84
|
+
'nistp384': {
|
85
|
+
size: 384,
|
86
|
+
pkcs8oid: '1.3.132.0.34',
|
87
|
+
p: new Buffer(('00' +
|
88
|
+
'ffffffff ffffffff ffffffff ffffffff' +
|
89
|
+
'ffffffff ffffffff ffffffff fffffffe' +
|
90
|
+
'ffffffff 00000000 00000000 ffffffff').
|
91
|
+
replace(/ /g, ''), 'hex'),
|
92
|
+
a: new Buffer(('00' +
|
93
|
+
'FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF' +
|
94
|
+
'FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFE' +
|
95
|
+
'FFFFFFFF 00000000 00000000 FFFFFFFC').
|
96
|
+
replace(/ /g, ''), 'hex'),
|
97
|
+
b: new Buffer((
|
98
|
+
'b3312fa7 e23ee7e4 988e056b e3f82d19' +
|
99
|
+
'181d9c6e fe814112 0314088f 5013875a' +
|
100
|
+
'c656398d 8a2ed19d 2a85c8ed d3ec2aef').
|
101
|
+
replace(/ /g, ''), 'hex'),
|
102
|
+
s: new Buffer(('00' +
|
103
|
+
'a335926a a319a27a 1d00896a 6773a482' +
|
104
|
+
'7acdac73').
|
105
|
+
replace(/ /g, ''), 'hex'),
|
106
|
+
n: new Buffer(('00' +
|
107
|
+
'ffffffff ffffffff ffffffff ffffffff' +
|
108
|
+
'ffffffff ffffffff c7634d81 f4372ddf' +
|
109
|
+
'581a0db2 48b0a77a ecec196a ccc52973').
|
110
|
+
replace(/ /g, ''), 'hex'),
|
111
|
+
G: new Buffer(('04' +
|
112
|
+
'aa87ca22 be8b0537 8eb1c71e f320ad74' +
|
113
|
+
'6e1d3b62 8ba79b98 59f741e0 82542a38' +
|
114
|
+
'5502f25d bf55296c 3a545e38 72760ab7' +
|
115
|
+
'3617de4a 96262c6f 5d9e98bf 9292dc29' +
|
116
|
+
'f8f41dbd 289a147c e9da3113 b5f0b8c0' +
|
117
|
+
'0a60b1ce 1d7e819d 7a431d7c 90ea0e5f').
|
118
|
+
replace(/ /g, ''), 'hex')
|
119
|
+
},
|
120
|
+
'nistp521': {
|
121
|
+
size: 521,
|
122
|
+
pkcs8oid: '1.3.132.0.35',
|
123
|
+
p: new Buffer((
|
124
|
+
'01ffffff ffffffff ffffffff ffffffff' +
|
125
|
+
'ffffffff ffffffff ffffffff ffffffff' +
|
126
|
+
'ffffffff ffffffff ffffffff ffffffff' +
|
127
|
+
'ffffffff ffffffff ffffffff ffffffff' +
|
128
|
+
'ffff').replace(/ /g, ''), 'hex'),
|
129
|
+
a: new Buffer(('01FF' +
|
130
|
+
'FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF' +
|
131
|
+
'FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF' +
|
132
|
+
'FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF' +
|
133
|
+
'FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFC').
|
134
|
+
replace(/ /g, ''), 'hex'),
|
135
|
+
b: new Buffer(('51' +
|
136
|
+
'953eb961 8e1c9a1f 929a21a0 b68540ee' +
|
137
|
+
'a2da725b 99b315f3 b8b48991 8ef109e1' +
|
138
|
+
'56193951 ec7e937b 1652c0bd 3bb1bf07' +
|
139
|
+
'3573df88 3d2c34f1 ef451fd4 6b503f00').
|
140
|
+
replace(/ /g, ''), 'hex'),
|
141
|
+
s: new Buffer(('00' +
|
142
|
+
'd09e8800 291cb853 96cc6717 393284aa' +
|
143
|
+
'a0da64ba').replace(/ /g, ''), 'hex'),
|
144
|
+
n: new Buffer(('01ff' +
|
145
|
+
'ffffffff ffffffff ffffffff ffffffff' +
|
146
|
+
'ffffffff ffffffff ffffffff fffffffa' +
|
147
|
+
'51868783 bf2f966b 7fcc0148 f709a5d0' +
|
148
|
+
'3bb5c9b8 899c47ae bb6fb71e 91386409').
|
149
|
+
replace(/ /g, ''), 'hex'),
|
150
|
+
G: new Buffer(('04' +
|
151
|
+
'00c6 858e06b7 0404e9cd 9e3ecb66 2395b442' +
|
152
|
+
'9c648139 053fb521 f828af60 6b4d3dba' +
|
153
|
+
'a14b5e77 efe75928 fe1dc127 a2ffa8de' +
|
154
|
+
'3348b3c1 856a429b f97e7e31 c2e5bd66' +
|
155
|
+
'0118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9' +
|
156
|
+
'98f54449 579b4468 17afbd17 273e662c' +
|
157
|
+
'97ee7299 5ef42640 c550b901 3fad0761' +
|
158
|
+
'353c7086 a272c240 88be9476 9fd16650').
|
159
|
+
replace(/ /g, ''), 'hex')
|
160
|
+
}
|
161
|
+
};
|
162
|
+
|
163
|
+
module.exports = {
|
164
|
+
info: algInfo,
|
165
|
+
privInfo: algPrivInfo,
|
166
|
+
hashAlgs: hashAlgs,
|
167
|
+
curves: curves
|
168
|
+
};
|
@@ -0,0 +1,312 @@
|
|
1
|
+
// Copyright 2015 Joyent, Inc.
|
2
|
+
|
3
|
+
module.exports = DiffieHellman;
|
4
|
+
|
5
|
+
var assert = require('assert-plus');
|
6
|
+
var crypto = require('crypto');
|
7
|
+
var algs = require('./algs');
|
8
|
+
var utils = require('./utils');
|
9
|
+
var ed;
|
10
|
+
|
11
|
+
var Key = require('./key');
|
12
|
+
var PrivateKey = require('./private-key');
|
13
|
+
|
14
|
+
var CRYPTO_HAVE_ECDH = (crypto.createECDH !== undefined &&
|
15
|
+
crypto.createECDH('prime256v1') !== undefined);
|
16
|
+
|
17
|
+
var ecdh, ec, jsbn;
|
18
|
+
|
19
|
+
function DiffieHellman(key) {
|
20
|
+
utils.assertCompatible(key, Key, [1, 4], 'key');
|
21
|
+
this._isPriv = PrivateKey.isPrivateKey(key, [1, 3]);
|
22
|
+
this._algo = key.type;
|
23
|
+
this._curve = key.curve;
|
24
|
+
this._key = key;
|
25
|
+
if (key.type === 'dsa') {
|
26
|
+
if (!CRYPTO_HAVE_ECDH) {
|
27
|
+
throw (new Error('Due to bugs in the node 0.10 ' +
|
28
|
+
'crypto API, node 0.12.x or later is required ' +
|
29
|
+
'to use DH'));
|
30
|
+
}
|
31
|
+
this._dh = crypto.createDiffieHellman(
|
32
|
+
key.part.p.data, undefined,
|
33
|
+
key.part.g.data, undefined);
|
34
|
+
this._p = key.part.p;
|
35
|
+
this._g = key.part.g;
|
36
|
+
if (this._isPriv)
|
37
|
+
this._dh.setPrivateKey(key.part.x.data);
|
38
|
+
this._dh.setPublicKey(key.part.y.data);
|
39
|
+
|
40
|
+
} else if (key.type === 'ecdsa') {
|
41
|
+
if (!CRYPTO_HAVE_ECDH) {
|
42
|
+
if (ecdh === undefined)
|
43
|
+
ecdh = require('ecc-jsbn');
|
44
|
+
if (ec === undefined)
|
45
|
+
ec = require('ecc-jsbn/lib/ec');
|
46
|
+
if (jsbn === undefined)
|
47
|
+
jsbn = require('jsbn').BigInteger;
|
48
|
+
|
49
|
+
this._ecParams = new X9ECParameters(this._curve);
|
50
|
+
|
51
|
+
if (this._isPriv) {
|
52
|
+
this._priv = new ECPrivate(
|
53
|
+
this._ecParams, key.part.d.data);
|
54
|
+
}
|
55
|
+
return;
|
56
|
+
}
|
57
|
+
|
58
|
+
var curve = {
|
59
|
+
'nistp256': 'prime256v1',
|
60
|
+
'nistp384': 'secp384r1',
|
61
|
+
'nistp521': 'secp521r1'
|
62
|
+
}[key.curve];
|
63
|
+
this._dh = crypto.createECDH(curve);
|
64
|
+
if (typeof (this._dh) !== 'object' ||
|
65
|
+
typeof (this._dh.setPrivateKey) !== 'function') {
|
66
|
+
CRYPTO_HAVE_ECDH = false;
|
67
|
+
DiffieHellman.call(this, key);
|
68
|
+
return;
|
69
|
+
}
|
70
|
+
if (this._isPriv)
|
71
|
+
this._dh.setPrivateKey(key.part.d.data);
|
72
|
+
this._dh.setPublicKey(key.part.Q.data);
|
73
|
+
|
74
|
+
} else if (key.type === 'curve25519') {
|
75
|
+
if (ed === undefined)
|
76
|
+
ed = require('jodid25519');
|
77
|
+
|
78
|
+
if (this._isPriv) {
|
79
|
+
this._priv = key.part.r.data;
|
80
|
+
if (this._priv[0] === 0x00)
|
81
|
+
this._priv = this._priv.slice(1);
|
82
|
+
this._priv = this._priv.slice(0, 32);
|
83
|
+
}
|
84
|
+
|
85
|
+
} else {
|
86
|
+
throw (new Error('DH not supported for ' + key.type + ' keys'));
|
87
|
+
}
|
88
|
+
}
|
89
|
+
|
90
|
+
DiffieHellman.prototype.getPublicKey = function () {
|
91
|
+
if (this._isPriv)
|
92
|
+
return (this._key.toPublic());
|
93
|
+
return (this._key);
|
94
|
+
};
|
95
|
+
|
96
|
+
DiffieHellman.prototype.getPrivateKey = function () {
|
97
|
+
if (this._isPriv)
|
98
|
+
return (this._key);
|
99
|
+
else
|
100
|
+
return (undefined);
|
101
|
+
};
|
102
|
+
DiffieHellman.prototype.getKey = DiffieHellman.prototype.getPrivateKey;
|
103
|
+
|
104
|
+
DiffieHellman.prototype._keyCheck = function (pk, isPub) {
|
105
|
+
assert.object(pk, 'key');
|
106
|
+
if (!isPub)
|
107
|
+
utils.assertCompatible(pk, PrivateKey, [1, 3], 'key');
|
108
|
+
utils.assertCompatible(pk, Key, [1, 4], 'key');
|
109
|
+
|
110
|
+
if (pk.type !== this._algo) {
|
111
|
+
throw (new Error('A ' + pk.type + ' key cannot be used in ' +
|
112
|
+
this._algo + ' Diffie-Hellman'));
|
113
|
+
}
|
114
|
+
|
115
|
+
if (pk.curve !== this._curve) {
|
116
|
+
throw (new Error('A key from the ' + pk.curve + ' curve ' +
|
117
|
+
'cannot be used with a ' + this._curve +
|
118
|
+
' Diffie-Hellman'));
|
119
|
+
}
|
120
|
+
|
121
|
+
if (pk.type === 'dsa') {
|
122
|
+
assert.deepEqual(pk.part.p, this._p,
|
123
|
+
'DSA key prime does not match');
|
124
|
+
assert.deepEqual(pk.part.g, this._g,
|
125
|
+
'DSA key generator does not match');
|
126
|
+
}
|
127
|
+
};
|
128
|
+
|
129
|
+
DiffieHellman.prototype.setKey = function (pk) {
|
130
|
+
this._keyCheck(pk);
|
131
|
+
|
132
|
+
if (pk.type === 'dsa') {
|
133
|
+
this._dh.setPrivateKey(pk.part.x.data);
|
134
|
+
this._dh.setPublicKey(pk.part.y.data);
|
135
|
+
|
136
|
+
} else if (pk.type === 'ecdsa') {
|
137
|
+
if (CRYPTO_HAVE_ECDH) {
|
138
|
+
this._dh.setPrivateKey(pk.part.d.data);
|
139
|
+
this._dh.setPublicKey(pk.part.Q.data);
|
140
|
+
} else {
|
141
|
+
this._priv = new ECPrivate(
|
142
|
+
this._ecParams, pk.part.d.data);
|
143
|
+
}
|
144
|
+
|
145
|
+
} else if (pk.type === 'curve25519') {
|
146
|
+
this._priv = pk.part.r.data;
|
147
|
+
if (this._priv[0] === 0x00)
|
148
|
+
this._priv = this._priv.slice(1);
|
149
|
+
this._priv = this._priv.slice(0, 32);
|
150
|
+
}
|
151
|
+
this._key = pk;
|
152
|
+
this._isPriv = true;
|
153
|
+
};
|
154
|
+
DiffieHellman.prototype.setPrivateKey = DiffieHellman.prototype.setKey;
|
155
|
+
|
156
|
+
DiffieHellman.prototype.computeSecret = function (otherpk) {
|
157
|
+
this._keyCheck(otherpk, true);
|
158
|
+
if (!this._isPriv)
|
159
|
+
throw (new Error('DH exchange has not been initialized with ' +
|
160
|
+
'a private key yet'));
|
161
|
+
|
162
|
+
var pub;
|
163
|
+
if (this._algo === 'dsa') {
|
164
|
+
return (this._dh.computeSecret(
|
165
|
+
otherpk.part.y.data));
|
166
|
+
|
167
|
+
} else if (this._algo === 'ecdsa') {
|
168
|
+
if (CRYPTO_HAVE_ECDH) {
|
169
|
+
return (this._dh.computeSecret(
|
170
|
+
otherpk.part.Q.data));
|
171
|
+
} else {
|
172
|
+
pub = new ECPublic(
|
173
|
+
this._ecParams, otherpk.part.Q.data);
|
174
|
+
return (this._priv.deriveSharedSecret(pub));
|
175
|
+
}
|
176
|
+
|
177
|
+
} else if (this._algo === 'curve25519') {
|
178
|
+
pub = otherpk.part.R.data;
|
179
|
+
if (pub[0] === 0x00)
|
180
|
+
pub = pub.slice(1);
|
181
|
+
|
182
|
+
var secret = ed.dh.computeKey(
|
183
|
+
this._priv.toString('binary'),
|
184
|
+
pub.toString('binary'));
|
185
|
+
|
186
|
+
return (new Buffer(secret, 'binary'));
|
187
|
+
}
|
188
|
+
|
189
|
+
throw (new Error('Invalid algorithm: ' + this._algo));
|
190
|
+
};
|
191
|
+
|
192
|
+
DiffieHellman.prototype.generateKey = function () {
|
193
|
+
var parts = [];
|
194
|
+
var priv, pub;
|
195
|
+
if (this._algo === 'dsa') {
|
196
|
+
this._dh.generateKeys();
|
197
|
+
|
198
|
+
parts.push({name: 'p', data: this._p.data});
|
199
|
+
parts.push({name: 'q', data: this._key.part.q.data});
|
200
|
+
parts.push({name: 'g', data: this._g.data});
|
201
|
+
parts.push({name: 'y', data: this._dh.getPublicKey()});
|
202
|
+
parts.push({name: 'x', data: this._dh.getPrivateKey()});
|
203
|
+
this._key = new PrivateKey({
|
204
|
+
type: 'dsa',
|
205
|
+
parts: parts
|
206
|
+
});
|
207
|
+
this._isPriv = true;
|
208
|
+
return (this._key);
|
209
|
+
|
210
|
+
} else if (this._algo === 'ecdsa') {
|
211
|
+
if (CRYPTO_HAVE_ECDH) {
|
212
|
+
this._dh.generateKeys();
|
213
|
+
|
214
|
+
parts.push({name: 'curve',
|
215
|
+
data: new Buffer(this._curve)});
|
216
|
+
parts.push({name: 'Q', data: this._dh.getPublicKey()});
|
217
|
+
parts.push({name: 'd', data: this._dh.getPrivateKey()});
|
218
|
+
this._key = new PrivateKey({
|
219
|
+
type: 'ecdsa',
|
220
|
+
curve: this._curve,
|
221
|
+
parts: parts
|
222
|
+
});
|
223
|
+
this._isPriv = true;
|
224
|
+
return (this._key);
|
225
|
+
|
226
|
+
} else {
|
227
|
+
var n = this._ecParams.getN();
|
228
|
+
var r = new jsbn(crypto.randomBytes(n.bitLength()));
|
229
|
+
var n1 = n.subtract(jsbn.ONE);
|
230
|
+
priv = r.mod(n1).add(jsbn.ONE);
|
231
|
+
pub = this._ecParams.getG().multiply(priv);
|
232
|
+
|
233
|
+
priv = new Buffer(priv.toByteArray());
|
234
|
+
pub = new Buffer(this._ecParams.getCurve().
|
235
|
+
encodePointHex(pub), 'hex');
|
236
|
+
|
237
|
+
this._priv = new ECPrivate(this._ecParams, priv);
|
238
|
+
|
239
|
+
parts.push({name: 'curve',
|
240
|
+
data: new Buffer(this._curve)});
|
241
|
+
parts.push({name: 'Q', data: pub});
|
242
|
+
parts.push({name: 'd', data: priv});
|
243
|
+
|
244
|
+
this._key = new PrivateKey({
|
245
|
+
type: 'ecdsa',
|
246
|
+
curve: this._curve,
|
247
|
+
parts: parts
|
248
|
+
});
|
249
|
+
this._isPriv = true;
|
250
|
+
return (this._key);
|
251
|
+
}
|
252
|
+
|
253
|
+
} else if (this._algo === 'curve25519') {
|
254
|
+
priv = ed.dh.generateKey();
|
255
|
+
pub = ed.dh.publicKey(priv);
|
256
|
+
this._priv = priv = new Buffer(priv, 'binary');
|
257
|
+
pub = new Buffer(pub, 'binary');
|
258
|
+
|
259
|
+
parts.push({name: 'R', data: pub});
|
260
|
+
parts.push({name: 'r', data: Buffer.concat([priv, pub])});
|
261
|
+
this._key = new PrivateKey({
|
262
|
+
type: 'curve25519',
|
263
|
+
parts: parts
|
264
|
+
});
|
265
|
+
this._isPriv = true;
|
266
|
+
return (this._key);
|
267
|
+
}
|
268
|
+
|
269
|
+
throw (new Error('Invalid algorithm: ' + this._algo));
|
270
|
+
};
|
271
|
+
DiffieHellman.prototype.generateKeys = DiffieHellman.prototype.generateKey;
|
272
|
+
|
273
|
+
/* These are helpers for using ecc-jsbn (for node 0.10 compatibility). */
|
274
|
+
|
275
|
+
function X9ECParameters(name) {
|
276
|
+
var params = algs.curves[name];
|
277
|
+
assert.object(params);
|
278
|
+
|
279
|
+
var p = new jsbn(params.p);
|
280
|
+
var a = new jsbn(params.a);
|
281
|
+
var b = new jsbn(params.b);
|
282
|
+
var n = new jsbn(params.n);
|
283
|
+
var h = jsbn.ONE;
|
284
|
+
var curve = new ec.ECCurveFp(p, a, b);
|
285
|
+
var G = curve.decodePointHex(params.G.toString('hex'));
|
286
|
+
|
287
|
+
this.curve = curve;
|
288
|
+
this.g = G;
|
289
|
+
this.n = n;
|
290
|
+
this.h = h;
|
291
|
+
}
|
292
|
+
X9ECParameters.prototype.getCurve = function () { return (this.curve); };
|
293
|
+
X9ECParameters.prototype.getG = function () { return (this.g); };
|
294
|
+
X9ECParameters.prototype.getN = function () { return (this.n); };
|
295
|
+
X9ECParameters.prototype.getH = function () { return (this.h); };
|
296
|
+
|
297
|
+
function ECPublic(params, buffer) {
|
298
|
+
this._params = params;
|
299
|
+
if (buffer[0] === 0x00)
|
300
|
+
buffer = buffer.slice(1);
|
301
|
+
this._pub = params.getCurve().decodePointHex(buffer.toString('hex'));
|
302
|
+
}
|
303
|
+
|
304
|
+
function ECPrivate(params, buffer) {
|
305
|
+
this._params = params;
|
306
|
+
this._priv = new jsbn(utils.mpNormalize(buffer));
|
307
|
+
}
|
308
|
+
ECPrivate.prototype.deriveSharedSecret = function (pubKey) {
|
309
|
+
assert.ok(pubKey instanceof ECPublic);
|
310
|
+
var S = pubKey._pub.multiply(this._priv);
|
311
|
+
return (new Buffer(S.getX().toBigInteger().toByteArray()));
|
312
|
+
};
|
@@ -0,0 +1,94 @@
|
|
1
|
+
// Copyright 2015 Joyent, Inc.
|
2
|
+
|
3
|
+
module.exports = {
|
4
|
+
Verifier: Verifier,
|
5
|
+
Signer: Signer
|
6
|
+
};
|
7
|
+
|
8
|
+
var nacl;
|
9
|
+
var stream = require('stream');
|
10
|
+
var util = require('util');
|
11
|
+
var assert = require('assert-plus');
|
12
|
+
var Signature = require('./signature');
|
13
|
+
|
14
|
+
function Verifier(key, hashAlgo) {
|
15
|
+
if (nacl === undefined)
|
16
|
+
nacl = require('tweetnacl');
|
17
|
+
|
18
|
+
if (hashAlgo.toLowerCase() !== 'sha512')
|
19
|
+
throw (new Error('ED25519 only supports the use of ' +
|
20
|
+
'SHA-512 hashes'));
|
21
|
+
|
22
|
+
this.key = key;
|
23
|
+
this.chunks = [];
|
24
|
+
|
25
|
+
stream.Writable.call(this, {});
|
26
|
+
}
|
27
|
+
util.inherits(Verifier, stream.Writable);
|
28
|
+
|
29
|
+
Verifier.prototype._write = function (chunk, enc, cb) {
|
30
|
+
this.chunks.push(chunk);
|
31
|
+
cb();
|
32
|
+
};
|
33
|
+
|
34
|
+
Verifier.prototype.update = function (chunk) {
|
35
|
+
if (typeof (chunk) === 'string')
|
36
|
+
chunk = new Buffer(chunk, 'binary');
|
37
|
+
this.chunks.push(chunk);
|
38
|
+
};
|
39
|
+
|
40
|
+
Verifier.prototype.verify = function (signature, fmt) {
|
41
|
+
var sig;
|
42
|
+
if (Signature.isSignature(signature, [2, 0])) {
|
43
|
+
sig = signature.toBuffer('raw');
|
44
|
+
|
45
|
+
} else if (typeof (signature) === 'string') {
|
46
|
+
sig = new Buffer(signature, 'base64');
|
47
|
+
|
48
|
+
} else if (Signature.isSignature(signature, [1, 0])) {
|
49
|
+
throw (new Error('signature was created by too old ' +
|
50
|
+
'a version of sshpk and cannot be verified'));
|
51
|
+
}
|
52
|
+
|
53
|
+
assert.buffer(sig);
|
54
|
+
return (nacl.sign.detached.verify(
|
55
|
+
new Uint8Array(Buffer.concat(this.chunks)),
|
56
|
+
new Uint8Array(sig),
|
57
|
+
new Uint8Array(this.key.part.R.data)));
|
58
|
+
};
|
59
|
+
|
60
|
+
function Signer(key, hashAlgo) {
|
61
|
+
if (nacl === undefined)
|
62
|
+
nacl = require('tweetnacl');
|
63
|
+
|
64
|
+
if (hashAlgo.toLowerCase() !== 'sha512')
|
65
|
+
throw (new Error('ED25519 only supports the use of ' +
|
66
|
+
'SHA-512 hashes'));
|
67
|
+
|
68
|
+
this.key = key;
|
69
|
+
this.chunks = [];
|
70
|
+
|
71
|
+
stream.Writable.call(this, {});
|
72
|
+
}
|
73
|
+
util.inherits(Signer, stream.Writable);
|
74
|
+
|
75
|
+
Signer.prototype._write = function (chunk, enc, cb) {
|
76
|
+
this.chunks.push(chunk);
|
77
|
+
cb();
|
78
|
+
};
|
79
|
+
|
80
|
+
Signer.prototype.update = function (chunk) {
|
81
|
+
if (typeof (chunk) === 'string')
|
82
|
+
chunk = new Buffer(chunk, 'binary');
|
83
|
+
this.chunks.push(chunk);
|
84
|
+
};
|
85
|
+
|
86
|
+
Signer.prototype.sign = function () {
|
87
|
+
var sig = nacl.sign.detached(
|
88
|
+
new Uint8Array(Buffer.concat(this.chunks)),
|
89
|
+
new Uint8Array(this.key.part.r.data));
|
90
|
+
var sigBuf = new Buffer(sig);
|
91
|
+
var sigObj = Signature.parse(sigBuf, 'ed25519', 'raw');
|
92
|
+
sigObj.hashAlgorithm = 'sha512';
|
93
|
+
return (sigObj);
|
94
|
+
};
|
@@ -0,0 +1,58 @@
|
|
1
|
+
// Copyright 2015 Joyent, Inc.
|
2
|
+
|
3
|
+
var assert = require('assert-plus');
|
4
|
+
var util = require('util');
|
5
|
+
|
6
|
+
function FingerprintFormatError(fp, format) {
|
7
|
+
if (Error.captureStackTrace)
|
8
|
+
Error.captureStackTrace(this, FingerprintFormatError);
|
9
|
+
this.name = 'FingerprintFormatError';
|
10
|
+
this.fingerprint = fp;
|
11
|
+
this.format = format;
|
12
|
+
this.message = 'Fingerprint format is not supported, or is invalid: ';
|
13
|
+
if (fp !== undefined)
|
14
|
+
this.message += ' fingerprint = ' + fp;
|
15
|
+
if (format !== undefined)
|
16
|
+
this.message += ' format = ' + format;
|
17
|
+
}
|
18
|
+
util.inherits(FingerprintFormatError, Error);
|
19
|
+
|
20
|
+
function InvalidAlgorithmError(alg) {
|
21
|
+
if (Error.captureStackTrace)
|
22
|
+
Error.captureStackTrace(this, InvalidAlgorithmError);
|
23
|
+
this.name = 'InvalidAlgorithmError';
|
24
|
+
this.algorithm = alg;
|
25
|
+
this.message = 'Algorithm "' + alg + '" is not supported';
|
26
|
+
}
|
27
|
+
util.inherits(InvalidAlgorithmError, Error);
|
28
|
+
|
29
|
+
function KeyParseError(name, format, innerErr) {
|
30
|
+
if (Error.captureStackTrace)
|
31
|
+
Error.captureStackTrace(this, KeyParseError);
|
32
|
+
this.name = 'KeyParseError';
|
33
|
+
this.format = format;
|
34
|
+
this.keyName = name;
|
35
|
+
this.innerErr = innerErr;
|
36
|
+
this.message = 'Failed to parse ' + name + ' as a valid ' + format +
|
37
|
+
' format key: ' + innerErr.message;
|
38
|
+
}
|
39
|
+
util.inherits(KeyParseError, Error);
|
40
|
+
|
41
|
+
function SignatureParseError(type, format, innerErr) {
|
42
|
+
if (Error.captureStackTrace)
|
43
|
+
Error.captureStackTrace(this, SignatureParseError);
|
44
|
+
this.name = 'SignatureParseError';
|
45
|
+
this.type = type;
|
46
|
+
this.format = format;
|
47
|
+
this.innerErr = innerErr;
|
48
|
+
this.message = 'Failed to parse the given data as a ' + type +
|
49
|
+
' signature in ' + format + ' format: ' + innerErr.message;
|
50
|
+
}
|
51
|
+
util.inherits(SignatureParseError, Error);
|
52
|
+
|
53
|
+
module.exports = {
|
54
|
+
FingerprintFormatError: FingerprintFormatError,
|
55
|
+
InvalidAlgorithmError: InvalidAlgorithmError,
|
56
|
+
KeyParseError: KeyParseError,
|
57
|
+
SignatureParseError: SignatureParseError
|
58
|
+
};
|