freezerwatch 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +10 -0
- data/CODE_OF_CONDUCT.md +13 -0
- data/Gemfile +4 -0
- data/LICENSE.txt +21 -0
- data/README.md +40 -0
- data/Rakefile +1 -0
- data/bin/console +14 -0
- data/bin/freezerwatch +9 -0
- data/bin/setup +7 -0
- data/freezerwatch.gemspec +23 -0
- data/lib/freezerwatch.rb +5 -0
- data/lib/freezerwatch/version.rb +3 -0
- data/node_modules/.bin/freezerwatch +139 -0
- data/node_modules/freezerwatch/.npmignore +3 -0
- data/node_modules/freezerwatch/.ruby-version +1 -0
- data/node_modules/freezerwatch/Gemfile +4 -0
- data/node_modules/freezerwatch/Gemfile.lock +79 -0
- data/node_modules/freezerwatch/LICENSE +23 -0
- data/node_modules/freezerwatch/README.md +41 -0
- data/node_modules/freezerwatch/Rakefile +13 -0
- data/node_modules/freezerwatch/freezerwatch.js +139 -0
- data/node_modules/freezerwatch/metrics/bigfiles_high_water_mark +1 -0
- data/node_modules/freezerwatch/metrics/cane_high_water_mark +1 -0
- data/node_modules/freezerwatch/metrics/flay_high_water_mark +1 -0
- data/node_modules/freezerwatch/metrics/flog_high_water_mark +1 -0
- data/node_modules/freezerwatch/metrics/punchlist_high_water_mark +2 -0
- data/node_modules/freezerwatch/metrics/reek_high_water_mark +1 -0
- data/node_modules/freezerwatch/metrics/rubocop_high_water_mark +1 -0
- data/node_modules/freezerwatch/node_modules/async/.jshintrc +25 -0
- data/node_modules/freezerwatch/node_modules/async/.travis.yml +6 -0
- data/node_modules/freezerwatch/node_modules/async/CHANGELOG.md +65 -0
- data/node_modules/freezerwatch/node_modules/async/LICENSE +19 -0
- data/node_modules/freezerwatch/node_modules/async/README.md +1803 -0
- data/node_modules/freezerwatch/node_modules/async/bower.json +43 -0
- data/node_modules/freezerwatch/node_modules/async/component.json +17 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/base.css +182 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/index.html +73 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/base.css +182 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/index.html +73 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/lib/async.js.html +3900 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/lib/index.html +73 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/prettify.css +1 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/prettify.js +1 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov-report/sorter.js +156 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lcov.info +1452 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lib/async.js.html +3597 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/lib/index.html +73 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/prettify.css +1 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/prettify.js +1 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/sort-arrow-sprite.png +0 -0
- data/node_modules/freezerwatch/node_modules/async/coverage/sorter.js +156 -0
- data/node_modules/freezerwatch/node_modules/async/lib/async.js +1191 -0
- data/node_modules/freezerwatch/node_modules/async/nyc_output/5074.json +1 -0
- data/node_modules/freezerwatch/node_modules/async/package.json +96 -0
- data/node_modules/freezerwatch/node_modules/async/support/sync-package-managers.js +53 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/.npmignore +15 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/Client.js +60 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/Device.js +38 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/DeviceRawReadStream.js +36 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/DeviceSingleRawReadStream.js +29 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/DeviceStream.js +35 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/LICENSE +23 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/README.md +25 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/index.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/.npmignore +2 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/.travis.yml +12 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/LICENSE +55 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/README.md +364 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/index.js +156 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/lib/copy.js +8 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/lib/debug.js +7 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/lib/getSafe.js +34 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/lib/optional.js +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/.bin/uuid +26 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/aws-sign2/LICENSE +55 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/aws-sign2/README.md +4 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/aws-sign2/index.js +202 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/aws-sign2/package.json +46 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/forever-agent/LICENSE +55 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/forever-agent/README.md +4 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/forever-agent/index.js +119 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/forever-agent/package.json +45 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/License +19 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/Readme.md +175 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/lib/form_data.js +351 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/.travis.yml +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/LICENSE +19 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/README.md +1647 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/bower.json +38 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/component.json +16 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/lib/async.js +1123 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/package.json +84 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/async/support/sync-package-managers.js +53 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/License +19 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/Readme.md +132 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/lib/combined_stream.js +188 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/.npmignore +2 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/License +19 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/Makefile +7 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/Readme.md +154 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/lib/delayed_stream.js +99 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/package.json +42 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/common.js +6 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-delayed-http-upload.js +38 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-delayed-stream-auto-pause.js +21 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-delayed-stream-pause.js +14 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-delayed-stream.js +48 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-handle-source-errors.js +15 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-max-data-size.js +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-pipe-resumes.js +13 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/integration/test-proxy-readable.js +13 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/node_modules/delayed-stream/test/run.js +7 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/node_modules/combined-stream/package.json +60 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/form-data/package.json +80 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/.npmignore +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/.travis.yml +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/LICENSE +24 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/Makefile +10 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/README.md +627 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/example/usage.js +78 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/images/hawk.png +0 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/images/logo.png +0 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/index.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/lib/browser.js +485 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/lib/client.js +367 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/lib/crypto.js +111 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/lib/index.js +15 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/lib/server.js +524 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/lib/utils.js +183 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/.npmignore +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/.travis.yml +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/LICENSE +24 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/Makefile +11 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/README.md +6 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/images/boom.png +0 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/index.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js +207 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/package.json +64 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/boom/test/index.js +245 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/.npmignore +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/.travis.yml +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/LICENSE +24 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/Makefile +11 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/README.md +6 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/index.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/lib/index.js +68 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/package.json +65 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/cryptiles/test/index.js +101 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/.npmignore +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/.travis.yml +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/LICENSE +33 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/Makefile +10 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/README.md +436 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/images/hoek.png +0 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/index.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/lib/escape.js +132 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/lib/index.js +585 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/package.json +70 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/test/escaper.js +86 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/test/index.js +1078 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/test/modules/test1.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/test/modules/test2.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/hoek/test/modules/test3.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/.npmignore +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/.travis.yml +5 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/LICENSE +24 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/Makefile +11 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/README.md +68 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/examples/offset.js +16 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/examples/time.js +25 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/index.js +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/lib/index.js +409 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/package.json +65 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/node_modules/sntp/test/index.js +359 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/package.json +70 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/browser.js +771 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/client.js +206 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/crypto.js +86 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/index.js +316 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/message.js +246 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/readme.js +98 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/server.js +686 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/uri.js +456 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/hawk/test/utils.js +120 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/.dir-locals.el +6 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/.npmignore +7 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/LICENSE +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/README.md +79 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/http_signing.md +296 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/lib/index.js +26 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/lib/parser.js +304 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/lib/signer.js +178 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/lib/util.js +304 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/lib/verify.js +42 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/.npmignore +2 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/LICENSE +19 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/README.md +50 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/lib/ber/errors.js +13 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/lib/ber/index.js +27 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/lib/ber/reader.js +267 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/lib/ber/types.js +36 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/lib/ber/writer.js +317 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/lib/index.js +20 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/package.json +63 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/tst/ber/reader.test.js +172 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/asn1/tst/ber/writer.test.js +296 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/assert-plus/README.md +126 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/assert-plus/assert.js +245 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/assert-plus/package.json +45 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/.npmignore +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/CHANGELOG +78 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/LICENSE +24 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/README +82 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/README.old +298 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/ctf.js +245 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/ctio.js +1485 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/ctype.js +944 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/man/man3ctype/ctio.3ctype +241 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/package.json +42 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/tools/jsl.conf +129 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/node_modules/ctype/tools/jsstyle +839 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/http-signature/package.json +72 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/.npmignore +1 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/CHANGELOG.md +14 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/LICENSE +15 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/Makefile +35 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/README.md +52 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/package.json +68 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/stringify.js +27 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/test/mocha.opts +2 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/json-stringify-safe/test/stringify_test.js +246 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/LICENSE +19 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/README.md +66 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/mime.js +114 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/package.json +57 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/test.js +84 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/types/mime.types +1588 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/mime/types/node.types +77 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/.npmignore +2 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/LICENSE.md +21 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/README.md +243 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/benchmark/README.md +53 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/benchmark/bench.gnu +174 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/benchmark/bench.sh +34 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/benchmark/benchmark-native.c +34 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/benchmark/benchmark.js +84 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/bin/uuid +26 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/bower.json +23 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/component.json +18 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/package.json +65 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/test/compare_v1.js +63 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/test/test.html +17 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/test/test.js +228 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/node-uuid/uuid.js +247 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/oauth-sign/LICENSE +55 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/oauth-sign/README.md +4 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/oauth-sign/index.js +43 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/oauth-sign/package.json +48 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/oauth-sign/test.js +49 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/qs/.gitmodules +6 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/qs/.npmignore +7 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/qs/Readme.md +58 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/qs/index.js +366 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/qs/package.json +55 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/.jshintrc +72 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/.npmignore +3 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/LICENSE +78 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/README.md +380 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/generate-pubsuffix.js +230 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/lib/cookie.js +947 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/lib/memstore.js +102 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/lib/pubsuffix.js +69 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/node_modules/punycode/LICENSE-MIT.txt +20 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/node_modules/punycode/README.md +176 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/node_modules/punycode/package.json +81 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/node_modules/punycode/punycode.js +530 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/package.json +63 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/public-suffix.txt +5229 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tough-cookie/test.js +1340 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tunnel-agent/LICENSE +55 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tunnel-agent/README.md +4 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tunnel-agent/index.js +227 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/node_modules/tunnel-agent/package.json +45 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/package.json +74 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/node_modules/request/request.js +1244 -0
- data/node_modules/freezerwatch/node_modules/lacrosse/package.json +34 -0
- data/node_modules/freezerwatch/node_modules/optparse/README.md +163 -0
- data/node_modules/freezerwatch/node_modules/optparse/TODO +1 -0
- data/node_modules/freezerwatch/node_modules/optparse/examples/browser-test.html +75 -0
- data/node_modules/freezerwatch/node_modules/optparse/examples/nodejs-test.js +86 -0
- data/node_modules/freezerwatch/node_modules/optparse/lib/optparse.js +309 -0
- data/node_modules/freezerwatch/node_modules/optparse/package.json +46 -0
- data/node_modules/freezerwatch/node_modules/optparse/seed.yml +5 -0
- data/node_modules/freezerwatch/node_modules/osenv/.npmignore +13 -0
- data/node_modules/freezerwatch/node_modules/osenv/.travis.yml +9 -0
- data/node_modules/freezerwatch/node_modules/osenv/LICENSE +15 -0
- data/node_modules/freezerwatch/node_modules/osenv/README.md +63 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-homedir/index.js +24 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-homedir/license +21 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-homedir/package.json +70 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-homedir/readme.md +33 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-tmpdir/index.js +25 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-tmpdir/license +21 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-tmpdir/package.json +70 -0
- data/node_modules/freezerwatch/node_modules/osenv/node_modules/os-tmpdir/readme.md +36 -0
- data/node_modules/freezerwatch/node_modules/osenv/osenv.js +72 -0
- data/node_modules/freezerwatch/node_modules/osenv/package.json +76 -0
- data/node_modules/freezerwatch/node_modules/osenv/test/unix.js +71 -0
- data/node_modules/freezerwatch/node_modules/osenv/test/windows.js +74 -0
- data/node_modules/freezerwatch/node_modules/osenv/x.tap +39 -0
- data/node_modules/freezerwatch/package.json +37 -0
- metadata +384 -0
@@ -0,0 +1,15 @@
|
|
1
|
+
// Export sub-modules
|
2
|
+
|
3
|
+
exports.error = exports.Error = require('boom');
|
4
|
+
exports.sntp = require('sntp');
|
5
|
+
exports.server = require('./server');
|
6
|
+
exports.client = require('./client');
|
7
|
+
exports.crypto = require('./crypto');
|
8
|
+
exports.utils = require('./utils');
|
9
|
+
|
10
|
+
exports.uri = {
|
11
|
+
authenticate: exports.server.authenticateBewit,
|
12
|
+
getBewit: exports.client.getBewit
|
13
|
+
};
|
14
|
+
|
15
|
+
|
@@ -0,0 +1,524 @@
|
|
1
|
+
// Load modules
|
2
|
+
|
3
|
+
var Boom = require('boom');
|
4
|
+
var Hoek = require('hoek');
|
5
|
+
var Cryptiles = require('cryptiles');
|
6
|
+
var Crypto = require('./crypto');
|
7
|
+
var Utils = require('./utils');
|
8
|
+
|
9
|
+
|
10
|
+
// Declare internals
|
11
|
+
|
12
|
+
var internals = {};
|
13
|
+
|
14
|
+
|
15
|
+
// Hawk authentication
|
16
|
+
|
17
|
+
/*
|
18
|
+
req: node's HTTP request object or an object as follows:
|
19
|
+
|
20
|
+
var request = {
|
21
|
+
method: 'GET',
|
22
|
+
url: '/resource/4?a=1&b=2',
|
23
|
+
host: 'example.com',
|
24
|
+
port: 8080,
|
25
|
+
authorization: 'Hawk id="dh37fgj492je", ts="1353832234", nonce="j4h3g2", ext="some-app-ext-data", mac="6R4rV5iE+NPoym+WwjeHzjAGXUtLNIxmo1vpMofpLAE="'
|
26
|
+
};
|
27
|
+
|
28
|
+
credentialsFunc: required function to lookup the set of Hawk credentials based on the provided credentials id.
|
29
|
+
The credentials include the MAC key, MAC algorithm, and other attributes (such as username)
|
30
|
+
needed by the application. This function is the equivalent of verifying the username and
|
31
|
+
password in Basic authentication.
|
32
|
+
|
33
|
+
var credentialsFunc = function (id, callback) {
|
34
|
+
|
35
|
+
// Lookup credentials in database
|
36
|
+
db.lookup(id, function (err, item) {
|
37
|
+
|
38
|
+
if (err || !item) {
|
39
|
+
return callback(err);
|
40
|
+
}
|
41
|
+
|
42
|
+
var credentials = {
|
43
|
+
// Required
|
44
|
+
key: item.key,
|
45
|
+
algorithm: item.algorithm,
|
46
|
+
// Application specific
|
47
|
+
user: item.user
|
48
|
+
};
|
49
|
+
|
50
|
+
return callback(null, credentials);
|
51
|
+
});
|
52
|
+
};
|
53
|
+
|
54
|
+
options: {
|
55
|
+
|
56
|
+
hostHeaderName: optional header field name, used to override the default 'Host' header when used
|
57
|
+
behind a cache of a proxy. Apache2 changes the value of the 'Host' header while preserving
|
58
|
+
the original (which is what the module must verify) in the 'x-forwarded-host' header field.
|
59
|
+
Only used when passed a node Http.ServerRequest object.
|
60
|
+
|
61
|
+
nonceFunc: optional nonce validation function. The function signature is function(nonce, ts, callback)
|
62
|
+
where 'callback' must be called using the signature function(err).
|
63
|
+
|
64
|
+
timestampSkewSec: optional number of seconds of permitted clock skew for incoming timestamps. Defaults to 60 seconds.
|
65
|
+
Provides a +/- skew which means actual allowed window is double the number of seconds.
|
66
|
+
|
67
|
+
localtimeOffsetMsec: optional local clock time offset express in a number of milliseconds (positive or negative).
|
68
|
+
Defaults to 0.
|
69
|
+
|
70
|
+
payload: optional payload for validation. The client calculates the hash value and includes it via the 'hash'
|
71
|
+
header attribute. The server always ensures the value provided has been included in the request
|
72
|
+
MAC. When this option is provided, it validates the hash value itself. Validation is done by calculating
|
73
|
+
a hash value over the entire payload (assuming it has already be normalized to the same format and
|
74
|
+
encoding used by the client to calculate the hash on request). If the payload is not available at the time
|
75
|
+
of authentication, the authenticatePayload() method can be used by passing it the credentials and
|
76
|
+
attributes.hash returned in the authenticate callback.
|
77
|
+
|
78
|
+
host: optional host name override. Only used when passed a node request object.
|
79
|
+
port: optional port override. Only used when passed a node request object.
|
80
|
+
}
|
81
|
+
|
82
|
+
callback: function (err, credentials, artifacts) { }
|
83
|
+
*/
|
84
|
+
|
85
|
+
exports.authenticate = function (req, credentialsFunc, options, callback) {
|
86
|
+
|
87
|
+
callback = Utils.nextTick(callback);
|
88
|
+
|
89
|
+
// Default options
|
90
|
+
|
91
|
+
options.nonceFunc = options.nonceFunc || function (nonce, ts, nonceCallback) { return nonceCallback(); }; // No validation
|
92
|
+
options.timestampSkewSec = options.timestampSkewSec || 60; // 60 seconds
|
93
|
+
|
94
|
+
// Application time
|
95
|
+
|
96
|
+
var now = Utils.now() + (options.localtimeOffsetMsec || 0); // Measure now before any other processing
|
97
|
+
|
98
|
+
// Convert node Http request object to a request configuration object
|
99
|
+
|
100
|
+
var request = Utils.parseRequest(req, options);
|
101
|
+
if (request instanceof Error) {
|
102
|
+
return callback(Boom.badRequest(request.message));
|
103
|
+
}
|
104
|
+
|
105
|
+
// Parse HTTP Authorization header
|
106
|
+
|
107
|
+
var attributes = Utils.parseAuthorizationHeader(request.authorization);
|
108
|
+
if (attributes instanceof Error) {
|
109
|
+
return callback(attributes);
|
110
|
+
}
|
111
|
+
|
112
|
+
// Construct artifacts container
|
113
|
+
|
114
|
+
var artifacts = {
|
115
|
+
method: request.method,
|
116
|
+
host: request.host,
|
117
|
+
port: request.port,
|
118
|
+
resource: request.url,
|
119
|
+
ts: attributes.ts,
|
120
|
+
nonce: attributes.nonce,
|
121
|
+
hash: attributes.hash,
|
122
|
+
ext: attributes.ext,
|
123
|
+
app: attributes.app,
|
124
|
+
dlg: attributes.dlg,
|
125
|
+
mac: attributes.mac,
|
126
|
+
id: attributes.id
|
127
|
+
};
|
128
|
+
|
129
|
+
// Verify required header attributes
|
130
|
+
|
131
|
+
if (!attributes.id ||
|
132
|
+
!attributes.ts ||
|
133
|
+
!attributes.nonce ||
|
134
|
+
!attributes.mac) {
|
135
|
+
|
136
|
+
return callback(Boom.badRequest('Missing attributes'), null, artifacts);
|
137
|
+
}
|
138
|
+
|
139
|
+
// Fetch Hawk credentials
|
140
|
+
|
141
|
+
credentialsFunc(attributes.id, function (err, credentials) {
|
142
|
+
|
143
|
+
if (err) {
|
144
|
+
return callback(err, credentials || null, artifacts);
|
145
|
+
}
|
146
|
+
|
147
|
+
if (!credentials) {
|
148
|
+
return callback(Boom.unauthorized('Unknown credentials', 'Hawk'), null, artifacts);
|
149
|
+
}
|
150
|
+
|
151
|
+
if (!credentials.key ||
|
152
|
+
!credentials.algorithm) {
|
153
|
+
|
154
|
+
return callback(Boom.internal('Invalid credentials'), credentials, artifacts);
|
155
|
+
}
|
156
|
+
|
157
|
+
if (Crypto.algorithms.indexOf(credentials.algorithm) === -1) {
|
158
|
+
return callback(Boom.internal('Unknown algorithm'), credentials, artifacts);
|
159
|
+
}
|
160
|
+
|
161
|
+
// Calculate MAC
|
162
|
+
|
163
|
+
var mac = Crypto.calculateMac('header', credentials, artifacts);
|
164
|
+
if (!Cryptiles.fixedTimeComparison(mac, attributes.mac)) {
|
165
|
+
return callback(Boom.unauthorized('Bad mac', 'Hawk'), credentials, artifacts);
|
166
|
+
}
|
167
|
+
|
168
|
+
// Check payload hash
|
169
|
+
|
170
|
+
if (options.payload !== null &&
|
171
|
+
options.payload !== undefined) { // '' is valid
|
172
|
+
|
173
|
+
if (!attributes.hash) {
|
174
|
+
return callback(Boom.unauthorized('Missing required payload hash', 'Hawk'), credentials, artifacts);
|
175
|
+
}
|
176
|
+
|
177
|
+
var hash = Crypto.calculatePayloadHash(options.payload, credentials.algorithm, request.contentType);
|
178
|
+
if (!Cryptiles.fixedTimeComparison(hash, attributes.hash)) {
|
179
|
+
return callback(Boom.unauthorized('Bad payload hash', 'Hawk'), credentials, artifacts);
|
180
|
+
}
|
181
|
+
}
|
182
|
+
|
183
|
+
// Check nonce
|
184
|
+
|
185
|
+
options.nonceFunc(attributes.nonce, attributes.ts, function (err) {
|
186
|
+
|
187
|
+
if (err) {
|
188
|
+
return callback(Boom.unauthorized('Invalid nonce', 'Hawk'), credentials, artifacts);
|
189
|
+
}
|
190
|
+
|
191
|
+
// Check timestamp staleness
|
192
|
+
|
193
|
+
if (Math.abs((attributes.ts * 1000) - now) > (options.timestampSkewSec * 1000)) {
|
194
|
+
var fresh = Math.floor((Utils.now() + (options.localtimeOffsetMsec || 0)) / 1000); // Get fresh now
|
195
|
+
var tsm = Crypto.calculateTsMac(fresh, credentials);
|
196
|
+
return callback(Boom.unauthorized('Stale timestamp', 'Hawk', { ts: fresh, tsm: tsm }), credentials, artifacts);
|
197
|
+
}
|
198
|
+
|
199
|
+
// Successful authentication
|
200
|
+
|
201
|
+
return callback(null, credentials, artifacts);
|
202
|
+
});
|
203
|
+
});
|
204
|
+
};
|
205
|
+
|
206
|
+
|
207
|
+
// Authenticate payload hash - used when payload cannot be provided during authenticate()
|
208
|
+
|
209
|
+
/*
|
210
|
+
payload: raw request payload
|
211
|
+
credentials: from authenticate callback
|
212
|
+
artifacts: from authenticate callback
|
213
|
+
contentType: req.headers['content-type']
|
214
|
+
*/
|
215
|
+
|
216
|
+
exports.authenticatePayload = function (payload, credentials, artifacts, contentType) {
|
217
|
+
|
218
|
+
var calculatedHash = Crypto.calculatePayloadHash(payload, credentials.algorithm, contentType);
|
219
|
+
return Cryptiles.fixedTimeComparison(calculatedHash, artifacts.hash);
|
220
|
+
};
|
221
|
+
|
222
|
+
|
223
|
+
// Generate a Server-Authorization header for a given response
|
224
|
+
|
225
|
+
/*
|
226
|
+
credentials: {}, // Object received from authenticate()
|
227
|
+
artifacts: {} // Object received from authenticate(); 'mac', 'hash', and 'ext' - ignored
|
228
|
+
options: {
|
229
|
+
ext: 'application-specific', // Application specific data sent via the ext attribute
|
230
|
+
payload: '{"some":"payload"}', // UTF-8 encoded string for body hash generation (ignored if hash provided)
|
231
|
+
contentType: 'application/json', // Payload content-type (ignored if hash provided)
|
232
|
+
hash: 'U4MKKSmiVxk37JCCrAVIjV=' // Pre-calculated payload hash
|
233
|
+
}
|
234
|
+
*/
|
235
|
+
|
236
|
+
exports.header = function (credentials, artifacts, options) {
|
237
|
+
|
238
|
+
// Prepare inputs
|
239
|
+
|
240
|
+
options = options || {};
|
241
|
+
|
242
|
+
if (!artifacts ||
|
243
|
+
typeof artifacts !== 'object' ||
|
244
|
+
typeof options !== 'object') {
|
245
|
+
|
246
|
+
return '';
|
247
|
+
}
|
248
|
+
|
249
|
+
artifacts = Hoek.clone(artifacts);
|
250
|
+
delete artifacts.mac;
|
251
|
+
artifacts.hash = options.hash;
|
252
|
+
artifacts.ext = options.ext;
|
253
|
+
|
254
|
+
// Validate credentials
|
255
|
+
|
256
|
+
if (!credentials ||
|
257
|
+
!credentials.key ||
|
258
|
+
!credentials.algorithm) {
|
259
|
+
|
260
|
+
// Invalid credential object
|
261
|
+
return '';
|
262
|
+
}
|
263
|
+
|
264
|
+
if (Crypto.algorithms.indexOf(credentials.algorithm) === -1) {
|
265
|
+
return '';
|
266
|
+
}
|
267
|
+
|
268
|
+
// Calculate payload hash
|
269
|
+
|
270
|
+
if (!artifacts.hash &&
|
271
|
+
options.hasOwnProperty('payload')) {
|
272
|
+
|
273
|
+
artifacts.hash = Crypto.calculatePayloadHash(options.payload, credentials.algorithm, options.contentType);
|
274
|
+
}
|
275
|
+
|
276
|
+
var mac = Crypto.calculateMac('response', credentials, artifacts);
|
277
|
+
|
278
|
+
// Construct header
|
279
|
+
|
280
|
+
var header = 'Hawk mac="' + mac + '"' +
|
281
|
+
(artifacts.hash ? ', hash="' + artifacts.hash + '"' : '');
|
282
|
+
|
283
|
+
if (artifacts.ext !== null &&
|
284
|
+
artifacts.ext !== undefined &&
|
285
|
+
artifacts.ext !== '') { // Other falsey values allowed
|
286
|
+
|
287
|
+
header += ', ext="' + Utils.escapeHeaderAttribute(artifacts.ext) + '"';
|
288
|
+
}
|
289
|
+
|
290
|
+
return header;
|
291
|
+
};
|
292
|
+
|
293
|
+
|
294
|
+
/*
|
295
|
+
* Arguments and options are the same as authenticate() with the exception that the only supported options are:
|
296
|
+
* 'hostHeaderName', 'localtimeOffsetMsec', 'host', 'port'
|
297
|
+
*/
|
298
|
+
|
299
|
+
exports.authenticateBewit = function (req, credentialsFunc, options, callback) {
|
300
|
+
|
301
|
+
callback = Utils.nextTick(callback);
|
302
|
+
|
303
|
+
// Application time
|
304
|
+
|
305
|
+
var now = Utils.now() + (options.localtimeOffsetMsec || 0);
|
306
|
+
|
307
|
+
// Convert node Http request object to a request configuration object
|
308
|
+
|
309
|
+
var request = Utils.parseRequest(req, options);
|
310
|
+
if (request instanceof Error) {
|
311
|
+
return callback(Boom.badRequest(request.message));
|
312
|
+
}
|
313
|
+
|
314
|
+
// Extract bewit
|
315
|
+
|
316
|
+
// 1 2 3 4
|
317
|
+
var resource = request.url.match(/^(\/.*)([\?&])bewit\=([^&$]*)(?:&(.+))?$/);
|
318
|
+
if (!resource) {
|
319
|
+
return callback(Boom.unauthorized(null, 'Hawk'));
|
320
|
+
}
|
321
|
+
|
322
|
+
// Bewit not empty
|
323
|
+
|
324
|
+
if (!resource[3]) {
|
325
|
+
return callback(Boom.unauthorized('Empty bewit', 'Hawk'));
|
326
|
+
}
|
327
|
+
|
328
|
+
// Verify method is GET
|
329
|
+
|
330
|
+
if (request.method !== 'GET' &&
|
331
|
+
request.method !== 'HEAD') {
|
332
|
+
|
333
|
+
return callback(Boom.unauthorized('Invalid method', 'Hawk'));
|
334
|
+
}
|
335
|
+
|
336
|
+
// No other authentication
|
337
|
+
|
338
|
+
if (request.authorization) {
|
339
|
+
return callback(Boom.badRequest('Multiple authentications', 'Hawk'));
|
340
|
+
}
|
341
|
+
|
342
|
+
// Parse bewit
|
343
|
+
|
344
|
+
var bewitString = Utils.base64urlDecode(resource[3]);
|
345
|
+
if (bewitString instanceof Error) {
|
346
|
+
return callback(Boom.badRequest('Invalid bewit encoding'));
|
347
|
+
}
|
348
|
+
|
349
|
+
// Bewit format: id\exp\mac\ext ('\' is used because it is a reserved header attribute character)
|
350
|
+
|
351
|
+
var bewitParts = bewitString.split('\\');
|
352
|
+
if (!bewitParts ||
|
353
|
+
bewitParts.length !== 4) {
|
354
|
+
|
355
|
+
return callback(Boom.badRequest('Invalid bewit structure'));
|
356
|
+
}
|
357
|
+
|
358
|
+
var bewit = {
|
359
|
+
id: bewitParts[0],
|
360
|
+
exp: parseInt(bewitParts[1], 10),
|
361
|
+
mac: bewitParts[2],
|
362
|
+
ext: bewitParts[3] || ''
|
363
|
+
};
|
364
|
+
|
365
|
+
if (!bewit.id ||
|
366
|
+
!bewit.exp ||
|
367
|
+
!bewit.mac) {
|
368
|
+
|
369
|
+
return callback(Boom.badRequest('Missing bewit attributes'));
|
370
|
+
}
|
371
|
+
|
372
|
+
// Construct URL without bewit
|
373
|
+
|
374
|
+
var url = resource[1];
|
375
|
+
if (resource[4]) {
|
376
|
+
url += resource[2] + resource[4];
|
377
|
+
}
|
378
|
+
|
379
|
+
// Check expiration
|
380
|
+
|
381
|
+
if (bewit.exp * 1000 <= now) {
|
382
|
+
return callback(Boom.unauthorized('Access expired', 'Hawk'), null, bewit);
|
383
|
+
}
|
384
|
+
|
385
|
+
// Fetch Hawk credentials
|
386
|
+
|
387
|
+
credentialsFunc(bewit.id, function (err, credentials) {
|
388
|
+
|
389
|
+
if (err) {
|
390
|
+
return callback(err, credentials || null, bewit.ext);
|
391
|
+
}
|
392
|
+
|
393
|
+
if (!credentials) {
|
394
|
+
return callback(Boom.unauthorized('Unknown credentials', 'Hawk'), null, bewit);
|
395
|
+
}
|
396
|
+
|
397
|
+
if (!credentials.key ||
|
398
|
+
!credentials.algorithm) {
|
399
|
+
|
400
|
+
return callback(Boom.internal('Invalid credentials'), credentials, bewit);
|
401
|
+
}
|
402
|
+
|
403
|
+
if (Crypto.algorithms.indexOf(credentials.algorithm) === -1) {
|
404
|
+
return callback(Boom.internal('Unknown algorithm'), credentials, bewit);
|
405
|
+
}
|
406
|
+
|
407
|
+
// Calculate MAC
|
408
|
+
|
409
|
+
var mac = Crypto.calculateMac('bewit', credentials, {
|
410
|
+
ts: bewit.exp,
|
411
|
+
nonce: '',
|
412
|
+
method: 'GET',
|
413
|
+
resource: url,
|
414
|
+
host: request.host,
|
415
|
+
port: request.port,
|
416
|
+
ext: bewit.ext
|
417
|
+
});
|
418
|
+
|
419
|
+
if (!Cryptiles.fixedTimeComparison(mac, bewit.mac)) {
|
420
|
+
return callback(Boom.unauthorized('Bad mac', 'Hawk'), credentials, bewit);
|
421
|
+
}
|
422
|
+
|
423
|
+
// Successful authentication
|
424
|
+
|
425
|
+
return callback(null, credentials, bewit);
|
426
|
+
});
|
427
|
+
};
|
428
|
+
|
429
|
+
|
430
|
+
/*
|
431
|
+
* options are the same as authenticate() with the exception that the only supported options are:
|
432
|
+
* 'nonceFunc', 'timestampSkewSec', 'localtimeOffsetMsec'
|
433
|
+
*/
|
434
|
+
|
435
|
+
exports.authenticateMessage = function (host, port, message, authorization, credentialsFunc, options, callback) {
|
436
|
+
|
437
|
+
callback = Utils.nextTick(callback);
|
438
|
+
|
439
|
+
// Default options
|
440
|
+
|
441
|
+
options.nonceFunc = options.nonceFunc || function (nonce, ts, nonceCallback) { return nonceCallback(); }; // No validation
|
442
|
+
options.timestampSkewSec = options.timestampSkewSec || 60; // 60 seconds
|
443
|
+
|
444
|
+
// Application time
|
445
|
+
|
446
|
+
var now = Utils.now() + (options.localtimeOffsetMsec || 0); // Measure now before any other processing
|
447
|
+
|
448
|
+
// Validate authorization
|
449
|
+
|
450
|
+
if (!authorization.id ||
|
451
|
+
!authorization.ts ||
|
452
|
+
!authorization.nonce ||
|
453
|
+
!authorization.hash ||
|
454
|
+
!authorization.mac) {
|
455
|
+
|
456
|
+
return callback(Boom.badRequest('Invalid authorization'))
|
457
|
+
}
|
458
|
+
|
459
|
+
// Fetch Hawk credentials
|
460
|
+
|
461
|
+
credentialsFunc(authorization.id, function (err, credentials) {
|
462
|
+
|
463
|
+
if (err) {
|
464
|
+
return callback(err, credentials || null);
|
465
|
+
}
|
466
|
+
|
467
|
+
if (!credentials) {
|
468
|
+
return callback(Boom.unauthorized('Unknown credentials', 'Hawk'));
|
469
|
+
}
|
470
|
+
|
471
|
+
if (!credentials.key ||
|
472
|
+
!credentials.algorithm) {
|
473
|
+
|
474
|
+
return callback(Boom.internal('Invalid credentials'), credentials);
|
475
|
+
}
|
476
|
+
|
477
|
+
if (Crypto.algorithms.indexOf(credentials.algorithm) === -1) {
|
478
|
+
return callback(Boom.internal('Unknown algorithm'), credentials);
|
479
|
+
}
|
480
|
+
|
481
|
+
// Construct artifacts container
|
482
|
+
|
483
|
+
var artifacts = {
|
484
|
+
ts: authorization.ts,
|
485
|
+
nonce: authorization.nonce,
|
486
|
+
host: host,
|
487
|
+
port: port,
|
488
|
+
hash: authorization.hash
|
489
|
+
};
|
490
|
+
|
491
|
+
// Calculate MAC
|
492
|
+
|
493
|
+
var mac = Crypto.calculateMac('message', credentials, artifacts);
|
494
|
+
if (!Cryptiles.fixedTimeComparison(mac, authorization.mac)) {
|
495
|
+
return callback(Boom.unauthorized('Bad mac', 'Hawk'), credentials);
|
496
|
+
}
|
497
|
+
|
498
|
+
// Check payload hash
|
499
|
+
|
500
|
+
var hash = Crypto.calculatePayloadHash(message, credentials.algorithm);
|
501
|
+
if (!Cryptiles.fixedTimeComparison(hash, authorization.hash)) {
|
502
|
+
return callback(Boom.unauthorized('Bad message hash', 'Hawk'), credentials);
|
503
|
+
}
|
504
|
+
|
505
|
+
// Check nonce
|
506
|
+
|
507
|
+
options.nonceFunc(authorization.nonce, authorization.ts, function (err) {
|
508
|
+
|
509
|
+
if (err) {
|
510
|
+
return callback(Boom.unauthorized('Invalid nonce', 'Hawk'), credentials);
|
511
|
+
}
|
512
|
+
|
513
|
+
// Check timestamp staleness
|
514
|
+
|
515
|
+
if (Math.abs((authorization.ts * 1000) - now) > (options.timestampSkewSec * 1000)) {
|
516
|
+
return callback(Boom.unauthorized('Stale timestamp'), credentials);
|
517
|
+
}
|
518
|
+
|
519
|
+
// Successful authentication
|
520
|
+
|
521
|
+
return callback(null, credentials);
|
522
|
+
});
|
523
|
+
});
|
524
|
+
};
|